[INFO] crate schnorr 0.0.18 is already in cache
[INFO] checking schnorr-0.0.18 against master#209b2be09fcaff937480d1fbbe8b31646e361c7a for pr-70917
[INFO] extracting crate schnorr 0.0.18 into /workspace/builds/worker-3/source
[INFO] validating manifest of crates.io crate schnorr 0.0.18 on toolchain 209b2be09fcaff937480d1fbbe8b31646e361c7a
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking crates.io crate schnorr 0.0.18
[INFO] finished tweaking crates.io crate schnorr 0.0.18
[INFO] tweaked toml for crates.io crate schnorr 0.0.18 written to /workspace/builds/worker-3/source/Cargo.toml
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3/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" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "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] 9ac082d3e82807bf8ec6a05f01947f8b99c301ec037f0ac7dfc39aecc21a7392
[INFO] running `"docker" "start" "-a" "9ac082d3e82807bf8ec6a05f01947f8b99c301ec037f0ac7dfc39aecc21a7392"`
[INFO] [stderr]    Compiling crunchy v0.2.2
[INFO] [stderr]    Compiling packed_simd v0.3.3
[INFO] [stderr]    Compiling curve25519-dalek-organism v0.0.5
[INFO] [stderr]     Checking subtle v2.2.2
[INFO] [stderr]     Checking blake2b_simd v0.5.10
[INFO] [stderr]     Checking rand_xoshiro v0.1.0
[INFO] [stderr]    Compiling parking_lot_core v0.6.2
[INFO] [stderr]    Compiling parking_lot v0.9.0
[INFO] [stderr]     Checking crypto-mac v0.7.0
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]    Compiling thiserror-impl v1.0.14
[INFO] [stderr]    Compiling zeroize_derive v1.0.0
[INFO] [stderr]     Checking criterion-plot v0.3.1
[INFO] [stderr]     Checking blake2 v0.8.1
[INFO] [stderr]     Checking bytes v0.4.12
[INFO] [stderr]     Checking bstr v0.2.12
[INFO] [stderr]     Checking bincode v0.9.2
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking tinytemplate v1.0.3
[INFO] [stderr]     Checking zeroize v1.1.0
[INFO] [stderr]     Checking csv v1.1.3
[INFO] [stderr]     Checking uint v0.8.2
[INFO] [stderr]     Checking thiserror v1.0.14
[INFO] [stderr]     Checking criterion v0.2.11
[INFO] [stderr]     Checking mohan v0.0.52
[INFO] [stderr]     Checking bacteria v0.0.8
[INFO] [stderr]     Checking schnorr v0.0.18 (/opt/rustwide/workdir)
[INFO] [stderr] warning: unused imports: `CompressedRistretto`, `IsIdentity`, `RISTRETTO_BASEPOINT_TABLE`, `RistrettoPoint`, `VartimeMultiscalarMul`, `scalar::Scalar`
[INFO] [stderr]    --> src/signature.rs:390:21
[INFO] [stderr]     |
[INFO] [stderr] 390 |         constants::{RISTRETTO_BASEPOINT_TABLE},
[INFO] [stderr]     |                     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 391 |         ristretto::{CompressedRistretto, RistrettoPoint},
[INFO] [stderr]     |                     ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stderr] 392 |         scalar::Scalar,
[INFO] [stderr]     |         ^^^^^^^^^^^^^^
[INFO] [stderr] 393 |         traits::{IsIdentity, VartimeMultiscalarMul},
[INFO] [stderr]     |                  ^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `BatchVerification`, `SecretKey`
[INFO] [stderr]    --> src/signature.rs:397:32
[INFO] [stderr]     |
[INFO] [stderr] 397 |         tools::SigningContext, BatchVerification, BatchVerifier, Keypair, PublicKey, SecretKey,
[INFO] [stderr]     |                                ^^^^^^^^^^^^^^^^^                                     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around type
[INFO] [stderr]    --> src/threshold.rs:212:17
[INFO] [stderr]     |
[INFO] [stderr] 212 |     ) -> Result<(VerifiableSS), SchnorrError> {
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `CompressedRistretto`, `H256`, `IsIdentity`, `RISTRETTO_BASEPOINT_POINT`, `RISTRETTO_BASEPOINT_TABLE`, `VartimeMultiscalarMul`, `blake256`, `mohan_rand`
[INFO] [stderr]   --> src/threshold_test.rs:14:5
[INFO] [stderr]    |
[INFO] [stderr] 14 |     mohan_rand,
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] 15 |     hash::{
[INFO] [stderr] 16 |         blake256,
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] 17 |         H256
[INFO] [stderr]    |         ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 20 |         constants::{RISTRETTO_BASEPOINT_POINT, RISTRETTO_BASEPOINT_TABLE},
[INFO] [stderr]    |                     ^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 21 |         ristretto::{CompressedRistretto, RistrettoPoint},
[INFO] [stderr]    |                     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 24 |             IsIdentity, 
[INFO] [stderr]    |             ^^^^^^^^^^
[INFO] [stderr] 25 |             VartimeMultiscalarMul
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ristretto::CompressedRistretto`
[INFO] [stderr]  --> src/musig_test.rs:4:20
[INFO] [stderr]   |
[INFO] [stderr] 4 | use mohan::dalek::{ristretto::CompressedRistretto, scalar::Scalar};
[INFO] [stderr]   |                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around type
[INFO] [stderr]    --> src/threshold.rs:212:17
[INFO] [stderr]     |
[INFO] [stderr] 212 |     ) -> Result<(VerifiableSS), SchnorrError> {
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function cannot return without recursing
[INFO] [stderr]    --> src/keys/public.rs:173:5
[INFO] [stderr]     |
[INFO] [stderr] 173 |     fn partial_cmp(&self, other: &PublicKey) -> Option<std::cmp::Ordering> {
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ cannot return without recursing
[INFO] [stderr] 174 |         self.partial_cmp(&other)
[INFO] [stderr]     |         ------------------------ recursive call site
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unconditional_recursion)]` on by default
[INFO] [stderr]     = help: a `loop` may express intention better if this is on purpose
[INFO] [stderr] 
[INFO] [stderr] warning: function cannot return without recursing
[INFO] [stderr]    --> src/keys/public.rs:179:5
[INFO] [stderr]     |
[INFO] [stderr] 179 |     fn cmp(&self, other: &Self) -> std::cmp::Ordering {
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ cannot return without recursing
[INFO] [stderr] 180 |         self.cmp(&other)
[INFO] [stderr]     |         ---------------- recursive call site
[INFO] [stderr]     |
[INFO] [stderr]     = help: a `loop` may express intention better if this is on purpose
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `child2_prv`
[INFO] [stderr]    --> src/keys/extended.rs:415:13
[INFO] [stderr]     |
[INFO] [stderr] 415 |         let child2_prv = child_prv.derive_intermediate_key(|prf| prf.append_u64(b"index", 1));
[INFO] [stderr]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_child2_prv`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `child2_pub`
[INFO] [stderr]    --> src/keys/extended.rs:416:13
[INFO] [stderr]     |
[INFO] [stderr] 416 |         let child2_pub = child_pub.derive_intermediate_key(|prf| prf.append_u64(b"index", 1));
[INFO] [stderr]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_child2_pub`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `leaf_prv`
[INFO] [stderr]    --> src/keys/extended.rs:419:13
[INFO] [stderr]     |
[INFO] [stderr] 419 |         let leaf_prv = child_prv.derive_key(|prf| prf.append_u64(b"index", 1));
[INFO] [stderr]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_leaf_prv`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `leaf_pub`
[INFO] [stderr]    --> src/keys/extended.rs:420:13
[INFO] [stderr]     |
[INFO] [stderr] 420 |         let leaf_pub = child_pub.derive_key(|prf| prf.append_u64(b"index", 1));
[INFO] [stderr]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_leaf_pub`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `seed`
[INFO] [stderr]    --> src/keys/extended.rs:455:13
[INFO] [stderr]     |
[INFO] [stderr] 455 |         let seed = [0u8; 32];
[INFO] [stderr]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_seed`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `xprv`
[INFO] [stderr]    --> src/keys/extended.rs:456:13
[INFO] [stderr]     |
[INFO] [stderr] 456 |         let xprv = XSecretKey::generate(&mut mohan::mohan_rand());
[INFO] [stderr]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_xprv`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `xprv`
[INFO] [stderr]    --> src/keys/extended.rs:473:13
[INFO] [stderr]     |
[INFO] [stderr] 473 |         let xprv = XSecretKey::generate(&mut rng).derive_intermediate_key(|t| {
[INFO] [stderr]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_xprv`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `xprv`
[INFO] [stderr]    --> src/keys/extended.rs:495:13
[INFO] [stderr]     |
[INFO] [stderr] 495 |         let xprv = XSecretKey::generate(&mut rng).derive_key(|t| {
[INFO] [stderr]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_xprv`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `xpub`
[INFO] [stderr]    --> src/keys/extended.rs:586:13
[INFO] [stderr]     |
[INFO] [stderr] 586 |         let xpub = xprv.to_public().derive_intermediate_key(|t| {
[INFO] [stderr]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_xpub`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `xpub`
[INFO] [stderr]    --> src/keys/extended.rs:607:13
[INFO] [stderr]     |
[INFO] [stderr] 607 |         let xpub = xprv.to_public().derive_key(|t| {
[INFO] [stderr]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_xpub`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `transcripts`
[INFO] [stderr]    --> src/signature.rs:583:17
[INFO] [stderr]     |
[INFO] [stderr] 583 |         let mut transcripts: Vec<Transcript> = messages.iter().map(|m| ctx.bytes(m)).collect();
[INFO] [stderr]     |                 ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transcripts`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/feldman_vss.rs:101:13
[INFO] [stderr]     |
[INFO] [stderr] 101 |         let mut transcript = Transcript::new(b"VSS");
[INFO] [stderr]     |             ----^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function cannot return without recursing
[INFO] [stderr]    --> src/keys/public.rs:173:5
[INFO] [stderr]     |
[INFO] [stderr] 173 |     fn partial_cmp(&self, other: &PublicKey) -> Option<std::cmp::Ordering> {
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ cannot return without recursing
[INFO] [stderr] 174 |         self.partial_cmp(&other)
[INFO] [stderr]     |         ------------------------ recursive call site
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unconditional_recursion)]` on by default
[INFO] [stderr]     = help: a `loop` may express intention better if this is on purpose
[INFO] [stderr] 
[INFO] [stderr] warning: function cannot return without recursing
[INFO] [stderr]    --> src/keys/public.rs:179:5
[INFO] [stderr]     |
[INFO] [stderr] 179 |     fn cmp(&self, other: &Self) -> std::cmp::Ordering {
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ cannot return without recursing
[INFO] [stderr] 180 |         self.cmp(&other)
[INFO] [stderr]     |         ---------------- recursive call site
[INFO] [stderr]     |
[INFO] [stderr]     = help: a `loop` may express intention better if this is on purpose
[INFO] [stderr] 
[INFO] [stderr] warning: variable `X` should have a snake case name
[INFO] [stderr]   --> src/keys/multikey.rs:43:13
[INFO] [stderr]    |
[INFO] [stderr] 43 |         for X in &pubkeys {
[INFO] [stderr]    |             ^ help: convert the identifier to snake case (notice the capitalization): `x`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable `X` should have a snake case name
[INFO] [stderr]   --> src/keys/multikey.rs:50:17
[INFO] [stderr]    |
[INFO] [stderr] 50 |         for (i, X) in pubkeys.iter().enumerate() {
[INFO] [stderr]    |                 ^ help: convert the identifier to snake case (notice the capitalization): `x`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `X` should have a snake case name
[INFO] [stderr]   --> src/keys/multikey.rs:52:17
[INFO] [stderr]    |
[INFO] [stderr] 52 |             let X = X.into_point();
[INFO] [stderr]    |                 ^ help: convert the identifier to snake case (notice the capitalization): `x`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]   --> src/multisignature.rs:75:13
[INFO] [stderr]    |
[INFO] [stderr] 75 |         let R = (RISTRETTO_BASEPOINT_POINT * r).compress();
[INFO] [stderr]    |             ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R_i` should have a snake case name
[INFO] [stderr]   --> src/counterparty.rs:33:33
[INFO] [stderr]    |
[INFO] [stderr] 33 |         commitments.iter().map(|R_i| R_i.0).sum()
[INFO] [stderr]    |                                 ^^^ help: convert the identifier to snake case: `r_i`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `S_i` should have a snake case name
[INFO] [stderr]    --> src/counterparty.rs:103:13
[INFO] [stderr]     |
[INFO] [stderr] 103 |         let S_i = share * RISTRETTO_BASEPOINT_POINT;
[INFO] [stderr]     |             ^^^ help: convert the identifier to snake case (notice the capitalization): `s_i`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `X_i` should have a snake case name
[INFO] [stderr]    --> src/counterparty.rs:105:13
[INFO] [stderr]     |
[INFO] [stderr] 105 |         let X_i = self.pubkey.into_point();
[INFO] [stderr]     |             ^^^ help: convert the identifier to snake case (notice the capitalization): `x_i`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `R` should have a snake case name
[INFO] [stderr]   --> src/signer.rs:42:5
[INFO] [stderr]    |
[INFO] [stderr] 42 |     R: RistrettoPoint,
[INFO] [stderr]    |     ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R_i` should have a snake case name
[INFO] [stderr]   --> src/signer.rs:63:13
[INFO] [stderr]    |
[INFO] [stderr] 63 |         let R_i = NonceCommitment::new(RISTRETTO_BASEPOINT_POINT * r_i);
[INFO] [stderr]    |             ^^^ help: convert the identifier to snake case: `r_i`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]    --> src/signer.rs:122:13
[INFO] [stderr]     |
[INFO] [stderr] 122 |         let R = NonceCommitment::sum(&nonce_commitments);
[INFO] [stderr]     |             ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/signature.rs:583:13
[INFO] [stderr]     |
[INFO] [stderr] 583 |         let mut transcripts: Vec<Transcript> = messages.iter().map(|m| ctx.bytes(m)).collect();
[INFO] [stderr]     |             ----^^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/feldman_vss.rs:101:13
[INFO] [stderr]     |
[INFO] [stderr] 101 |         let mut transcript = Transcript::new(b"VSS");
[INFO] [stderr]     |             ----^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/feldman_vss.rs:264:13
[INFO] [stderr]     |
[INFO] [stderr] 264 |         let mut transcript = Transcript::new(b"VSS");
[INFO] [stderr]     |             ----^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/feldman_vss.rs:287:13
[INFO] [stderr]     |
[INFO] [stderr] 287 |         let mut transcript = Transcript::new(b"VSS");
[INFO] [stderr]     |             ----^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/feldman_vss.rs:335:14
[INFO] [stderr]     |
[INFO] [stderr] 335 |          let mut transcript = Transcript::new(b"VSS");
[INFO] [stderr]     |              ----^^^^^^^^^^
[INFO] [stderr]     |              |
[INFO] [stderr]     |              help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/feldman_vss.rs:378:14
[INFO] [stderr]     |
[INFO] [stderr] 378 |          let mut transcript = Transcript::new(b"VSS");
[INFO] [stderr]     |              ----^^^^^^^^^^
[INFO] [stderr]     |              |
[INFO] [stderr]     |              help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/feldman_vss.rs:413:13
[INFO] [stderr]     |
[INFO] [stderr] 413 |         let mut transcript = Transcript::new(b"VSS");
[INFO] [stderr]     |             ----^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `X` should have a snake case name
[INFO] [stderr]   --> src/keys/multikey.rs:43:13
[INFO] [stderr]    |
[INFO] [stderr] 43 |         for X in &pubkeys {
[INFO] [stderr]    |             ^ help: convert the identifier to snake case (notice the capitalization): `x`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable `X` should have a snake case name
[INFO] [stderr]   --> src/keys/multikey.rs:50:17
[INFO] [stderr]    |
[INFO] [stderr] 50 |         for (i, X) in pubkeys.iter().enumerate() {
[INFO] [stderr]    |                 ^ help: convert the identifier to snake case (notice the capitalization): `x`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `X` should have a snake case name
[INFO] [stderr]   --> src/keys/multikey.rs:52:17
[INFO] [stderr]    |
[INFO] [stderr] 52 |             let X = X.into_point();
[INFO] [stderr]    |                 ^ help: convert the identifier to snake case (notice the capitalization): `x`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]   --> src/multisignature.rs:75:13
[INFO] [stderr]    |
[INFO] [stderr] 75 |         let R = (RISTRETTO_BASEPOINT_POINT * r).compress();
[INFO] [stderr]    |             ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R_i` should have a snake case name
[INFO] [stderr]   --> src/counterparty.rs:33:33
[INFO] [stderr]    |
[INFO] [stderr] 33 |         commitments.iter().map(|R_i| R_i.0).sum()
[INFO] [stderr]    |                                 ^^^ help: convert the identifier to snake case: `r_i`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `S_i` should have a snake case name
[INFO] [stderr]    --> src/counterparty.rs:103:13
[INFO] [stderr]     |
[INFO] [stderr] 103 |         let S_i = share * RISTRETTO_BASEPOINT_POINT;
[INFO] [stderr]     |             ^^^ help: convert the identifier to snake case (notice the capitalization): `s_i`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `X_i` should have a snake case name
[INFO] [stderr]    --> src/counterparty.rs:105:13
[INFO] [stderr]     |
[INFO] [stderr] 105 |         let X_i = self.pubkey.into_point();
[INFO] [stderr]     |             ^^^ help: convert the identifier to snake case (notice the capitalization): `x_i`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `R` should have a snake case name
[INFO] [stderr]   --> src/signer.rs:42:5
[INFO] [stderr]    |
[INFO] [stderr] 42 |     R: RistrettoPoint,
[INFO] [stderr]    |     ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R_i` should have a snake case name
[INFO] [stderr]   --> src/signer.rs:63:13
[INFO] [stderr]    |
[INFO] [stderr] 63 |         let R_i = NonceCommitment::new(RISTRETTO_BASEPOINT_POINT * r_i);
[INFO] [stderr]    |             ^^^ help: convert the identifier to snake case: `r_i`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]    --> src/signer.rs:122:13
[INFO] [stderr]     |
[INFO] [stderr] 122 |         let R = NonceCommitment::sum(&nonce_commitments);
[INFO] [stderr]     |             ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr]     Finished dev [unoptimized + debuginfo] target(s) in 52.07s
[INFO] running `"docker" "inspect" "9ac082d3e82807bf8ec6a05f01947f8b99c301ec037f0ac7dfc39aecc21a7392"`
[INFO] running `"docker" "rm" "-f" "9ac082d3e82807bf8ec6a05f01947f8b99c301ec037f0ac7dfc39aecc21a7392"`
[INFO] [stdout] 9ac082d3e82807bf8ec6a05f01947f8b99c301ec037f0ac7dfc39aecc21a7392
