[INFO] crate amcl_wrapper 0.3.5 is already in cache
[INFO] checking amcl_wrapper-0.3.5 against master#bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc for pr-70917
[INFO] extracting crate amcl_wrapper 0.3.5 into /workspace/builds/worker-4/source
[INFO] validating manifest of crates.io crate amcl_wrapper 0.3.5 on toolchain bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking crates.io crate amcl_wrapper 0.3.5
[INFO] finished tweaking crates.io crate amcl_wrapper 0.3.5
[INFO] tweaked toml for crates.io crate amcl_wrapper 0.3.5 written to /workspace/builds/worker-4/source/Cargo.toml
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"`
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "check" "--frozen" "--all" "--all-targets"`
[INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
[INFO] [stdout] 4deae269e05cd8a0566c3d86a3b3085435ab0f772e8d114fe85e25d483b1cd12
[INFO] running `"docker" "start" "-a" "4deae269e05cd8a0566c3d86a3b3085435ab0f772e8d114fe85e25d483b1cd12"`
[INFO] [stderr]     Checking byte-tools v0.3.1
[INFO] [stderr]     Checking either v1.5.3
[INFO] [stderr]     Checking opaque-debug v0.2.3
[INFO] [stderr]     Checking keccak v0.1.0
[INFO] [stderr]     Checking zeroize v1.1.0
[INFO] [stderr]     Checking miracl_amcl v3.2.5
[INFO] [stderr]     Checking getrandom v0.1.14
[INFO] [stderr]     Checking digest v0.8.1
[INFO] [stderr]     Checking rayon-core v1.7.0
[INFO] [stderr]     Checking block-padding v0.1.5
[INFO] [stderr]     Checking block-buffer v0.7.3
[INFO] [stderr]     Checking subtle-encoding v0.5.1
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]     Checking sha3 v0.8.2
[INFO] [stderr]     Checking rayon v1.3.0
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking amcl_wrapper v0.3.5 (/opt/rustwide/workdir)
[INFO] [stderr] warning: unused doc comment
[INFO] [stderr]    --> src/group_elem_g1.rs:174:1
[INFO] [stderr]     |
[INFO] [stderr] 174 | /// Represents an element of the sub-group of the elliptic curve over the prime field
[INFO] [stderr]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macros
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_doc_comments)]` on by default
[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 doc comment
[INFO] [stderr]    --> src/group_elem_g2.rs:179:1
[INFO] [stderr]     |
[INFO] [stderr] 179 | /// Represents an element of the sub-group of the elliptic curve over prime the extension field
[INFO] [stderr]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macros
[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: `crate::errors::SerzDeserzError`
[INFO] [stderr]   --> src/utils.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use crate::errors::SerzDeserzError;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Sha3_256`
[INFO] [stderr]   --> src/utils.rs:12:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | 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: 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 import: `Error as SError`
[INFO] [stderr]   --> src/group_elem_g1.rs:16:18
[INFO] [stderr]    |
[INFO] [stderr] 16 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^^
[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: `Error as SError`
[INFO] [stderr]   --> src/extension_field_gt.rs:17:18
[INFO] [stderr]    |
[INFO] [stderr] 17 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `FromStr`
[INFO] [stderr]   --> src/extension_field_gt.rs:18:16
[INFO] [stderr]    |
[INFO] [stderr] 18 | use std::str::{FromStr, SplitWhitespace};
[INFO] [stderr]    |                ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused doc comment
[INFO] [stderr]    --> src/group_elem_g1.rs:174:1
[INFO] [stderr]     |
[INFO] [stderr] 174 | /// Represents an element of the sub-group of the elliptic curve over the prime field
[INFO] [stderr]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macros
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_doc_comments)]` on by default
[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 doc comment
[INFO] [stderr]    --> src/group_elem_g2.rs:179:1
[INFO] [stderr]     |
[INFO] [stderr] 179 | /// Represents an element of the sub-group of the elliptic curve over prime the extension field
[INFO] [stderr]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macros
[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: `crate::errors::SerzDeserzError`
[INFO] [stderr]   --> src/utils.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use crate::errors::SerzDeserzError;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Sha3_256`
[INFO] [stderr]   --> src/utils.rs:12:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | use sha3::{Sha3_256, Shake256};
[INFO] [stderr]    |            ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]    --> src/utils.rs:171:21
[INFO] [stderr]     |
[INFO] [stderr] 171 |     use std::time::{Duration, Instant};
[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: unused import: `amcl::bls381::big::BIG`
[INFO] [stderr]     --> src/field_elem.rs:1017:9
[INFO] [stderr]      |
[INFO] [stderr] 1017 |     use amcl::bls381::big::BIG;
[INFO] [stderr]      |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]     --> src/field_elem.rs:1021:21
[INFO] [stderr]      |
[INFO] [stderr] 1021 |     use std::time::{Duration, Instant};
[INFO] [stderr]      |                     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]    --> src/group_elem.rs:939:21
[INFO] [stderr]     |
[INFO] [stderr] 939 |     use std::time::{Duration, Instant};
[INFO] [stderr]     |                     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Error as SError`
[INFO] [stderr]   --> src/group_elem_g1.rs:16:18
[INFO] [stderr]    |
[INFO] [stderr] 16 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::borrow::Borrow`
[INFO] [stderr]    --> src/group_elem_g1.rs:216:9
[INFO] [stderr]     |
[INFO] [stderr] 216 |     use std::borrow::Borrow;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `HashMap`, `HashSet`
[INFO] [stderr]    --> src/group_elem_g1.rs:217:28
[INFO] [stderr]     |
[INFO] [stderr] 217 |     use std::collections::{HashMap, HashSet};
[INFO] [stderr]     |                            ^^^^^^^  ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]    --> src/group_elem_g1.rs:218:21
[INFO] [stderr]     |
[INFO] [stderr] 218 |     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: `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: `super::*`
[INFO] [stderr]    --> src/group_elem_g2.rs:208:9
[INFO] [stderr]     |
[INFO] [stderr] 208 |     use super::*;
[INFO] [stderr]     |         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Error as SError`
[INFO] [stderr]   --> src/extension_field_gt.rs:17:18
[INFO] [stderr]    |
[INFO] [stderr] 17 | use serde::ser::{Error as SError, Serialize, Serializer};
[INFO] [stderr]    |                  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `FromStr`
[INFO] [stderr]   --> src/extension_field_gt.rs:18:16
[INFO] [stderr]    |
[INFO] [stderr] 18 | use std::str::{FromStr, SplitWhitespace};
[INFO] [stderr]    |                ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::group_elem_g1::G1Vector`
[INFO] [stderr]    --> src/extension_field_gt.rs:260:9
[INFO] [stderr]     |
[INFO] [stderr] 260 |     use crate::group_elem_g1::G1Vector;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Duration`
[INFO] [stderr]    --> src/extension_field_gt.rs:261:21
[INFO] [stderr]     |
[INFO] [stderr] 261 |     use std::time::{Duration, Instant};
[INFO] [stderr]     |                     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item '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:667:17
[INFO] [stderr]     |
[INFO] [stderr] 667 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g1.rs:184:1
[INFO] [stderr]     |
[INFO] [stderr] 184 | 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 a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item '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:667:17
[INFO] [stderr]     |
[INFO] [stderr] 667 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g2.rs:189:1
[INFO] [stderr]     |
[INFO] [stderr] 189 | impl_group_elem_vec_product_ops!(G2, G2Vector, G2LookupTable);
[INFO] [stderr]     | -------------------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/group_elem.rs:150:21
[INFO] [stderr]     |
[INFO] [stderr] 150 |                 let mut c = self.value.clone();
[INFO] [stderr]     |                     ----^
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     help: remove this `mut`
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g1.rs:164:1
[INFO] [stderr]     |
[INFO] [stderr] 164 | impl_group_elem_traits!(G1, GroupG1);
[INFO] [stderr]     | ------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr]     = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/group_elem.rs:150:21
[INFO] [stderr]     |
[INFO] [stderr] 150 |                 let mut c = self.value.clone();
[INFO] [stderr]     |                     ----^
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     help: remove this `mut`
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g2.rs:169:1
[INFO] [stderr]     |
[INFO] [stderr] 169 | impl_group_elem_traits!(G2, GroupG2);
[INFO] [stderr]     | ------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: constant `BigNumBits` should have an upper case name
[INFO] [stderr]  --> src/constants.rs:8:11
[INFO] [stderr]   |
[INFO] [stderr] 8 | 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)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `FieldElement_SIZE` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:11:11
[INFO] [stderr]    |
[INFO] [stderr] 11 | 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:14:11
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub const GroupG1_SIZE: usize = (2 * MODBYTES + 1) as usize;
[INFO] [stderr]    |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_G1_SIZE`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `GeneratorG1` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:17:20
[INFO] [stderr]    |
[INFO] [stderr] 17 |     pub static ref GeneratorG1: GroupG1 = GroupG1::generator();
[INFO] [stderr]    |                    ^^^^^^^^^^^ help: convert the identifier to upper case: `GENERATOR_G1`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `CurveOrder` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:18:20
[INFO] [stderr]    |
[INFO] [stderr] 18 |     pub static ref CurveOrder: BigNum = BigNum::new_ints(&rom::CURVE_ORDER);
[INFO] [stderr]    |                    ^^^^^^^^^^ help: convert the identifier to upper case: `CURVE_ORDER`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `CurveOrderBitSize` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:19:20
[INFO] [stderr]    |
[INFO] [stderr] 19 |     pub static ref CurveOrderBitSize: usize = CurveOrder.nbits();
[INFO] [stderr]    |                    ^^^^^^^^^^^^^^^^^ help: convert the identifier to upper case: `CURVE_ORDER_BIT_SIZE`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `FieldElementZero` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:20:20
[INFO] [stderr]    |
[INFO] [stderr] 20 |     pub static ref FieldElementZero: BigNum = BigNum::new();
[INFO] [stderr]    |                    ^^^^^^^^^^^^^^^^ help: convert the identifier to upper case: `FIELD_ELEMENT_ZERO`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `BarrettRedc_k` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:21:20
[INFO] [stderr]    |
[INFO] [stderr] 21 |     pub static ref BarrettRedc_k: usize = CurveOrder.nbits();
[INFO] [stderr]    |                    ^^^^^^^^^^^^^ help: convert the identifier to upper case: `BARRETT_REDC_K`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `BarrettRedc_u` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:22:20
[INFO] [stderr]    |
[INFO] [stderr] 22 |     pub static ref BarrettRedc_u: BigNum = {
[INFO] [stderr]    |                    ^^^^^^^^^^^^^ help: convert the identifier to upper case: `BARRETT_REDC_U`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `BarrettRedc_v` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:34:20
[INFO] [stderr]    |
[INFO] [stderr] 34 |     pub static ref BarrettRedc_v: BigNum = {
[INFO] [stderr]    |                    ^^^^^^^^^^^^^ help: convert the identifier to upper case: `BARRETT_REDC_V`
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_seeded_RNG_with_rng` should have a snake case name
[INFO] [stderr]   --> src/utils.rs:23:8
[INFO] [stderr]    |
[INFO] [stderr] 23 | 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)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_seeded_RNG` should have a snake case name
[INFO] [stderr]   --> src/utils.rs:30:8
[INFO] [stderr]    |
[INFO] [stderr] 30 | 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:37:4
[INFO] [stderr]    |
[INFO] [stderr] 37 | 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:334:8
[INFO] [stderr]     |
[INFO] [stderr] 334 |     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: variable `A` should have a snake case name
[INFO] [stderr]    --> src/group_elem.rs:411:21
[INFO] [stderr]     |
[INFO] [stderr] 411 |             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:172:1
[INFO] [stderr]     |
[INFO] [stderr] 172 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (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:412:25
[INFO] [stderr]     |
[INFO] [stderr] 412 |                 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:172:1
[INFO] [stderr]     |
[INFO] [stderr] 172 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (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:422:21
[INFO] [stderr]     |
[INFO] [stderr] 422 |                 let A2 = A.double();
[INFO] [stderr]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g1.rs:172:1
[INFO] [stderr]     |
[INFO] [stderr] 172 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_hex_as_FP` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g1.rs:189:8
[INFO] [stderr]     |
[INFO] [stderr] 189 | pub fn parse_hex_as_FP(iter: &mut SplitWhitespace) -> Result<FP, SerzDeserzError> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp`
[INFO] [stderr] 
[INFO] [stderr] warning: constant `GroupG2_SIZE` should have an upper case name
[INFO] [stderr]  --> src/types_g2.rs:5:11
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub const GroupG2_SIZE: usize = (4 * MODBYTES) as usize;
[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: static variable `GeneratorG2` should have an upper case name
[INFO] [stderr]   --> src/types_g2.rs:11:20
[INFO] [stderr]    |
[INFO] [stderr] 11 |     pub static ref GeneratorG2: GroupG2 = GroupG2::generator();
[INFO] [stderr]    |                    ^^^^^^^^^^^ help: convert the identifier to upper case: `GENERATOR_G2`
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_hex_as_FP2` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g2.rs:156:8
[INFO] [stderr]     |
[INFO] [stderr] 156 | pub fn parse_hex_as_FP2(iter: &mut SplitWhitespace) -> 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:411:21
[INFO] [stderr]     |
[INFO] [stderr] 411 |             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:177:1
[INFO] [stderr]     |
[INFO] [stderr] 177 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (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:412:25
[INFO] [stderr]     |
[INFO] [stderr] 412 |                 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:177:1
[INFO] [stderr]     |
[INFO] [stderr] 177 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (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:422:21
[INFO] [stderr]     |
[INFO] [stderr] 422 |                 let A2 = A.double();
[INFO] [stderr]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g2.rs:177:1
[INFO] [stderr]     |
[INFO] [stderr] 177 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_hex_as_FP4` should have a snake case name
[INFO] [stderr]    --> src/extension_field_gt.rs:202:8
[INFO] [stderr]     |
[INFO] [stderr] 202 | pub fn parse_hex_as_FP4(iter: &mut SplitWhitespace) -> Result<FP4, SerzDeserzError> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp4`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item '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:667:17
[INFO] [stderr]     |
[INFO] [stderr] 667 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g1.rs:184:1
[INFO] [stderr]     |
[INFO] [stderr] 184 | 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 a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item '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:667:17
[INFO] [stderr]     |
[INFO] [stderr] 667 |                 Self::multi_scalar_mul_var_time_from_ref_vecs(group_elems, field_elems)
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g2.rs:189:1
[INFO] [stderr]     |
[INFO] [stderr] 189 | impl_group_elem_vec_product_ops!(G2, G2Vector, G2LookupTable);
[INFO] [stderr]     | -------------------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[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: variable does not need to be mutable
[INFO] [stderr]    --> src/group_elem.rs:150:21
[INFO] [stderr]     |
[INFO] [stderr] 150 |                 let mut c = self.value.clone();
[INFO] [stderr]     |                     ----^
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     help: remove this `mut`
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g1.rs:164:1
[INFO] [stderr]     |
[INFO] [stderr] 164 | impl_group_elem_traits!(G1, GroupG1);
[INFO] [stderr]     | ------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr]     = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/group_elem.rs:150:21
[INFO] [stderr]     |
[INFO] [stderr] 150 |                 let mut c = self.value.clone();
[INFO] [stderr]     |                     ----^
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     help: remove this `mut`
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g2.rs:169:1
[INFO] [stderr]     |
[INFO] [stderr] 169 | impl_group_elem_traits!(G2, GroupG2);
[INFO] [stderr]     | ------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[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: constant `BigNumBits` should have an upper case name
[INFO] [stderr]  --> src/constants.rs:8:11
[INFO] [stderr]   |
[INFO] [stderr] 8 | 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)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: constant `FieldElement_SIZE` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:11:11
[INFO] [stderr]    |
[INFO] [stderr] 11 | 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:14:11
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub const GroupG1_SIZE: usize = (2 * MODBYTES + 1) as usize;
[INFO] [stderr]    |           ^^^^^^^^^^^^ help: convert the identifier to upper case: `GROUP_G1_SIZE`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `GeneratorG1` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:17:20
[INFO] [stderr]    |
[INFO] [stderr] 17 |     pub static ref GeneratorG1: GroupG1 = GroupG1::generator();
[INFO] [stderr]    |                    ^^^^^^^^^^^ help: convert the identifier to upper case: `GENERATOR_G1`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `CurveOrder` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:18:20
[INFO] [stderr]    |
[INFO] [stderr] 18 |     pub static ref CurveOrder: BigNum = BigNum::new_ints(&rom::CURVE_ORDER);
[INFO] [stderr]    |                    ^^^^^^^^^^ help: convert the identifier to upper case: `CURVE_ORDER`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `CurveOrderBitSize` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:19:20
[INFO] [stderr]    |
[INFO] [stderr] 19 |     pub static ref CurveOrderBitSize: usize = CurveOrder.nbits();
[INFO] [stderr]    |                    ^^^^^^^^^^^^^^^^^ help: convert the identifier to upper case: `CURVE_ORDER_BIT_SIZE`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `FieldElementZero` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:20:20
[INFO] [stderr]    |
[INFO] [stderr] 20 |     pub static ref FieldElementZero: BigNum = BigNum::new();
[INFO] [stderr]    |                    ^^^^^^^^^^^^^^^^ help: convert the identifier to upper case: `FIELD_ELEMENT_ZERO`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `BarrettRedc_k` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:21:20
[INFO] [stderr]    |
[INFO] [stderr] 21 |     pub static ref BarrettRedc_k: usize = CurveOrder.nbits();
[INFO] [stderr]    |                    ^^^^^^^^^^^^^ help: convert the identifier to upper case: `BARRETT_REDC_K`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `BarrettRedc_u` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:22:20
[INFO] [stderr]    |
[INFO] [stderr] 22 |     pub static ref BarrettRedc_u: BigNum = {
[INFO] [stderr]    |                    ^^^^^^^^^^^^^ help: convert the identifier to upper case: `BARRETT_REDC_U`
[INFO] [stderr] 
[INFO] [stderr] warning: static variable `BarrettRedc_v` should have an upper case name
[INFO] [stderr]   --> src/constants.rs:34:20
[INFO] [stderr]    |
[INFO] [stderr] 34 |     pub static ref BarrettRedc_v: BigNum = {
[INFO] [stderr]    |                    ^^^^^^^^^^^^^ help: convert the identifier to upper case: `BARRETT_REDC_V`
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_seeded_RNG_with_rng` should have a snake case name
[INFO] [stderr]   --> src/utils.rs:23:8
[INFO] [stderr]    |
[INFO] [stderr] 23 | 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)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_seeded_RNG` should have a snake case name
[INFO] [stderr]   --> src/utils.rs:30:8
[INFO] [stderr]    |
[INFO] [stderr] 30 | 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:37:4
[INFO] [stderr]    |
[INFO] [stderr] 37 | 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:334:8
[INFO] [stderr]     |
[INFO] [stderr] 334 |     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: variable `R` should have a snake case name
[INFO] [stderr]     --> src/field_elem.rs:1472:17
[INFO] [stderr]      |
[INFO] [stderr] 1472 |         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:1117:25
[INFO] [stderr]      |
[INFO] [stderr] 1117 |                 let mut R = $group::random();
[INFO] [stderr]      |                         ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] ...
[INFO] [stderr] 1137 |         add_mul!(G1);
[INFO] [stderr]      |         ------------- in this macro invocation
[INFO] [stderr]      |
[INFO] [stderr]      = note: this warning originates in a macro (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:1127:21
[INFO] [stderr]      |
[INFO] [stderr] 1127 |                     &points[i] * &fs[i];
[INFO] [stderr]      |                     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1137 |         add_mul!(G1);
[INFO] [stderr]      |         ------------- in this macro invocation
[INFO] [stderr]      |
[INFO] [stderr]      = note: `#[warn(unused_must_use)]` on by default
[INFO] [stderr]      = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]     --> src/group_elem.rs:1117:25
[INFO] [stderr]      |
[INFO] [stderr] 1117 |                 let mut R = $group::random();
[INFO] [stderr]      |                         ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] ...
[INFO] [stderr] 1139 |         add_mul!(G2);
[INFO] [stderr]      |         ------------- in this macro invocation
[INFO] [stderr]      |
[INFO] [stderr]      = note: this warning originates in a macro (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:1127:21
[INFO] [stderr]      |
[INFO] [stderr] 1127 |                     &points[i] * &fs[i];
[INFO] [stderr]      |                     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 1139 |         add_mul!(G2);
[INFO] [stderr]      |         ------------- in this macro invocation
[INFO] [stderr]      |
[INFO] [stderr]      = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: variable `A` should have a snake case name
[INFO] [stderr]    --> src/group_elem.rs:411:21
[INFO] [stderr]     |
[INFO] [stderr] 411 |             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:172:1
[INFO] [stderr]     |
[INFO] [stderr] 172 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (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:412:25
[INFO] [stderr]     |
[INFO] [stderr] 412 |                 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:172:1
[INFO] [stderr]     |
[INFO] [stderr] 172 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (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:422:21
[INFO] [stderr]     |
[INFO] [stderr] 422 |                 let A2 = A.double();
[INFO] [stderr]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g1.rs:172:1
[INFO] [stderr]     |
[INFO] [stderr] 172 | impl_group_element_lookup_table!(G1, G1LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_hex_as_FP` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g1.rs:189:8
[INFO] [stderr]     |
[INFO] [stderr] 189 | pub fn parse_hex_as_FP(iter: &mut SplitWhitespace) -> Result<FP, SerzDeserzError> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp`
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_parse_hex_for_FP` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g1.rs:221:8
[INFO] [stderr]     |
[INFO] [stderr] 221 |     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:226:8
[INFO] [stderr]     |
[INFO] [stderr] 226 |     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: constant `GroupG2_SIZE` should have an upper case name
[INFO] [stderr]  --> src/types_g2.rs:5:11
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub const GroupG2_SIZE: usize = (4 * MODBYTES) as usize;
[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: static variable `GeneratorG2` should have an upper case name
[INFO] [stderr]   --> src/types_g2.rs:11:20
[INFO] [stderr]    |
[INFO] [stderr] 11 |     pub static ref GeneratorG2: GroupG2 = GroupG2::generator();
[INFO] [stderr]    |                    ^^^^^^^^^^^ help: convert the identifier to upper case: `GENERATOR_G2`
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_hex_as_FP2` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g2.rs:156:8
[INFO] [stderr]     |
[INFO] [stderr] 156 | pub fn parse_hex_as_FP2(iter: &mut SplitWhitespace) -> 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:411:21
[INFO] [stderr]     |
[INFO] [stderr] 411 |             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:177:1
[INFO] [stderr]     |
[INFO] [stderr] 177 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (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:412:25
[INFO] [stderr]     |
[INFO] [stderr] 412 |                 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:177:1
[INFO] [stderr]     |
[INFO] [stderr] 177 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (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:422:21
[INFO] [stderr]     |
[INFO] [stderr] 422 |                 let A2 = A.double();
[INFO] [stderr]     |                     ^^ help: convert the identifier to snake case: `a2`
[INFO] [stderr]     | 
[INFO] [stderr]    ::: src/group_elem_g2.rs:177:1
[INFO] [stderr]     |
[INFO] [stderr] 177 | impl_group_element_lookup_table!(G2, G2LookupTable);
[INFO] [stderr]     | ---------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_parse_hex_for_FP2` should have a snake case name
[INFO] [stderr]    --> src/group_elem_g2.rs:211:8
[INFO] [stderr]     |
[INFO] [stderr] 211 |     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:216:8
[INFO] [stderr]     |
[INFO] [stderr] 216 |     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: function `parse_hex_as_FP4` should have a snake case name
[INFO] [stderr]    --> src/extension_field_gt.rs:202:8
[INFO] [stderr]     |
[INFO] [stderr] 202 | pub fn parse_hex_as_FP4(iter: &mut SplitWhitespace) -> Result<FP4, SerzDeserzError> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `parse_hex_as_fp4`
[INFO] [stderr] 
[INFO] [stderr]     Finished dev [unoptimized + debuginfo] target(s) in 14.88s
[INFO] running `"docker" "inspect" "4deae269e05cd8a0566c3d86a3b3085435ab0f772e8d114fe85e25d483b1cd12"`
[INFO] running `"docker" "rm" "-f" "4deae269e05cd8a0566c3d86a3b3085435ab0f772e8d114fe85e25d483b1cd12"`
[INFO] [stdout] 4deae269e05cd8a0566c3d86a3b3085435ab0f772e8d114fe85e25d483b1cd12
