[INFO] fetching crate amcl_wrapper 0.4.0...
[INFO] testing amcl_wrapper-0.4.0 against try#c2e32f1c9652b13ed99608599c1e855462f421f3 for pr-146098-7
[INFO] extracting crate amcl_wrapper 0.4.0 into /workspace/builds/worker-0-tc2/source
[INFO] started tweaking crates.io crate amcl_wrapper 0.4.0
[INFO] finished tweaking crates.io crate amcl_wrapper 0.4.0
[INFO] tweaked toml for crates.io crate amcl_wrapper 0.4.0 written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate amcl_wrapper 0.4.0 on toolchain c2e32f1c9652b13ed99608599c1e855462f421f3
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 44 packages to latest compatible versions
[INFO] [stderr]       Adding miracl_core v1.0.0 (available: v2.7.0)
[INFO] [stderr]       Adding rand v0.7.3 (available: v0.9.2)
[INFO] [stderr]       Adding sha3 v0.8.2 (available: v0.10.8)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 6f4d9383eb949c5b78456bca1354eb3e36bb0ad26bf186a6fba25e9bc27850aa
[INFO] running `Command { std: "docker" "start" "-a" "6f4d9383eb949c5b78456bca1354eb3e36bb0ad26bf186a6fba25e9bc27850aa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "6f4d9383eb949c5b78456bca1354eb3e36bb0ad26bf186a6fba25e9bc27850aa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6f4d9383eb949c5b78456bca1354eb3e36bb0ad26bf186a6fba25e9bc27850aa", kill_on_drop: false }`
[INFO] [stdout] 6f4d9383eb949c5b78456bca1354eb3e36bb0ad26bf186a6fba25e9bc27850aa
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 90d74ed651dd484bf4a050161502002fe344619f154cba15f5d2a48c8c9c9571
[INFO] running `Command { std: "docker" "start" "-a" "90d74ed651dd484bf4a050161502002fe344619f154cba15f5d2a48c8c9c9571", kill_on_drop: false }`
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]    Compiling byte-tools v0.3.1
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]    Compiling keccak v0.1.5
[INFO] [stderr]    Compiling opaque-debug v0.2.3
[INFO] [stderr]    Compiling memchr v2.7.6
[INFO] [stderr]    Compiling zeroize v1.8.2
[INFO] [stderr]    Compiling miracl_core v1.0.0
[INFO] [stderr]    Compiling getrandom v0.1.16
[INFO] [stderr]    Compiling serde_bytes v0.11.19
[INFO] [stderr]    Compiling syn v2.0.110
[INFO] [stderr]    Compiling block-padding v0.1.5
[INFO] [stderr]    Compiling subtle-encoding v0.5.1
[INFO] [stderr]    Compiling rand_core v0.5.1
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]    Compiling rand_chacha v0.2.2
[INFO] [stderr]    Compiling rayon v1.11.0
[INFO] [stderr]    Compiling rand v0.7.3
[INFO] [stderr]    Compiling generic-array v0.12.4
[INFO] [stderr]    Compiling digest v0.8.1
[INFO] [stderr]    Compiling block-buffer v0.7.3
[INFO] [stderr]    Compiling sha3 v0.8.2
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling amcl_wrapper v0.4.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `DNLEN as curve_DNLEN`
[INFO] [stdout]  --> src/constants.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 |     BASEBITS, DNLEN as curve_DNLEN, MODBYTES as curve_MODBYTES, NLEN as curve_NLEN,
[INFO] [stdout]   |               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `GroupG1`
[INFO] [stdout]   --> src/utils.rs:10:42
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::types::{BigNum, DoubleBigNum, GroupG1, FP};
[INFO] [stdout]    |                                          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::errors::SerzDeserzError`
[INFO] [stdout]   --> src/utils.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use crate::errors::SerzDeserzError;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Sha3_256`
[INFO] [stdout]   --> src/utils.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | use sha3::{Sha3_256, Shake256};
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `amcl::arch::CHUNK`
[INFO] [stdout]  --> src/field_elem.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use amcl::arch::CHUNK;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/field_elem.rs:18:18
[INFO] [stdout]    |
[INFO] [stdout] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]    --> src/field_elem.rs:891:22
[INFO] [stdout]     |
[INFO] [stdout] 891 |             .map(|i| (&self[i] * &b[i]))
[INFO] [stdout]     |                      ^                ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 891 -             .map(|i| (&self[i] * &b[i]))
[INFO] [stdout] 891 +             .map(|i| &self[i] * &b[i] )
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `FieldElementVector`
[INFO] [stdout]  --> src/group_elem.rs:4:39
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::field_elem::{FieldElement, FieldElementVector};
[INFO] [stdout]   |                                       ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rayon::prelude::*`
[INFO] [stdout]  --> src/group_elem.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rayon::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/group_elem_g1.rs:203:1
[INFO] [stdout]     |
[INFO] [stdout] 203 | /// Represents an element of the sub-group of the elliptic curve over the prime field
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BigNum`
[INFO] [stdout]  --> src/group_elem_g1.rs:8:20
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::types::{BigNum, GroupG1, FP};
[INFO] [stdout]   |                    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/group_elem_g1.rs:19:18
[INFO] [stdout]    |
[INFO] [stdout] 19 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/group_elem_g2.rs:167:1
[INFO] [stdout]     |
[INFO] [stdout] 167 | /// Represents an element of the sub-group of the elliptic curve over prime the extension field
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/group_elem_g2.rs:18:18
[INFO] [stdout]    |
[INFO] [stdout] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DENSE`
[INFO] [stdout]  --> src/extension_field_gt.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | use super::ECCurve::fp12::{DENSE, FP12};
[INFO] [stdout]   |                            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hash`
[INFO] [stdout]   --> src/extension_field_gt.rs:14:17
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::hash::{Hash, Hasher};
[INFO] [stdout]    |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/extension_field_gt.rs:18:18
[INFO] [stdout]    |
[INFO] [stdout] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FromStr` and `SplitWhitespace`
[INFO] [stdout]   --> src/extension_field_gt.rs:19:16
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::str::{FromStr, SplitWhitespace};
[INFO] [stdout]    |                ^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `group_elem_g1::G1Vector::multi_scalar_mul_var_time_from_ref_vecs`: Please use the `multi_scalar_mul_var_time_without_precomputation` function instead
[INFO] [stdout]    --> src/group_elem.rs:744:23
[INFO] [stdout]     |
[INFO] [stdout] 744 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:213:1
[INFO] [stdout]     |
[INFO] [stdout] 213 | impl_group_elem_vec_product_ops!(G1, G1Vector, G1LookupTable);
[INFO] [stdout]     | ------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_product_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `group_elem_g2::G2Vector::multi_scalar_mul_var_time_from_ref_vecs`: Please use the `multi_scalar_mul_var_time_without_precomputation` function instead
[INFO] [stdout]    --> src/group_elem.rs:744:23
[INFO] [stdout]     |
[INFO] [stdout] 744 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:177:1
[INFO] [stdout]     |
[INFO] [stdout] 177 | impl_group_elem_vec_product_ops!(G2, G2Vector, G2LookupTable);
[INFO] [stdout]     | ------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_product_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hasher`
[INFO] [stdout]   --> src/extension_field_gt.rs:14:23
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::hash::{Hash, Hasher};
[INFO] [stdout]    |                       ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/field_elem.rs:462:21
[INFO] [stdout]     |
[INFO] [stdout] 462 |     pub fn from_hex(mut s: String) -> Result<Self, SerzDeserzError> {
[INFO] [stdout]     |                     ----^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BigNumBits` should have an upper case name
[INFO] [stdout]   --> src/constants.rs:12:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub const BigNumBits: usize = BASEBITS;
[INFO] [stdout]    |           ^^^^^^^^^^ help: convert the identifier to upper case: `BIG_NUM_BITS`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FieldElement_SIZE` should have an upper case name
[INFO] [stdout]   --> src/constants.rs:15:11
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub const FieldElement_SIZE: usize = MODBYTES;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^ help: convert the identifier to upper case: `FIELD_ELEMENT_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GroupG1_SIZE` should have an upper case name
[INFO] [stdout]   --> src/constants.rs:19:11
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub const GroupG1_SIZE: usize = 2 * MODBYTES + 1;
[INFO] [stdout]    |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_G1_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_seeded_RNG_with_rng` should have a snake case name
[INFO] [stdout]   --> src/utils.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn get_seeded_RNG_with_rng<R: RngCore + CryptoRng>(entropy_size: usize, rng: &mut R) -> RAND {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_seeded_rng_with_rng`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_seeded_RNG` should have a snake case name
[INFO] [stdout]   --> src/utils.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub fn get_seeded_RNG(entropy_size: usize) -> RAND {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_seeded_rng`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_RAND` should have a snake case name
[INFO] [stdout]   --> src/utils.rs:41:4
[INFO] [stdout]    |
[INFO] [stdout] 41 | fn get_RAND(entropy_size: usize, entropy: &[u8]) -> RAND {
[INFO] [stdout]    |    ^^^^^^^^ help: convert the identifier to snake case: `get_rand`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_big_num_from_RAND` should have a snake case name
[INFO] [stdout]    --> src/field_elem.rs:330:8
[INFO] [stdout]     |
[INFO] [stdout] 330 |     fn get_big_num_from_RAND(r: &mut RAND) -> BigNum {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_big_num_from_rand`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/field_elem.rs:928:17
[INFO] [stdout]     |
[INFO] [stdout] 928 |     pub fn iter(&self) -> Iter<FieldElement> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 928 |     pub fn iter(&self) -> Iter<'_, FieldElement> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/group_elem.rs:602:13
[INFO] [stdout]     |
[INFO] [stdout] 602 |     fn iter(&self) -> Iter<T>;
[INFO] [stdout]     |             ^^^^^     ^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |             |
[INFO] [stdout]     |             the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 602 |     fn iter(&self) -> Iter<'_, T>;
[INFO] [stdout]     |                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g1.rs:181:17
[INFO] [stdout]     |
[INFO] [stdout] 181 |         let mut P = GroupG1::map2point(&u[0]);
[INFO] [stdout]     |                 ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P1` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g1.rs:182:13
[INFO] [stdout]     |
[INFO] [stdout] 182 |         let P1 = GroupG1::map2point(&u[1]);
[INFO] [stdout]     |             ^^ help: convert the identifier to snake case: `p1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:488:21
[INFO] [stdout]     |
[INFO] [stdout] 488 |             fn from(A: &'a $group_element) -> Self {
[INFO] [stdout]     |                     ^ help: convert the identifier to snake case: `a`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:201:1
[INFO] [stdout]     |
[INFO] [stdout] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `Ai` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:489:25
[INFO] [stdout]     |
[INFO] [stdout] 489 |                 let mut Ai: [$group_element; 8] = [
[INFO] [stdout]     |                         ^^ help: convert the identifier to snake case: `ai`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:201:1
[INFO] [stdout]     |
[INFO] [stdout] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A2` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:499:21
[INFO] [stdout]     |
[INFO] [stdout] 499 |                 let A2 = A.double();
[INFO] [stdout]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:201:1
[INFO] [stdout]     |
[INFO] [stdout] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/group_elem.rs:705:21
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<$group_element> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:211:1
[INFO] [stdout]     |
[INFO] [stdout] 211 | impl_group_elem_vec_ops!(G1, G1Vector);
[INFO] [stdout]     | -------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<'_, $group_element> {
[INFO] [stdout]     |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GroupG2_SIZE` should have an upper case name
[INFO] [stdout]  --> src/types_g2.rs:4:11
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub const GroupG2_SIZE: usize = 4 * MODBYTES + 1;
[INFO] [stdout]   |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_G2_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GroupGT_SIZE` should have an upper case name
[INFO] [stdout]  --> src/types_g2.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const GroupGT_SIZE: usize = (12 * MODBYTES) as usize;
[INFO] [stdout]   |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_GT_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_hex_as_FP2` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:144:8
[INFO] [stdout]     |
[INFO] [stdout] 144 | pub fn parse_hex_as_FP2(mut string: String) -> Result<FP2, SerzDeserzError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:488:21
[INFO] [stdout]     |
[INFO] [stdout] 488 |             fn from(A: &'a $group_element) -> Self {
[INFO] [stdout]     |                     ^ help: convert the identifier to snake case: `a`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `Ai` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:489:25
[INFO] [stdout]     |
[INFO] [stdout] 489 |                 let mut Ai: [$group_element; 8] = [
[INFO] [stdout]     |                         ^^ help: convert the identifier to snake case: `ai`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A2` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:499:21
[INFO] [stdout]     |
[INFO] [stdout] 499 |                 let A2 = A.double();
[INFO] [stdout]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/group_elem.rs:705:21
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<$group_element> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:175:1
[INFO] [stdout]     |
[INFO] [stdout] 175 | impl_group_elem_vec_ops!(G2, G2Vector);
[INFO] [stdout]     | -------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<'_, $group_element> {
[INFO] [stdout]     |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:209:17
[INFO] [stdout]     |
[INFO] [stdout] 209 |         let mut P = GroupG2::map2point(&fp2_1);
[INFO] [stdout]     |                 ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P1` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:210:13
[INFO] [stdout]     |
[INFO] [stdout] 210 |         let P1 = GroupG2::map2point(&fp2_2);
[INFO] [stdout]     |             ^^ help: convert the identifier to snake case: `p1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_hex_as_FP4` should have a snake case name
[INFO] [stdout]    --> src/extension_field_gt.rs:205:8
[INFO] [stdout]     |
[INFO] [stdout] 205 | pub fn parse_hex_as_FP4(mut string: String) -> Result<FP4, SerzDeserzError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp4`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 10.97s
[INFO] running `Command { std: "docker" "inspect" "90d74ed651dd484bf4a050161502002fe344619f154cba15f5d2a48c8c9c9571", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "90d74ed651dd484bf4a050161502002fe344619f154cba15f5d2a48c8c9c9571", kill_on_drop: false }`
[INFO] [stdout] 90d74ed651dd484bf4a050161502002fe344619f154cba15f5d2a48c8c9c9571
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 3a5abe2cb421e8f48c28911c95c88d90efb8a0c309665ffe1b8b07380974a1e7
[INFO] running `Command { std: "docker" "start" "-a" "3a5abe2cb421e8f48c28911c95c88d90efb8a0c309665ffe1b8b07380974a1e7", kill_on_drop: false }`
[INFO] [stdout] warning: unused import: `DNLEN as curve_DNLEN`
[INFO] [stdout]  --> src/constants.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 |     BASEBITS, DNLEN as curve_DNLEN, MODBYTES as curve_MODBYTES, NLEN as curve_NLEN,
[INFO] [stdout]   |               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `GroupG1`
[INFO] [stdout]   --> src/utils.rs:10:42
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::types::{BigNum, DoubleBigNum, GroupG1, FP};
[INFO] [stdout]    |                                          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::errors::SerzDeserzError`
[INFO] [stdout]   --> src/utils.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use crate::errors::SerzDeserzError;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Sha3_256`
[INFO] [stdout]   --> src/utils.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | use sha3::{Sha3_256, Shake256};
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `amcl::arch::CHUNK`
[INFO] [stdout]  --> src/field_elem.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use amcl::arch::CHUNK;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/field_elem.rs:18:18
[INFO] [stdout]    |
[INFO] [stdout] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]    --> src/field_elem.rs:891:22
[INFO] [stdout]     |
[INFO] [stdout] 891 |             .map(|i| (&self[i] * &b[i]))
[INFO] [stdout]     |                      ^                ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 891 -             .map(|i| (&self[i] * &b[i]))
[INFO] [stdout] 891 +             .map(|i| &self[i] * &b[i] )
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `FieldElementVector`
[INFO] [stdout]  --> src/group_elem.rs:4:39
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::field_elem::{FieldElement, FieldElementVector};
[INFO] [stdout]   |                                       ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rayon::prelude::*`
[INFO] [stdout]  --> src/group_elem.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rayon::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/group_elem_g1.rs:203:1
[INFO] [stdout]     |
[INFO] [stdout] 203 | /// Represents an element of the sub-group of the elliptic curve over the prime field
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BigNum`
[INFO] [stdout]  --> src/group_elem_g1.rs:8:20
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::types::{BigNum, GroupG1, FP};
[INFO] [stdout]   |                    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/group_elem_g1.rs:19:18
[INFO] [stdout]    |
[INFO] [stdout] 19 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/group_elem_g2.rs:167:1
[INFO] [stdout]     |
[INFO] [stdout] 167 | /// Represents an element of the sub-group of the elliptic curve over prime the extension field
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/group_elem_g2.rs:18:18
[INFO] [stdout]    |
[INFO] [stdout] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DENSE`
[INFO] [stdout]  --> src/extension_field_gt.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | use super::ECCurve::fp12::{DENSE, FP12};
[INFO] [stdout]   |                            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hash`
[INFO] [stdout]   --> src/extension_field_gt.rs:14:17
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::hash::{Hash, Hasher};
[INFO] [stdout]    |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/extension_field_gt.rs:18:18
[INFO] [stdout]    |
[INFO] [stdout] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FromStr` and `SplitWhitespace`
[INFO] [stdout]   --> src/extension_field_gt.rs:19:16
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::str::{FromStr, SplitWhitespace};
[INFO] [stdout]    |                ^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `group_elem_g1::G1Vector::multi_scalar_mul_var_time_from_ref_vecs`: Please use the `multi_scalar_mul_var_time_without_precomputation` function instead
[INFO] [stdout]    --> src/group_elem.rs:744:23
[INFO] [stdout]     |
[INFO] [stdout] 744 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:213:1
[INFO] [stdout]     |
[INFO] [stdout] 213 | impl_group_elem_vec_product_ops!(G1, G1Vector, G1LookupTable);
[INFO] [stdout]     | ------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_product_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `group_elem_g2::G2Vector::multi_scalar_mul_var_time_from_ref_vecs`: Please use the `multi_scalar_mul_var_time_without_precomputation` function instead
[INFO] [stdout]    --> src/group_elem.rs:744:23
[INFO] [stdout]     |
[INFO] [stdout] 744 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:177:1
[INFO] [stdout]     |
[INFO] [stdout] 177 | impl_group_elem_vec_product_ops!(G2, G2Vector, G2LookupTable);
[INFO] [stdout]     | ------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_product_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hasher`
[INFO] [stdout]   --> src/extension_field_gt.rs:14:23
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::hash::{Hash, Hasher};
[INFO] [stdout]    |                       ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/field_elem.rs:462:21
[INFO] [stdout]     |
[INFO] [stdout] 462 |     pub fn from_hex(mut s: String) -> Result<Self, SerzDeserzError> {
[INFO] [stdout]     |                     ----^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BigNumBits` should have an upper case name
[INFO] [stdout]   --> src/constants.rs:12:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub const BigNumBits: usize = BASEBITS;
[INFO] [stdout]    |           ^^^^^^^^^^ help: convert the identifier to upper case: `BIG_NUM_BITS`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FieldElement_SIZE` should have an upper case name
[INFO] [stdout]   --> src/constants.rs:15:11
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub const FieldElement_SIZE: usize = MODBYTES;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^ help: convert the identifier to upper case: `FIELD_ELEMENT_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GroupG1_SIZE` should have an upper case name
[INFO] [stdout]   --> src/constants.rs:19:11
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub const GroupG1_SIZE: usize = 2 * MODBYTES + 1;
[INFO] [stdout]    |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_G1_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_seeded_RNG_with_rng` should have a snake case name
[INFO] [stdout]   --> src/utils.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn get_seeded_RNG_with_rng<R: RngCore + CryptoRng>(entropy_size: usize, rng: &mut R) -> RAND {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_seeded_rng_with_rng`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_seeded_RNG` should have a snake case name
[INFO] [stdout]   --> src/utils.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub fn get_seeded_RNG(entropy_size: usize) -> RAND {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_seeded_rng`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_RAND` should have a snake case name
[INFO] [stdout]   --> src/utils.rs:41:4
[INFO] [stdout]    |
[INFO] [stdout] 41 | fn get_RAND(entropy_size: usize, entropy: &[u8]) -> RAND {
[INFO] [stdout]    |    ^^^^^^^^ help: convert the identifier to snake case: `get_rand`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_big_num_from_RAND` should have a snake case name
[INFO] [stdout]    --> src/field_elem.rs:330:8
[INFO] [stdout]     |
[INFO] [stdout] 330 |     fn get_big_num_from_RAND(r: &mut RAND) -> BigNum {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_big_num_from_rand`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling amcl_wrapper v0.4.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/field_elem.rs:928:17
[INFO] [stdout]     |
[INFO] [stdout] 928 |     pub fn iter(&self) -> Iter<FieldElement> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 928 |     pub fn iter(&self) -> Iter<'_, FieldElement> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/group_elem.rs:602:13
[INFO] [stdout]     |
[INFO] [stdout] 602 |     fn iter(&self) -> Iter<T>;
[INFO] [stdout]     |             ^^^^^     ^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |             |
[INFO] [stdout]     |             the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 602 |     fn iter(&self) -> Iter<'_, T>;
[INFO] [stdout]     |                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g1.rs:181:17
[INFO] [stdout]     |
[INFO] [stdout] 181 |         let mut P = GroupG1::map2point(&u[0]);
[INFO] [stdout]     |                 ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P1` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g1.rs:182:13
[INFO] [stdout]     |
[INFO] [stdout] 182 |         let P1 = GroupG1::map2point(&u[1]);
[INFO] [stdout]     |             ^^ help: convert the identifier to snake case: `p1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:488:21
[INFO] [stdout]     |
[INFO] [stdout] 488 |             fn from(A: &'a $group_element) -> Self {
[INFO] [stdout]     |                     ^ help: convert the identifier to snake case: `a`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:201:1
[INFO] [stdout]     |
[INFO] [stdout] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `Ai` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:489:25
[INFO] [stdout]     |
[INFO] [stdout] 489 |                 let mut Ai: [$group_element; 8] = [
[INFO] [stdout]     |                         ^^ help: convert the identifier to snake case: `ai`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:201:1
[INFO] [stdout]     |
[INFO] [stdout] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A2` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:499:21
[INFO] [stdout]     |
[INFO] [stdout] 499 |                 let A2 = A.double();
[INFO] [stdout]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:201:1
[INFO] [stdout]     |
[INFO] [stdout] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/group_elem.rs:705:21
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<$group_element> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:211:1
[INFO] [stdout]     |
[INFO] [stdout] 211 | impl_group_elem_vec_ops!(G1, G1Vector);
[INFO] [stdout]     | -------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<'_, $group_element> {
[INFO] [stdout]     |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GroupG2_SIZE` should have an upper case name
[INFO] [stdout]  --> src/types_g2.rs:4:11
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub const GroupG2_SIZE: usize = 4 * MODBYTES + 1;
[INFO] [stdout]   |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_G2_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GroupGT_SIZE` should have an upper case name
[INFO] [stdout]  --> src/types_g2.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const GroupGT_SIZE: usize = (12 * MODBYTES) as usize;
[INFO] [stdout]   |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_GT_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_hex_as_FP2` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:144:8
[INFO] [stdout]     |
[INFO] [stdout] 144 | pub fn parse_hex_as_FP2(mut string: String) -> Result<FP2, SerzDeserzError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:488:21
[INFO] [stdout]     |
[INFO] [stdout] 488 |             fn from(A: &'a $group_element) -> Self {
[INFO] [stdout]     |                     ^ help: convert the identifier to snake case: `a`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `Ai` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:489:25
[INFO] [stdout]     |
[INFO] [stdout] 489 |                 let mut Ai: [$group_element; 8] = [
[INFO] [stdout]     |                         ^^ help: convert the identifier to snake case: `ai`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A2` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:499:21
[INFO] [stdout]     |
[INFO] [stdout] 499 |                 let A2 = A.double();
[INFO] [stdout]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/group_elem.rs:705:21
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<$group_element> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:175:1
[INFO] [stdout]     |
[INFO] [stdout] 175 | impl_group_elem_vec_ops!(G2, G2Vector);
[INFO] [stdout]     | -------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<'_, $group_element> {
[INFO] [stdout]     |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:209:17
[INFO] [stdout]     |
[INFO] [stdout] 209 |         let mut P = GroupG2::map2point(&fp2_1);
[INFO] [stdout]     |                 ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P1` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:210:13
[INFO] [stdout]     |
[INFO] [stdout] 210 |         let P1 = GroupG2::map2point(&fp2_2);
[INFO] [stdout]     |             ^^ help: convert the identifier to snake case: `p1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_hex_as_FP4` should have a snake case name
[INFO] [stdout]    --> src/extension_field_gt.rs:205:8
[INFO] [stdout]     |
[INFO] [stdout] 205 | pub fn parse_hex_as_FP4(mut string: String) -> Result<FP4, SerzDeserzError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp4`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DNLEN as curve_DNLEN`
[INFO] [stdout]  --> src/constants.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 |     BASEBITS, DNLEN as curve_DNLEN, MODBYTES as curve_MODBYTES, NLEN as curve_NLEN,
[INFO] [stdout]   |               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `GroupG1`
[INFO] [stdout]   --> src/utils.rs:10:42
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::types::{BigNum, DoubleBigNum, GroupG1, FP};
[INFO] [stdout]    |                                          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::errors::SerzDeserzError`
[INFO] [stdout]   --> src/utils.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use crate::errors::SerzDeserzError;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Sha3_256`
[INFO] [stdout]   --> src/utils.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | use sha3::{Sha3_256, Shake256};
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]    --> src/utils.rs:315:21
[INFO] [stdout]     |
[INFO] [stdout] 315 |     use std::time::{Duration, Instant};
[INFO] [stdout]     |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `amcl::arch::CHUNK`
[INFO] [stdout]  --> src/field_elem.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use amcl::arch::CHUNK;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/field_elem.rs:18:18
[INFO] [stdout]    |
[INFO] [stdout] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]    --> src/field_elem.rs:891:22
[INFO] [stdout]     |
[INFO] [stdout] 891 |             .map(|i| (&self[i] * &b[i]))
[INFO] [stdout]     |                      ^                ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 891 -             .map(|i| (&self[i] * &b[i]))
[INFO] [stdout] 891 +             .map(|i| &self[i] * &b[i] )
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `amcl::bls381::big::BIG`
[INFO] [stdout]     --> src/field_elem.rs:1020:9
[INFO] [stdout]      |
[INFO] [stdout] 1020 |     use amcl::bls381::big::BIG;
[INFO] [stdout]      |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]     --> src/field_elem.rs:1024:21
[INFO] [stdout]      |
[INFO] [stdout] 1024 |     use std::time::{Duration, Instant};
[INFO] [stdout]      |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `GroupGT_SIZE`
[INFO] [stdout]     --> src/group_elem.rs:1009:42
[INFO] [stdout]      |
[INFO] [stdout] 1009 |     use crate::constants::{GroupG2_SIZE, GroupGT_SIZE, G2_COMP_BYTE_SIZE};
[INFO] [stdout]      |                                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]     --> src/group_elem.rs:1016:21
[INFO] [stdout]      |
[INFO] [stdout] 1016 |     use std::time::{Duration, Instant};
[INFO] [stdout]      |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/group_elem_g1.rs:203:1
[INFO] [stdout]     |
[INFO] [stdout] 203 | /// Represents an element of the sub-group of the elliptic curve over the prime field
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BigNum`
[INFO] [stdout]  --> src/group_elem_g1.rs:8:20
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::types::{BigNum, GroupG1, FP};
[INFO] [stdout]   |                    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/group_elem_g1.rs:19:18
[INFO] [stdout]    |
[INFO] [stdout] 19 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::borrow::Borrow`
[INFO] [stdout]    --> src/group_elem_g1.rs:220:9
[INFO] [stdout]     |
[INFO] [stdout] 220 |     use std::borrow::Borrow;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HashMap` and `HashSet`
[INFO] [stdout]    --> src/group_elem_g1.rs:221:28
[INFO] [stdout]     |
[INFO] [stdout] 221 |     use std::collections::{HashMap, HashSet};
[INFO] [stdout]     |                            ^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]    --> src/group_elem_g1.rs:222:21
[INFO] [stdout]     |
[INFO] [stdout] 222 |     use std::time::{Duration, Instant};
[INFO] [stdout]     |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]    --> src/univar_poly.rs:260:21
[INFO] [stdout]     |
[INFO] [stdout] 260 |     use std::time::{Duration, Instant};
[INFO] [stdout]     |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/group_elem_g2.rs:167:1
[INFO] [stdout]     |
[INFO] [stdout] 167 | /// Represents an element of the sub-group of the elliptic curve over prime the extension field
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/group_elem_g2.rs:18:18
[INFO] [stdout]    |
[INFO] [stdout] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> src/group_elem_g2.rs:221:9
[INFO] [stdout]     |
[INFO] [stdout] 221 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DENSE`
[INFO] [stdout]  --> src/extension_field_gt.rs:3:28
[INFO] [stdout]   |
[INFO] [stdout] 3 | use super::ECCurve::fp12::{DENSE, FP12};
[INFO] [stdout]   |                            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hash`
[INFO] [stdout]   --> src/extension_field_gt.rs:14:17
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::hash::{Hash, Hasher};
[INFO] [stdout]    |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Error as SError`
[INFO] [stdout]   --> src/extension_field_gt.rs:18:18
[INFO] [stdout]    |
[INFO] [stdout] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FromStr` and `SplitWhitespace`
[INFO] [stdout]   --> src/extension_field_gt.rs:19:16
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::str::{FromStr, SplitWhitespace};
[INFO] [stdout]    |                ^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::group_elem_g1::G1Vector`
[INFO] [stdout]    --> src/extension_field_gt.rs:315:9
[INFO] [stdout]     |
[INFO] [stdout] 315 |     use crate::group_elem_g1::G1Vector;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]    --> src/extension_field_gt.rs:316:21
[INFO] [stdout]     |
[INFO] [stdout] 316 |     use std::time::{Duration, Instant};
[INFO] [stdout]     |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `group_elem_g1::G1Vector::multi_scalar_mul_var_time_from_ref_vecs`: Please use the `multi_scalar_mul_var_time_without_precomputation` function instead
[INFO] [stdout]    --> src/group_elem.rs:744:23
[INFO] [stdout]     |
[INFO] [stdout] 744 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:213:1
[INFO] [stdout]     |
[INFO] [stdout] 213 | impl_group_elem_vec_product_ops!(G1, G1Vector, G1LookupTable);
[INFO] [stdout]     | ------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_product_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `group_elem_g2::G2Vector::multi_scalar_mul_var_time_from_ref_vecs`: Please use the `multi_scalar_mul_var_time_without_precomputation` function instead
[INFO] [stdout]    --> src/group_elem.rs:744:23
[INFO] [stdout]     |
[INFO] [stdout] 744 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:177:1
[INFO] [stdout]     |
[INFO] [stdout] 177 | impl_group_elem_vec_product_ops!(G2, G2Vector, G2LookupTable);
[INFO] [stdout]     | ------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_product_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rayon::prelude`
[INFO] [stdout]  --> src/group_elem.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rayon::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hasher`
[INFO] [stdout]   --> src/extension_field_gt.rs:14:23
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::hash::{Hash, Hasher};
[INFO] [stdout]    |                       ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/field_elem.rs:462:21
[INFO] [stdout]     |
[INFO] [stdout] 462 |     pub fn from_hex(mut s: String) -> Result<Self, SerzDeserzError> {
[INFO] [stdout]     |                     ----^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]     --> src/group_elem.rs:1337:13
[INFO] [stdout]      |
[INFO] [stdout] 1337 |         for i in 0..count {
[INFO] [stdout]      |             ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/univar_poly.rs:654:13
[INFO] [stdout]     |
[INFO] [stdout] 654 |         let mut start = Instant::now();
[INFO] [stdout]     |             ----^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BigNumBits` should have an upper case name
[INFO] [stdout]   --> src/constants.rs:12:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub const BigNumBits: usize = BASEBITS;
[INFO] [stdout]    |           ^^^^^^^^^^ help: convert the identifier to upper case: `BIG_NUM_BITS`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FieldElement_SIZE` should have an upper case name
[INFO] [stdout]   --> src/constants.rs:15:11
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub const FieldElement_SIZE: usize = MODBYTES;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^ help: convert the identifier to upper case: `FIELD_ELEMENT_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GroupG1_SIZE` should have an upper case name
[INFO] [stdout]   --> src/constants.rs:19:11
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub const GroupG1_SIZE: usize = 2 * MODBYTES + 1;
[INFO] [stdout]    |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_G1_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_seeded_RNG_with_rng` should have a snake case name
[INFO] [stdout]   --> src/utils.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn get_seeded_RNG_with_rng<R: RngCore + CryptoRng>(entropy_size: usize, rng: &mut R) -> RAND {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_seeded_rng_with_rng`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_seeded_RNG` should have a snake case name
[INFO] [stdout]   --> src/utils.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub fn get_seeded_RNG(entropy_size: usize) -> RAND {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_seeded_rng`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_RAND` should have a snake case name
[INFO] [stdout]   --> src/utils.rs:41:4
[INFO] [stdout]    |
[INFO] [stdout] 41 | fn get_RAND(entropy_size: usize, entropy: &[u8]) -> RAND {
[INFO] [stdout]    |    ^^^^^^^^ help: convert the identifier to snake case: `get_rand`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_big_num_from_RAND` should have a snake case name
[INFO] [stdout]    --> src/field_elem.rs:330:8
[INFO] [stdout]     |
[INFO] [stdout] 330 |     fn get_big_num_from_RAND(r: &mut RAND) -> BigNum {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_big_num_from_rand`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/field_elem.rs:928:17
[INFO] [stdout]     |
[INFO] [stdout] 928 |     pub fn iter(&self) -> Iter<FieldElement> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 928 |     pub fn iter(&self) -> Iter<'_, FieldElement> {
[INFO] [stdout]     |                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R` should have a snake case name
[INFO] [stdout]     --> src/field_elem.rs:1479:17
[INFO] [stdout]      |
[INFO] [stdout] 1479 |         let mut R = FieldElement::random();
[INFO] [stdout]      |                 ^ help: convert the identifier to snake case: `r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/group_elem.rs:602:13
[INFO] [stdout]     |
[INFO] [stdout] 602 |     fn iter(&self) -> Iter<T>;
[INFO] [stdout]     |             ^^^^^     ^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |             |
[INFO] [stdout]     |             the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 602 |     fn iter(&self) -> Iter<'_, T>;
[INFO] [stdout]     |                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R` should have a snake case name
[INFO] [stdout]     --> src/group_elem.rs:1248:25
[INFO] [stdout]      |
[INFO] [stdout] 1248 |                 let mut R = $group::random();
[INFO] [stdout]      |                         ^ help: convert the identifier to snake case: `r`
[INFO] [stdout] ...
[INFO] [stdout] 1274 |         add_mul!(G1, "G1");
[INFO] [stdout]      |         ------------------ in this macro invocation
[INFO] [stdout]      |
[INFO] [stdout]      = note: this warning originates in the macro `add_mul` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused arithmetic operation that must be used
[INFO] [stdout]     --> src/group_elem.rs:1263:21
[INFO] [stdout]      |
[INFO] [stdout] 1263 |                     &points[i] * &fs[i];
[INFO] [stdout]      |                     ^^^^^^^^^^^^^^^^^^^ the arithmetic operation produces a value
[INFO] [stdout] ...
[INFO] [stdout] 1274 |         add_mul!(G1, "G1");
[INFO] [stdout]      |         ------------------ in this macro invocation
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout]      = note: this warning originates in the macro `add_mul` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]      |
[INFO] [stdout] 1274 |         let _ = add_mul!(G1, "G1");
[INFO] [stdout]      |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R` should have a snake case name
[INFO] [stdout]     --> src/group_elem.rs:1248:25
[INFO] [stdout]      |
[INFO] [stdout] 1248 |                 let mut R = $group::random();
[INFO] [stdout]      |                         ^ help: convert the identifier to snake case: `r`
[INFO] [stdout] ...
[INFO] [stdout] 1276 |         add_mul!(G2, "G2");
[INFO] [stdout]      |         ------------------ in this macro invocation
[INFO] [stdout]      |
[INFO] [stdout]      = note: this warning originates in the macro `add_mul` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused arithmetic operation that must be used
[INFO] [stdout]     --> src/group_elem.rs:1263:21
[INFO] [stdout]      |
[INFO] [stdout] 1263 |                     &points[i] * &fs[i];
[INFO] [stdout]      |                     ^^^^^^^^^^^^^^^^^^^ the arithmetic operation produces a value
[INFO] [stdout] ...
[INFO] [stdout] 1276 |         add_mul!(G2, "G2");
[INFO] [stdout]      |         ------------------ in this macro invocation
[INFO] [stdout]      |
[INFO] [stdout]      = note: this warning originates in the macro `add_mul` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]      |
[INFO] [stdout] 1276 |         let _ = add_mul!(G2, "G2");
[INFO] [stdout]      |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g1.rs:181:17
[INFO] [stdout]     |
[INFO] [stdout] 181 |         let mut P = GroupG1::map2point(&u[0]);
[INFO] [stdout]     |                 ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P1` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g1.rs:182:13
[INFO] [stdout]     |
[INFO] [stdout] 182 |         let P1 = GroupG1::map2point(&u[1]);
[INFO] [stdout]     |             ^^ help: convert the identifier to snake case: `p1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:488:21
[INFO] [stdout]     |
[INFO] [stdout] 488 |             fn from(A: &'a $group_element) -> Self {
[INFO] [stdout]     |                     ^ help: convert the identifier to snake case: `a`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:201:1
[INFO] [stdout]     |
[INFO] [stdout] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `Ai` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:489:25
[INFO] [stdout]     |
[INFO] [stdout] 489 |                 let mut Ai: [$group_element; 8] = [
[INFO] [stdout]     |                         ^^ help: convert the identifier to snake case: `ai`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:201:1
[INFO] [stdout]     |
[INFO] [stdout] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A2` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:499:21
[INFO] [stdout]     |
[INFO] [stdout] 499 |                 let A2 = A.double();
[INFO] [stdout]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:201:1
[INFO] [stdout]     |
[INFO] [stdout] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/group_elem.rs:705:21
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<$group_element> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g1.rs:211:1
[INFO] [stdout]     |
[INFO] [stdout] 211 | impl_group_elem_vec_ops!(G1, G1Vector);
[INFO] [stdout]     | -------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<'_, $group_element> {
[INFO] [stdout]     |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_parse_hex_for_FP` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g1.rs:225:8
[INFO] [stdout]     |
[INFO] [stdout] 225 |     fn test_parse_hex_for_FP() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_parse_hex_for_fp`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_parse_bad_hex_for_FP` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g1.rs:230:8
[INFO] [stdout]     |
[INFO] [stdout] 230 |     fn test_parse_bad_hex_for_FP() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_parse_bad_hex_for_fp`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GroupG2_SIZE` should have an upper case name
[INFO] [stdout]  --> src/types_g2.rs:4:11
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub const GroupG2_SIZE: usize = 4 * MODBYTES + 1;
[INFO] [stdout]   |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_G2_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GroupGT_SIZE` should have an upper case name
[INFO] [stdout]  --> src/types_g2.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub const GroupGT_SIZE: usize = (12 * MODBYTES) as usize;
[INFO] [stdout]   |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_GT_SIZE`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_hex_as_FP2` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:144:8
[INFO] [stdout]     |
[INFO] [stdout] 144 | pub fn parse_hex_as_FP2(mut string: String) -> Result<FP2, SerzDeserzError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:488:21
[INFO] [stdout]     |
[INFO] [stdout] 488 |             fn from(A: &'a $group_element) -> Self {
[INFO] [stdout]     |                     ^ help: convert the identifier to snake case: `a`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `Ai` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:489:25
[INFO] [stdout]     |
[INFO] [stdout] 489 |                 let mut Ai: [$group_element; 8] = [
[INFO] [stdout]     |                         ^^ help: convert the identifier to snake case: `ai`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `A2` should have a snake case name
[INFO] [stdout]    --> src/group_elem.rs:499:21
[INFO] [stdout]     |
[INFO] [stdout] 499 |                 let A2 = A.double();
[INFO] [stdout]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:165:1
[INFO] [stdout]     |
[INFO] [stdout] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stdout]     | --------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/group_elem.rs:705:21
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<$group_element> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/group_elem_g2.rs:175:1
[INFO] [stdout]     |
[INFO] [stdout] 175 | impl_group_elem_vec_ops!(G2, G2Vector);
[INFO] [stdout]     | -------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: this warning originates in the macro `impl_group_elem_vec_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 705 |             fn iter(&self) -> Iter<'_, $group_element> {
[INFO] [stdout]     |                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:209:17
[INFO] [stdout]     |
[INFO] [stdout] 209 |         let mut P = GroupG2::map2point(&fp2_1);
[INFO] [stdout]     |                 ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P1` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:210:13
[INFO] [stdout]     |
[INFO] [stdout] 210 |         let P1 = GroupG2::map2point(&fp2_2);
[INFO] [stdout]     |             ^^ help: convert the identifier to snake case: `p1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_parse_hex_for_FP2` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:224:8
[INFO] [stdout]     |
[INFO] [stdout] 224 |     fn test_parse_hex_for_FP2() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_parse_hex_for_fp2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_parse_bad_hex_for_FP2` should have a snake case name
[INFO] [stdout]    --> src/group_elem_g2.rs:229:8
[INFO] [stdout]     |
[INFO] [stdout] 229 |     fn test_parse_bad_hex_for_FP2() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_parse_bad_hex_for_fp2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_hex_as_FP4` should have a snake case name
[INFO] [stdout]    --> src/extension_field_gt.rs:205:8
[INFO] [stdout]     |
[INFO] [stdout] 205 | pub fn parse_hex_as_FP4(mut string: String) -> Result<FP4, SerzDeserzError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp4`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 2.89s
[INFO] running `Command { std: "docker" "inspect" "3a5abe2cb421e8f48c28911c95c88d90efb8a0c309665ffe1b8b07380974a1e7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3a5abe2cb421e8f48c28911c95c88d90efb8a0c309665ffe1b8b07380974a1e7", kill_on_drop: false }`
[INFO] [stdout] 3a5abe2cb421e8f48c28911c95c88d90efb8a0c309665ffe1b8b07380974a1e7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] e9a95c5cfd4584066296b35385d0cd0f55091431c850e061a3d706159471c3df
[INFO] running `Command { std: "docker" "start" "-a" "e9a95c5cfd4584066296b35385d0cd0f55091431c850e061a3d706159471c3df", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `DNLEN as curve_DNLEN`
[INFO] [stderr]  --> src/constants.rs:4:15
[INFO] [stderr]   |
[INFO] [stderr] 4 |     BASEBITS, DNLEN as curve_DNLEN, MODBYTES as curve_MODBYTES, NLEN as curve_NLEN,
[INFO] [stderr]   |               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `GroupG1`
[INFO] [stderr]   --> src/utils.rs:10:42
[INFO] [stderr]    |
[INFO] [stderr] 10 | use crate::types::{BigNum, DoubleBigNum, GroupG1, FP};
[INFO] [stderr]    |                                          ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::errors::SerzDeserzError`
[INFO] [stderr]   --> src/utils.rs:14:5
[INFO] [stderr]    |
[INFO] [stderr] 14 | use crate::errors::SerzDeserzError;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Sha3_256`
[INFO] [stderr]   --> src/utils.rs:16:12
[INFO] [stderr]    |
[INFO] [stderr] 16 | use sha3::{Sha3_256, Shake256};
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `amcl::arch::CHUNK`
[INFO] [stderr]  --> src/field_elem.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 | use amcl::arch::CHUNK;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Error as SError`
[INFO] [stderr]   --> src/field_elem.rs:18:18
[INFO] [stderr]    |
[INFO] [stderr] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around closure body
[INFO] [stderr]    --> src/field_elem.rs:891:22
[INFO] [stderr]     |
[INFO] [stderr] 891 |             .map(|i| (&self[i] * &b[i]))
[INFO] [stderr]     |                      ^                ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 891 -             .map(|i| (&self[i] * &b[i]))
[INFO] [stderr] 891 +             .map(|i| &self[i] * &b[i] )
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `FieldElementVector`
[INFO] [stderr]  --> src/group_elem.rs:4:39
[INFO] [stderr]   |
[INFO] [stderr] 4 | use crate::field_elem::{FieldElement, FieldElementVector};
[INFO] [stderr]   |                                       ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rayon::prelude::*`
[INFO] [stderr]  --> src/group_elem.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use rayon::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused doc comment
[INFO] [stderr]    --> src/group_elem_g1.rs:203:1
[INFO] [stderr]     |
[INFO] [stderr] 203 | /// Represents an element of the sub-group of the elliptic curve over the prime field
[INFO] [stderr]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stderr]     |
[INFO] [stderr]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stderr]     = note: `#[warn(unused_doc_comments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `BigNum`
[INFO] [stderr]  --> src/group_elem_g1.rs:8:20
[INFO] [stderr]   |
[INFO] [stderr] 8 | use crate::types::{BigNum, GroupG1, FP};
[INFO] [stderr]   |                    ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Error as SError`
[INFO] [stderr]   --> src/group_elem_g1.rs:19:18
[INFO] [stderr]    |
[INFO] [stderr] 19 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused doc comment
[INFO] [stderr]    --> src/group_elem_g2.rs:167:1
[INFO] [stderr]     |
[INFO] [stderr] 167 | /// Represents an element of the sub-group of the elliptic curve over prime the extension field
[INFO] [stderr]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stderr]     |
[INFO] [stderr]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Error as SError`
[INFO] [stderr]   --> src/group_elem_g2.rs:18:18
[INFO] [stderr]    |
[INFO] [stderr] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `DENSE`
[INFO] [stderr]  --> src/extension_field_gt.rs:3:28
[INFO] [stderr]   |
[INFO] [stderr] 3 | use super::ECCurve::fp12::{DENSE, FP12};
[INFO] [stderr]   |                            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Hash`
[INFO] [stderr]   --> src/extension_field_gt.rs:14:17
[INFO] [stderr]    |
[INFO] [stderr] 14 | use std::hash::{Hash, Hasher};
[INFO] [stderr]    |                 ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Error as SError`
[INFO] [stderr]   --> src/extension_field_gt.rs:18:18
[INFO] [stderr]    |
[INFO] [stderr] 18 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `FromStr` and `SplitWhitespace`
[INFO] [stderr]   --> src/extension_field_gt.rs:19:16
[INFO] [stderr]    |
[INFO] [stderr] 19 | use std::str::{FromStr, SplitWhitespace};
[INFO] [stderr]    |                ^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated associated function `group_elem_g1::G1Vector::multi_scalar_mul_var_time_from_ref_vecs`: Please use the `multi_scalar_mul_var_time_without_precomputation` function instead
[INFO] [stderr]    --> src/group_elem.rs:744:23
[INFO] [stderr]     |
[INFO] [stderr] 744 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stderr]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/group_elem_g1.rs:213:1
[INFO] [stderr]     |
[INFO] [stderr] 213 | impl_group_elem_vec_product_ops!(G1, G1Vector, G1LookupTable);
[INFO] [stderr]     | ------------------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(deprecated)]` on by default
[INFO] [stderr]     = note: this warning originates in the macro `impl_group_elem_vec_product_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated associated function `group_elem_g2::G2Vector::multi_scalar_mul_var_time_from_ref_vecs`: Please use the `multi_scalar_mul_var_time_without_precomputation` function instead
[INFO] [stderr]    --> src/group_elem.rs:744:23
[INFO] [stderr]     |
[INFO] [stderr] 744 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stderr]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/group_elem_g2.rs:177:1
[INFO] [stderr]     |
[INFO] [stderr] 177 | impl_group_elem_vec_product_ops!(G2, G2Vector, G2LookupTable);
[INFO] [stderr]     | ------------------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `impl_group_elem_vec_product_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Hasher`
[INFO] [stderr]   --> src/extension_field_gt.rs:14:23
[INFO] [stderr]    |
[INFO] [stderr] 14 | use std::hash::{Hash, Hasher};
[INFO] [stderr]    |                       ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/field_elem.rs:462:21
[INFO] [stderr]     |
[INFO] [stderr] 462 |     pub fn from_hex(mut s: String) -> Result<Self, SerzDeserzError> {
[INFO] [stderr]     |                     ----^
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `BigNumBits` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:12:11
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub const BigNumBits: usize = BASEBITS;
[INFO] [stderr]    |           ^^^^^^^^^^ help: convert the identifier to upper case: `BIG_NUM_BITS`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `FieldElement_SIZE` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:15:11
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub const FieldElement_SIZE: usize = MODBYTES;
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^^^ help: convert the identifier to upper case: `FIELD_ELEMENT_SIZE`
[INFO] [stderr] 
[INFO] [stderr] warning: constant `GroupG1_SIZE` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:19:11
[INFO] [stderr]    |
[INFO] [stderr] 19 | pub const GroupG1_SIZE: usize = 2 * MODBYTES + 1;
[INFO] [stderr]    |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_G1_SIZE`
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_seeded_RNG_with_rng` should have a snake case name
[INFO] [stderr]   --> src/utils.rs:27:8
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub fn get_seeded_RNG_with_rng<R: RngCore + CryptoRng>(entropy_size: usize, rng: &mut R) -> RAND {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_seeded_rng_with_rng`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_seeded_RNG` should have a snake case name
[INFO] [stderr]   --> src/utils.rs:34:8
[INFO] [stderr]    |
[INFO] [stderr] 34 | pub fn get_seeded_RNG(entropy_size: usize) -> RAND {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_seeded_rng`
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_RAND` should have a snake case name
[INFO] [stderr]   --> src/utils.rs:41:4
[INFO] [stderr]    |
[INFO] [stderr] 41 | fn get_RAND(entropy_size: usize, entropy: &[u8]) -> RAND {
[INFO] [stderr]    |    ^^^^^^^^ help: convert the identifier to snake case: `get_rand`
[INFO] [stderr] 
[INFO] [stderr] warning: method `get_big_num_from_RAND` should have a snake case name
[INFO] [stderr]    --> src/field_elem.rs:330:8
[INFO] [stderr]     |
[INFO] [stderr] 330 |     fn get_big_num_from_RAND(r: &mut RAND) -> BigNum {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `get_big_num_from_rand`
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/field_elem.rs:928:17
[INFO] [stderr]     |
[INFO] [stderr] 928 |     pub fn iter(&self) -> Iter<FieldElement> {
[INFO] [stderr]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 928 |     pub fn iter(&self) -> Iter<'_, FieldElement> {
[INFO] [stderr]     |                                +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/group_elem.rs:602:13
[INFO] [stderr]     |
[INFO] [stderr] 602 |     fn iter(&self) -> Iter<T>;
[INFO] [stderr]     |             ^^^^^     ^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |             |
[INFO] [stderr]     |             the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 602 |     fn iter(&self) -> Iter<'_, T>;
[INFO] [stderr]     |                            +++
[INFO] [stderr] 
[INFO] [stderr] warning: variable `P` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g1.rs:181:17
[INFO] [stderr]     |
[INFO] [stderr] 181 |         let mut P = GroupG1::map2point(&u[0]);
[INFO] [stderr]     |                 ^ help: convert the identifier to snake case: `p`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `P1` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g1.rs:182:13
[INFO] [stderr]     |
[INFO] [stderr] 182 |         let P1 = GroupG1::map2point(&u[1]);
[INFO] [stderr]     |             ^^ help: convert the identifier to snake case: `p1`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `A` should have a snake case name
[INFO] [stderr]    --> src/group_elem.rs:488:21
[INFO] [stderr]     |
[INFO] [stderr] 488 |             fn from(A: &'a $group_element) -> Self {
[INFO] [stderr]     |                     ^ help: convert the identifier to snake case: `a`
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/group_elem_g1.rs:201:1
[INFO] [stderr]     |
[INFO] [stderr] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stderr]     | --------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: variable `Ai` should have a snake case name
[INFO] [stderr]    --> src/group_elem.rs:489:25
[INFO] [stderr]     |
[INFO] [stderr] 489 |                 let mut Ai: [$group_element; 8] = [
[INFO] [stderr]     |                         ^^ help: convert the identifier to snake case: `ai`
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/group_elem_g1.rs:201:1
[INFO] [stderr]     |
[INFO] [stderr] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stderr]     | --------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: variable `A2` should have a snake case name
[INFO] [stderr]    --> src/group_elem.rs:499:21
[INFO] [stderr]     |
[INFO] [stderr] 499 |                 let A2 = A.double();
[INFO] [stderr]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/group_elem_g1.rs:201:1
[INFO] [stderr]     |
[INFO] [stderr] 201 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stderr]     | --------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/group_elem.rs:705:21
[INFO] [stderr]     |
[INFO] [stderr] 705 |             fn iter(&self) -> Iter<$group_element> {
[INFO] [stderr]     |                     ^^^^^     ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/group_elem_g1.rs:211:1
[INFO] [stderr]     |
[INFO] [stderr] 211 | impl_group_elem_vec_ops!(G1, G1Vector);
[INFO] [stderr]     | -------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: this warning originates in the macro `impl_group_elem_vec_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 705 |             fn iter(&self) -> Iter<'_, $group_element> {
[INFO] [stderr]     |                                    +++
[INFO] [stderr] 
[INFO] [stderr] warning: constant `GroupG2_SIZE` should have an upper case name
[INFO] [stderr]  --> src/types_g2.rs:4:11
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub const GroupG2_SIZE: usize = 4 * MODBYTES + 1;
[INFO] [stderr]   |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_G2_SIZE`
[INFO] [stderr] 
[INFO] [stderr] warning: constant `GroupGT_SIZE` should have an upper case name
[INFO] [stderr]  --> src/types_g2.rs:8:11
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub const GroupGT_SIZE: usize = (12 * MODBYTES) as usize;
[INFO] [stderr]   |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_GT_SIZE`
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_hex_as_FP2` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g2.rs:144:8
[INFO] [stderr]     |
[INFO] [stderr] 144 | pub fn parse_hex_as_FP2(mut string: String) -> Result<FP2, SerzDeserzError> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp2`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `A` should have a snake case name
[INFO] [stderr]    --> src/group_elem.rs:488:21
[INFO] [stderr]     |
[INFO] [stderr] 488 |             fn from(A: &'a $group_element) -> Self {
[INFO] [stderr]     |                     ^ help: convert the identifier to snake case: `a`
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/group_elem_g2.rs:165:1
[INFO] [stderr]     |
[INFO] [stderr] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stderr]     | --------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: variable `Ai` should have a snake case name
[INFO] [stderr]    --> src/group_elem.rs:489:25
[INFO] [stderr]     |
[INFO] [stderr] 489 |                 let mut Ai: [$group_element; 8] = [
[INFO] [stderr]     |                         ^^ help: convert the identifier to snake case: `ai`
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/group_elem_g2.rs:165:1
[INFO] [stderr]     |
[INFO] [stderr] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stderr]     | --------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: variable `A2` should have a snake case name
[INFO] [stderr]    --> src/group_elem.rs:499:21
[INFO] [stderr]     |
[INFO] [stderr] 499 |                 let A2 = A.double();
[INFO] [stderr]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/group_elem_g2.rs:165:1
[INFO] [stderr]     |
[INFO] [stderr] 165 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stderr]     | --------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in the macro `impl_group_element_lookup_table` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/group_elem.rs:705:21
[INFO] [stderr]     |
[INFO] [stderr] 705 |             fn iter(&self) -> Iter<$group_element> {
[INFO] [stderr]     |                     ^^^^^     ^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/group_elem_g2.rs:175:1
[INFO] [stderr]     |
[INFO] [stderr] 175 | impl_group_elem_vec_ops!(G2, G2Vector);
[INFO] [stderr]     | -------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: this warning originates in the macro `impl_group_elem_vec_ops` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 705 |             fn iter(&self) -> Iter<'_, $group_element> {
[INFO] [stderr]     |                                    +++
[INFO] [stderr] 
[INFO] [stderr] warning: variable `P` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g2.rs:209:17
[INFO] [stderr]     |
[INFO] [stderr] 209 |         let mut P = GroupG2::map2point(&fp2_1);
[INFO] [stderr]     |                 ^ help: convert the identifier to snake case: `p`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `P1` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g2.rs:210:13
[INFO] [stderr]     |
[INFO] [stderr] 210 |         let P1 = GroupG2::map2point(&fp2_2);
[INFO] [stderr]     |             ^^ help: convert the identifier to snake case: `p1`
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_hex_as_FP4` should have a snake case name
[INFO] [stderr]    --> src/extension_field_gt.rs:205:8
[INFO] [stderr]     |
[INFO] [stderr] 205 | pub fn parse_hex_as_FP4(mut string: String) -> Result<FP4, SerzDeserzError> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp4`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]    --> src/utils.rs:315:21
[INFO] [stderr]     |
[INFO] [stderr] 315 |     use std::time::{Duration, Instant};
[INFO] [stderr]     |                     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `amcl::bls381::big::BIG`
[INFO] [stderr]     --> src/field_elem.rs:1020:9
[INFO] [stderr]      |
[INFO] [stderr] 1020 |     use amcl::bls381::big::BIG;
[INFO] [stderr]      |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]     --> src/field_elem.rs:1024:21
[INFO] [stderr]      |
[INFO] [stderr] 1024 |     use std::time::{Duration, Instant};
[INFO] [stderr]      |                     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `GroupGT_SIZE`
[INFO] [stderr]     --> src/group_elem.rs:1009:42
[INFO] [stderr]      |
[INFO] [stderr] 1009 |     use crate::constants::{GroupG2_SIZE, GroupGT_SIZE, G2_COMP_BYTE_SIZE};
[INFO] [stderr]      |                                          ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]     --> src/group_elem.rs:1016:21
[INFO] [stderr]      |
[INFO] [stderr] 1016 |     use std::time::{Duration, Instant};
[INFO] [stderr]      |                     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::borrow::Borrow`
[INFO] [stderr]    --> src/group_elem_g1.rs:220:9
[INFO] [stderr]     |
[INFO] [stderr] 220 |     use std::borrow::Borrow;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `HashMap` and `HashSet`
[INFO] [stderr]    --> src/group_elem_g1.rs:221:28
[INFO] [stderr]     |
[INFO] [stderr] 221 |     use std::collections::{HashMap, HashSet};
[INFO] [stderr]     |                            ^^^^^^^  ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]    --> src/group_elem_g1.rs:222:21
[INFO] [stderr]     |
[INFO] [stderr] 222 |     use std::time::{Duration, Instant};
[INFO] [stderr]     |                     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]    --> src/univar_poly.rs:260:21
[INFO] [stderr]     |
[INFO] [stderr] 260 |     use std::time::{Duration, Instant};
[INFO] [stderr]     |                     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::*`
[INFO] [stderr]    --> src/group_elem_g2.rs:221:9
[INFO] [stderr]     |
[INFO] [stderr] 221 |     use super::*;
[INFO] [stderr]     |         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::group_elem_g1::G1Vector`
[INFO] [stderr]    --> src/extension_field_gt.rs:315:9
[INFO] [stderr]     |
[INFO] [stderr] 315 |     use crate::group_elem_g1::G1Vector;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]    --> src/extension_field_gt.rs:316:21
[INFO] [stderr]     |
[INFO] [stderr] 316 |     use std::time::{Duration, Instant};
[INFO] [stderr]     |                     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rayon::prelude`
[INFO] [stderr]  --> src/group_elem.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use rayon::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `i`
[INFO] [stderr]     --> src/group_elem.rs:1337:13
[INFO] [stderr]      |
[INFO] [stderr] 1337 |         for i in 0..count {
[INFO] [stderr]      |             ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/univar_poly.rs:654:13
[INFO] [stderr]     |
[INFO] [stderr] 654 |         let mut start = Instant::now();
[INFO] [stderr]     |             ----^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]     --> src/field_elem.rs:1479:17
[INFO] [stderr]      |
[INFO] [stderr] 1479 |         let mut R = FieldElement::random();
[INFO] [stderr]      |                 ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]     --> src/group_elem.rs:1248:25
[INFO] [stderr]      |
[INFO] [stderr] 1248 |                 let mut R = $group::random();
[INFO] [stderr]      |                         ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] ...
[INFO] [stderr] 1274 |         add_mul!(G1, "G1");
[INFO] [stderr]      |         ------------------ in this macro invocation
[INFO] [stderr]      |
[INFO] [stderr]      = note: this warning originates in the macro `add_mul` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: unused arithmetic operation that must be used
[INFO] [stderr]     --> src/group_elem.rs:1263:21
[INFO] [stderr]      |
[INFO] [stderr] 1263 |                     &points[i] * &fs[i];
[INFO] [stderr]      |                     ^^^^^^^^^^^^^^^^^^^ the arithmetic operation produces a value
[INFO] [stderr] ...
[INFO] [stderr] 1274 |         add_mul!(G1, "G1");
[INFO] [stderr]      |         ------------------ in this macro invocation
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr]      = note: this warning originates in the macro `add_mul` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]      |
[INFO] [stderr] 1274 |         let _ = add_mul!(G1, "G1");
[INFO] [stderr]      |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]     --> src/group_elem.rs:1248:25
[INFO] [stderr]      |
[INFO] [stderr] 1248 |                 let mut R = $group::random();
[INFO] [stderr]      |                         ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] ...
[INFO] [stderr] 1276 |         add_mul!(G2, "G2");
[INFO] [stderr]      |         ------------------ in this macro invocation
[INFO] [stderr]      |
[INFO] [stderr]      = note: this warning originates in the macro `add_mul` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: unused arithmetic operation that must be used
[INFO] [stderr]     --> src/group_elem.rs:1263:21
[INFO] [stderr]      |
[INFO] [stderr] 1263 |                     &points[i] * &fs[i];
[INFO] [stderr]      |                     ^^^^^^^^^^^^^^^^^^^ the arithmetic operation produces a value
[INFO] [stderr] ...
[INFO] [stderr] 1276 |         add_mul!(G2, "G2");
[INFO] [stderr]      |         ------------------ in this macro invocation
[INFO] [stderr]      |
[INFO] [stderr]      = note: this warning originates in the macro `add_mul` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]      |
[INFO] [stderr] 1276 |         let _ = add_mul!(G2, "G2");
[INFO] [stderr]      |         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_parse_hex_for_FP` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g1.rs:225:8
[INFO] [stderr]     |
[INFO] [stderr] 225 |     fn test_parse_hex_for_FP() {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_parse_hex_for_fp`
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_parse_bad_hex_for_FP` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g1.rs:230:8
[INFO] [stderr]     |
[INFO] [stderr] 230 |     fn test_parse_bad_hex_for_FP() {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_parse_bad_hex_for_fp`
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_parse_hex_for_FP2` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g2.rs:224:8
[INFO] [stderr]     |
[INFO] [stderr] 224 |     fn test_parse_hex_for_FP2() {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_parse_hex_for_fp2`
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_parse_bad_hex_for_FP2` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g2.rs:229:8
[INFO] [stderr]     |
[INFO] [stderr] 229 |     fn test_parse_bad_hex_for_FP2() {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_parse_bad_hex_for_fp2`
[INFO] [stderr] 
[INFO] [stderr] warning: `amcl_wrapper` (lib) generated 47 warnings (run `cargo fix --lib -p amcl_wrapper` to apply 21 suggestions)
[INFO] [stderr] warning: `amcl_wrapper` (lib test) generated 69 warnings (45 duplicates) (run `cargo fix --lib -p amcl_wrapper --tests` to apply 14 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.13s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/amcl_wrapper-2e4e4a6baa883558)
[INFO] [stdout] 
[INFO] [stdout] running 77 tests
[INFO] [stdout] test errors::test::test_vector_size_equality ... ok
[INFO] [stdout] test extension_field_gt::test::test_unity ... ok
[INFO] [stdout] test field_elem::test::test_field_elem_multiplication ... ok
[INFO] [stdout] test field_elem::test::test_field_elements_hadamard_product ... ok
[INFO] [stdout] test field_elem::test::test_add_field_element_vectors ... ok
[INFO] [stdout] test field_elem::test::test_field_elements_inner_product ... ok
[INFO] [stdout] test field_elem::test::test_hashing ... ok
[INFO] [stdout] test field_elem::test::test_negating_field_elems ... ok
[INFO] [stdout] test field_elem::test::test_field_elem_subtraction ... ok
[INFO] [stdout] test field_elem::test::test_field_elem_addition ... ok
[INFO] [stdout] test field_elem::test::test_parse_bad_hex_for_bignum ... ok
[INFO] [stdout] test field_elem::test::test_field_elem_vandermonde_vector ... ok
[INFO] [stdout] test field_elem::test::test_pow ... ok
[INFO] [stdout] test field_elem::test::test_scale_field_element_vector ... ok
[INFO] [stdout] test field_elem::test::test_inversion ... ok
[INFO] [stdout] test field_elem::test::test_nth_bit ... ok
[INFO] [stdout] test field_elem::test::test_static_field_elems ... ok
[INFO] [stdout] test field_elem::test::test_to_bits ... ok
[INFO] [stdout] test field_elem::test::test_to_bitvectors ... ok
[INFO] [stdout] test field_elem::test::test_equality ... ok
[INFO] [stdout] test extension_field_gt::test::test_ate_pairing_negative ... ok
[INFO] [stdout] test extension_field_gt::test::test_ate_pairing_product ... ok
[INFO] [stdout] test field_elem::test::test_parse_hex_as_bignum ... ok
[INFO] [stdout] test field_elem::test::timing_multiplication_inversion ... ok
[INFO] [stdout] test field_elem::test::test_serialization_deserialization_field_elem ... ok
[INFO] [stdout] test field_elem::test::test_field_elem_to_from_base ... ok
[INFO] [stdout] test group_elem::test::test_hashing ... ok
[INFO] [stdout] test group_elem::test::test_lookup_table ... ok
[INFO] [stdout] test field_elem::test::timing_field_elem_addition ... ok
[INFO] [stdout] test group_elem::test::test_negating_group_elems ... ok
[INFO] [stdout] test group_elem::test::test_negation ... ok
[INFO] [stdout] test field_elem::test::test_or ... ok
[INFO] [stdout] test extension_field_gt::test::test_ate_pairing_identity ... ok
[INFO] [stdout] test field_elem::test::test_to_and_from_bytes ... ok
[INFO] [stdout] test group_elem::test::test_equality ... ok
[INFO] [stdout] test extension_field_gt::test::test_ate_pairing ... ok
[INFO] [stdout] test group_elem::test::test_group_elem_addition ... ok
[INFO] [stdout] test group_elem::test::timing_correct_order_check ... ok
[INFO] [stdout] test group_elem::test::test_scalar_mult_operators ... ok
[INFO] [stdout] test extension_field_gt::test::timing_ate_multi_pairing ... ok
[INFO] [stdout] test group_elem_g1::test::test_multiples ... ok
[INFO] [stdout] test group_elem_g1::test::test_parse_bad_hex_for_FP ... ok
[INFO] [stdout] test group_elem_g1::test::test_parse_hex_for_FP ... ok
[INFO] [stdout] test extension_field_gt::test::test_inverse ... ok
[INFO] [stdout] test group_elem_g1::test::test_binary_scalar_mul ... ok
[INFO] [stdout] test group_elem_g2::test::test_parse_bad_hex_for_FP2 ... ok
[INFO] [stdout] test group_elem_g2::test::test_parse_hex_for_FP2 ... ok
[INFO] [stdout] test univar_poly::tests::test_create_poly_from_macro ... ok
[INFO] [stdout] test univar_poly::tests::test_multiply_with_constant ... ok
[INFO] [stdout] test univar_poly::tests::test_multiply_with_monic_monomial ... ok
[INFO] [stdout] test univar_poly::tests::test_poly ... ok
[INFO] [stdout] test extension_field_gt::test::timing_pairing_pow ... ok
[INFO] [stdout] test univar_poly::tests::test_poly_long_div ... ok
[INFO] [stdout] test univar_poly::tests::test_poly_multiply ... ok
[INFO] [stdout] test univar_poly::tests::test_poly_rem ... ok
[INFO] [stdout] test group_elem::test::timing_vector_scaling ... ok
[INFO] [stdout] test field_elem::test::timing_field_elem_squaring ... ok
[INFO] [stdout] test group_elem_g1::test::timing_wnaf_mul ... ok
[INFO] [stdout] test group_elem_g1::test::timing_multi_scalar_multiplication ... ok
[INFO] [stdout] test utils::test::timing_barrett_reduction ... ok
[INFO] [stdout] test utils::test::timing_fp_big ... ok
[INFO] [stdout] test univar_poly::tests::test_poly_from_given_roots ... ok
[INFO] [stdout] test utils::test::timing_rmod_with_barrett_reduction ... ok
[INFO] [stdout] test field_elem::test::test_hex_field_elem ... ok
[INFO] [stdout] test field_elem::test::timing_field_elem_multiplication ... ok
[INFO] [stdout] test extension_field_gt::test::test_to_and_from_bytes ... ok
[INFO] [stdout] test group_elem::test::timing_group_elem_addition_and_scalar_multiplication ... ok
[INFO] [stdout] test group_elem::test::test_hex_group_elem has been running for over 60 seconds
[INFO] [stdout] test group_elem::test::test_multi_scalar_multiplication has been running for over 60 seconds
[INFO] [stdout] test group_elem::test::timing_hash_to_curve ... ok
[INFO] [stdout] test group_elem::test::test_serialization_deserialization_group_elem has been running for over 60 seconds
[INFO] [stdout] test group_elem::test::test_to_and_from_bytes has been running for over 60 seconds
[INFO] [stdout] test group_elem::test::test_wnaf_mul has been running for over 60 seconds
[INFO] [stdout] test utils::test::timing_ecp ... ok
[INFO] [stdout] test group_elem::test::test_to_and_from_bytes ... ok
[INFO] [stdout] test group_elem::test::test_wnaf_mul ... ok
[INFO] [stdout] test univar_poly::tests::test_random_poly_long_div has been running for over 60 seconds
[INFO] [stdout] test univar_poly::tests::test_random_poly_long_div_remainder has been running for over 60 seconds
[INFO] [stdout] test univar_poly::tests::test_random_poly_sum_difference has been running for over 60 seconds
[INFO] [stdout] test group_elem::test::test_serialization_deserialization_group_elem ... ok
[INFO] [stdout] test univar_poly::tests::test_random_poly_sum_difference ... ok
[INFO] [stdout] test univar_poly::tests::test_random_poly_long_div_remainder ... ok
[INFO] [stdout] test univar_poly::tests::test_random_poly_long_div ... ok
[INFO] [stdout] test group_elem::test::test_hex_group_elem ... ok
[INFO] [stdout] test group_elem::test::test_multi_scalar_multiplication ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 77 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 166.28s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests amcl_wrapper
[INFO] [stderr] warning: unnecessary parentheses around closure body
[INFO] [stderr]    --> src/field_elem.rs:891:22
[INFO] [stderr]     |
[INFO] [stderr] 891 |             .map(|i| (&self[i] * &b[i]))
[INFO] [stderr]     |                      ^                ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 891 -             .map(|i| (&self[i] * &b[i]))
[INFO] [stderr] 891 +             .map(|i| &self[i] * &b[i] )
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: 1 warning emitted
[INFO] [stderr] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "e9a95c5cfd4584066296b35385d0cd0f55091431c850e061a3d706159471c3df", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e9a95c5cfd4584066296b35385d0cd0f55091431c850e061a3d706159471c3df", kill_on_drop: false }`
[INFO] [stdout] e9a95c5cfd4584066296b35385d0cd0f55091431c850e061a3d706159471c3df
