[INFO] fetching crate safecoin-vote-program 1.14.17... [INFO] checking safecoin-vote-program-1.14.17 against master#8c32e313cccf7df531e2d49ffb8227bb92304aee for pr-145608-1 [INFO] extracting crate safecoin-vote-program 1.14.17 into /workspace/builds/worker-0-tc1/source [INFO] started tweaking crates.io crate safecoin-vote-program 1.14.17 [INFO] finished tweaking crates.io crate safecoin-vote-program 1.14.17 [INFO] tweaked toml for crates.io crate safecoin-vote-program 1.14.17 written to /workspace/builds/worker-0-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate safecoin-vote-program 1.14.17 on toolchain 8c32e313cccf7df531e2d49ffb8227bb92304aee [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+8c32e313cccf7df531e2d49ffb8227bb92304aee" "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" "+8c32e313cccf7df531e2d49ffb8227bb92304aee" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 302 packages to latest compatible versions [INFO] [stderr] Adding bincode v1.3.3 (available: v2.0.1) [INFO] [stderr] Adding itertools v0.10.5 (available: v0.14.0) [INFO] [stderr] Adding num-derive v0.3.3 (available: v0.4.2) [INFO] [stderr] Adding rand v0.7.3 (available: v0.9.2) [INFO] [stderr] Adding test-case v2.2.2 (available: v3.3.1) [INFO] [stderr] Adding thiserror v1.0.69 (available: v2.0.16) [INFO] [stderr] Adding zeroize v1.3.0 (available: v1.8.1) [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+8c32e313cccf7df531e2d49ffb8227bb92304aee" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded test-case-macros v2.2.2 [INFO] [stderr] Downloaded safecoin-sdk-macro v1.14.17 [INFO] [stderr] Downloaded safecoin-logger v1.14.17 [INFO] [stderr] Downloaded safecoin-frozen-abi-macro v1.14.17 [INFO] [stderr] Downloaded test-case v2.2.2 [INFO] [stderr] Downloaded safecoin-frozen-abi v1.14.17 [INFO] [stderr] Downloaded safecoin-measure v1.14.17 [INFO] [stderr] Downloaded safecoin-program-runtime v1.14.17 [INFO] [stderr] Downloaded safecoin-program v1.14.17 [INFO] [stderr] Downloaded safecoin-metrics v1.14.17 [INFO] [stderr] Downloaded safecoin-sdk v1.14.17 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+8c32e313cccf7df531e2d49ffb8227bb92304aee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 39e05516cd9ada2abe732a3d3e74ac885e855fab8f431b9b0b433c66cd6ef16f [INFO] running `Command { std: "docker" "start" "-a" "39e05516cd9ada2abe732a3d3e74ac885e855fab8f431b9b0b433c66cd6ef16f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "39e05516cd9ada2abe732a3d3e74ac885e855fab8f431b9b0b433c66cd6ef16f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "39e05516cd9ada2abe732a3d3e74ac885e855fab8f431b9b0b433c66cd6ef16f", kill_on_drop: false }` [INFO] [stdout] 39e05516cd9ada2abe732a3d3e74ac885e855fab8f431b9b0b433c66cd6ef16f [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+8c32e313cccf7df531e2d49ffb8227bb92304aee" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] fc2d0fa6ca7ea2723c7cee274abf044a689c2376c41d19b853be094f57f3a319 [INFO] running `Command { std: "docker" "start" "-a" "fc2d0fa6ca7ea2723c7cee274abf044a689c2376c41d19b853be094f57f3a319", kill_on_drop: false }` [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling generic-array v0.14.7 [INFO] [stderr] Compiling ahash v0.7.8 [INFO] [stderr] Checking rand_chacha v0.2.2 [INFO] [stderr] Compiling safecoin-frozen-abi-macro v1.14.17 [INFO] [stderr] Checking regex-automata v0.4.10 [INFO] [stderr] Checking serde_json v1.0.143 [INFO] [stderr] Compiling safecoin-frozen-abi v1.14.17 [INFO] [stderr] Compiling memoffset v0.6.5 [INFO] [stderr] Checking futures-util v0.3.31 [INFO] [stderr] Checking blake3 v1.8.2 [INFO] [stderr] Compiling safecoin-program v1.14.17 [INFO] [stderr] Compiling safecoin-sdk v1.14.17 [INFO] [stderr] Checking base64 v0.13.1 [INFO] [stderr] Checking compression-codecs v0.4.30 [INFO] [stderr] Checking chrono v0.4.41 [INFO] [stderr] Compiling safecoin-program-runtime v1.14.17 [INFO] [stderr] Compiling safecoin-vote-program v1.14.17 (/opt/rustwide/workdir) [INFO] [stderr] Checking async-compression v0.4.30 [INFO] [stderr] Checking rand v0.7.3 [INFO] [stderr] Compiling digest v0.9.0 [INFO] [stderr] Compiling libsecp256k1-core v0.2.2 [INFO] [stderr] Checking hashbrown v0.11.2 [INFO] [stderr] Checking hashbrown v0.12.3 [INFO] [stderr] Checking ed25519-dalek v1.0.1 [INFO] [stderr] Checking tiny-bip39 v0.8.2 [INFO] [stderr] Checking ed25519-dalek-bip32 v0.2.0 [INFO] [stderr] Checking regex v1.11.2 [INFO] [stderr] Compiling libsecp256k1-gen-genmult v0.2.1 [INFO] [stderr] Compiling libsecp256k1-gen-ecmult v0.2.1 [INFO] [stderr] Checking h2 v0.3.27 [INFO] [stderr] Compiling libsecp256k1 v0.6.0 [INFO] [stderr] Checking env_logger v0.9.3 [INFO] [stderr] Checking safecoin-logger v1.14.17 [INFO] [stderr] Compiling borsh-derive-internal v0.9.3 [INFO] [stderr] Compiling borsh-schema-derive-internal v0.9.3 [INFO] [stderr] Compiling proc-macro-error v1.0.4 [INFO] [stderr] Checking hyper v0.14.32 [INFO] [stderr] Compiling borsh-derive v0.9.3 [INFO] [stderr] Compiling safecoin-sdk-macro v1.14.17 [INFO] [stderr] Compiling num-derive v0.3.3 [INFO] [stderr] Compiling enum-iterator-derive v0.8.1 [INFO] [stderr] Compiling test-case-macros v2.2.2 [INFO] [stderr] Checking borsh v0.9.3 [INFO] [stderr] Checking test-case v2.2.2 [INFO] [stderr] Checking enum-iterator v0.8.1 [INFO] [stderr] Checking hyper-rustls v0.24.2 [INFO] [stderr] Checking reqwest v0.11.27 [INFO] [stderr] Checking safecoin-metrics v1.14.17 [INFO] [stderr] Checking safecoin-measure v1.14.17 [INFO] [stdout] warning: unexpected `cfg` condition name: `RUSTC_WITH_SPECIALIZATION` [INFO] [stdout] --> src/lib.rs:1:13 [INFO] [stdout] | [INFO] [stdout] 1 | #![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: expected names are: `docsrs`, `feature`, and `test` and 31 more [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(RUSTC_WITH_SPECIALIZATION)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(RUSTC_WITH_SPECIALIZATION)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: `#[warn(unexpected_cfgs)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:23:21 [INFO] [stdout] | [INFO] [stdout] 23 | /// the signer for withdrawals [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 24 | authorized_withdrawer: state.authorized_withdrawer, [INFO] [stdout] | -------------------------------------------------- rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] = note: `#[warn(unused_doc_comments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:26:21 [INFO] [stdout] | [INFO] [stdout] 26 | / /// percentage (0-100) that represents what part of a rewards [INFO] [stdout] 27 | | /// payout should be given to this VoteAccount [INFO] [stdout] | |___________________________________________________________________^ [INFO] [stdout] 28 | commission: state.commission, [INFO] [stdout] | ---------------------------- rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:34:21 [INFO] [stdout] | [INFO] [stdout] 34 | /// the signer for vote transactions [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 35 | authorized_voters, [INFO] [stdout] | ----------------- rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:37:21 [INFO] [stdout] | [INFO] [stdout] 37 | / /// history of prior authorized voters and the epochs for which [INFO] [stdout] 38 | | /// they were set, the bottom end of the range is inclusive, [INFO] [stdout] 39 | | /// the top of the range is exclusive [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] 40 | prior_voters: CircBuf::default(), [INFO] [stdout] | -------------------------------- rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:42:21 [INFO] [stdout] | [INFO] [stdout] 42 | / /// history of how many credits earned by the end of each epoch [INFO] [stdout] 43 | | /// each tuple is (Epoch, credits, prev_credits) [INFO] [stdout] | |_____________________________________________________________________^ [INFO] [stdout] 44 | epoch_credits: state.epoch_credits.clone(), [INFO] [stdout] | ------------------------------------------ rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:46:21 [INFO] [stdout] | [INFO] [stdout] 46 | /// most recent timestamp submitted with a vote [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 47 | last_timestamp: state.last_timestamp.clone(), [INFO] [stdout] | -------------------------------------------- rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unexpected `cfg` condition name: `RUSTC_WITH_SPECIALIZATION` [INFO] [stdout] --> src/lib.rs:1:13 [INFO] [stdout] | [INFO] [stdout] 1 | #![cfg_attr(RUSTC_WITH_SPECIALIZATION, feature(min_specialization))] [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: expected names are: `docsrs`, `feature`, and `test` and 31 more [INFO] [stdout] = help: consider using a Cargo feature instead [INFO] [stdout] = help: or consider adding in `Cargo.toml` the `check-cfg` lint config for the lint: [INFO] [stdout] [lints.rust] [INFO] [stdout] unexpected_cfgs = { level = "warn", check-cfg = ['cfg(RUSTC_WITH_SPECIALIZATION)'] } [INFO] [stdout] = help: or consider adding `println!("cargo::rustc-check-cfg=cfg(RUSTC_WITH_SPECIALIZATION)");` to the top of the `build.rs` [INFO] [stdout] = note: see for more information about checking conditional configuration [INFO] [stdout] = note: `#[warn(unexpected_cfgs)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:23:21 [INFO] [stdout] | [INFO] [stdout] 23 | /// the signer for withdrawals [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 24 | authorized_withdrawer: state.authorized_withdrawer, [INFO] [stdout] | -------------------------------------------------- rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] = note: `#[warn(unused_doc_comments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:26:21 [INFO] [stdout] | [INFO] [stdout] 26 | / /// percentage (0-100) that represents what part of a rewards [INFO] [stdout] 27 | | /// payout should be given to this VoteAccount [INFO] [stdout] | |___________________________________________________________________^ [INFO] [stdout] 28 | commission: state.commission, [INFO] [stdout] | ---------------------------- rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:34:21 [INFO] [stdout] | [INFO] [stdout] 34 | /// the signer for vote transactions [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 35 | authorized_voters, [INFO] [stdout] | ----------------- rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:37:21 [INFO] [stdout] | [INFO] [stdout] 37 | / /// history of prior authorized voters and the epochs for which [INFO] [stdout] 38 | | /// they were set, the bottom end of the range is inclusive, [INFO] [stdout] 39 | | /// the top of the range is exclusive [INFO] [stdout] | |_________________________________________________________^ [INFO] [stdout] 40 | prior_voters: CircBuf::default(), [INFO] [stdout] | -------------------------------- rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:42:21 [INFO] [stdout] | [INFO] [stdout] 42 | / /// history of how many credits earned by the end of each epoch [INFO] [stdout] 43 | | /// each tuple is (Epoch, credits, prev_credits) [INFO] [stdout] | |_____________________________________________________________________^ [INFO] [stdout] 44 | epoch_credits: state.epoch_credits.clone(), [INFO] [stdout] | ------------------------------------------ rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused doc comment [INFO] [stdout] --> src/vote_state/vote_state_versions.rs:46:21 [INFO] [stdout] | [INFO] [stdout] 46 | /// most recent timestamp submitted with a vote [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 47 | last_timestamp: state.last_timestamp.clone(), [INFO] [stdout] | -------------------------------------------- rustdoc does not generate documentation for expression fields [INFO] [stdout] | [INFO] [stdout] = help: use `//` for a plain comment [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/vote_state/mod.rs:1593:5 [INFO] [stdout] | [INFO] [stdout] 1593 | let mut slot_hash_int = ( (slot_hashes[0].1.to_string().chars().nth(0).unwrap() as usize ) % 10 ) as usize; [INFO] [stdout] | ----^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/vote_state/mod.rs:1594:5 [INFO] [stdout] | [INFO] [stdout] 1594 | let mut mixed_int = ( ( ( (slot_hashes[0].1.to_string().chars().nth(0).unwrap() as usize ) % 9 + 1 ) as usize [INFO] [stdout] | ----^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/authorized_voters.rs:81:17 [INFO] [stdout] | [INFO] [stdout] 81 | pub fn iter(&self) -> std::collections::btree_map::Iter { [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] 81 | pub fn iter(&self) -> std::collections::btree_map::Iter<'_, Epoch, Pubkey> { [INFO] [stdout] | +++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item [INFO] [stdout] --> src/vote_error.rs:11:46 [INFO] [stdout] | [INFO] [stdout] 11 | #[derive(Error, Debug, Clone, PartialEq, Eq, FromPrimitive, ToPrimitive)] [INFO] [stdout] | ^------------ [INFO] [stdout] | | [INFO] [stdout] | `FromPrimitive` is not local [INFO] [stdout] | move the `impl` block outside of this constant `_IMPL_NUM_FromPrimitive_FOR_VoteError` [INFO] [stdout] 12 | pub enum VoteError { [INFO] [stdout] | --------- `VoteError` is not local [INFO] [stdout] | [INFO] [stdout] = note: the derive macro `FromPrimitive` defines the non-local `impl`, and may need to be changed [INFO] [stdout] = note: the derive macro `FromPrimitive` may come from an old version of the `num_derive` crate, try updating your dependency with `cargo update -p num_derive` [INFO] [stdout] = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl` [INFO] [stdout] = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint [INFO] [stdout] = note: `#[warn(non_local_definitions)]` on by default [INFO] [stdout] = note: this warning originates in the derive macro `FromPrimitive` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item [INFO] [stdout] --> src/vote_error.rs:11:61 [INFO] [stdout] | [INFO] [stdout] 11 | #[derive(Error, Debug, Clone, PartialEq, Eq, FromPrimitive, ToPrimitive)] [INFO] [stdout] | ^---------- [INFO] [stdout] | | [INFO] [stdout] | `ToPrimitive` is not local [INFO] [stdout] | move the `impl` block outside of this constant `_IMPL_NUM_ToPrimitive_FOR_VoteError` [INFO] [stdout] 12 | pub enum VoteError { [INFO] [stdout] | --------- `VoteError` is not local [INFO] [stdout] | [INFO] [stdout] = note: the derive macro `ToPrimitive` defines the non-local `impl`, and may need to be changed [INFO] [stdout] = note: the derive macro `ToPrimitive` may come from an old version of the `num_derive` crate, try updating your dependency with `cargo update -p num_derive` [INFO] [stdout] = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl` [INFO] [stdout] = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint [INFO] [stdout] = note: this warning originates in the derive macro `ToPrimitive` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/vote_state/mod.rs:1593:5 [INFO] [stdout] | [INFO] [stdout] 1593 | let mut slot_hash_int = ( (slot_hashes[0].1.to_string().chars().nth(0).unwrap() as usize ) % 10 ) as usize; [INFO] [stdout] | ----^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/vote_state/mod.rs:1594:5 [INFO] [stdout] | [INFO] [stdout] 1594 | let mut mixed_int = ( ( ( (slot_hashes[0].1.to_string().chars().nth(0).unwrap() as usize ) % 9 + 1 ) as usize [INFO] [stdout] | ----^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing [INFO] [stdout] --> src/authorized_voters.rs:81:17 [INFO] [stdout] | [INFO] [stdout] 81 | pub fn iter(&self) -> std::collections::btree_map::Iter { [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] 81 | pub fn iter(&self) -> std::collections::btree_map::Iter<'_, Epoch, Pubkey> { [INFO] [stdout] | +++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item [INFO] [stdout] --> src/vote_error.rs:11:46 [INFO] [stdout] | [INFO] [stdout] 11 | #[derive(Error, Debug, Clone, PartialEq, Eq, FromPrimitive, ToPrimitive)] [INFO] [stdout] | ^------------ [INFO] [stdout] | | [INFO] [stdout] | `FromPrimitive` is not local [INFO] [stdout] | move the `impl` block outside of this constant `_IMPL_NUM_FromPrimitive_FOR_VoteError` [INFO] [stdout] 12 | pub enum VoteError { [INFO] [stdout] | --------- `VoteError` is not local [INFO] [stdout] | [INFO] [stdout] = note: the derive macro `FromPrimitive` defines the non-local `impl`, and may need to be changed [INFO] [stdout] = note: the derive macro `FromPrimitive` may come from an old version of the `num_derive` crate, try updating your dependency with `cargo update -p num_derive` [INFO] [stdout] = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl` [INFO] [stdout] = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint [INFO] [stdout] = note: `#[warn(non_local_definitions)]` on by default [INFO] [stdout] = note: this warning originates in the derive macro `FromPrimitive` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item [INFO] [stdout] --> src/vote_error.rs:11:61 [INFO] [stdout] | [INFO] [stdout] 11 | #[derive(Error, Debug, Clone, PartialEq, Eq, FromPrimitive, ToPrimitive)] [INFO] [stdout] | ^---------- [INFO] [stdout] | | [INFO] [stdout] | `ToPrimitive` is not local [INFO] [stdout] | move the `impl` block outside of this constant `_IMPL_NUM_ToPrimitive_FOR_VoteError` [INFO] [stdout] 12 | pub enum VoteError { [INFO] [stdout] | --------- `VoteError` is not local [INFO] [stdout] | [INFO] [stdout] = note: the derive macro `ToPrimitive` defines the non-local `impl`, and may need to be changed [INFO] [stdout] = note: the derive macro `ToPrimitive` may come from an old version of the `num_derive` crate, try updating your dependency with `cargo update -p num_derive` [INFO] [stdout] = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl` [INFO] [stdout] = note: items in an anonymous const item (`const _: () = { ... }`) are treated as in the same scope as the anonymous const's declaration for the purpose of this lint [INFO] [stdout] = note: this warning originates in the derive macro `ToPrimitive` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 29.93s [INFO] running `Command { std: "docker" "inspect" "fc2d0fa6ca7ea2723c7cee274abf044a689c2376c41d19b853be094f57f3a319", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "fc2d0fa6ca7ea2723c7cee274abf044a689c2376c41d19b853be094f57f3a319", kill_on_drop: false }` [INFO] [stdout] fc2d0fa6ca7ea2723c7cee274abf044a689c2376c41d19b853be094f57f3a319