[INFO] fetching crate etcommon-trie-test 0.3.12...
[INFO] testing etcommon-trie-test-0.3.12 against beta-2025-09-21 for beta-1.91-3
[INFO] extracting crate etcommon-trie-test 0.3.12 into /workspace/builds/worker-5-tc2/source
[INFO] started tweaking crates.io crate etcommon-trie-test 0.3.12
[INFO] finished tweaking crates.io crate etcommon-trie-test 0.3.12
[INFO] tweaked toml for crates.io crate etcommon-trie-test 0.3.12 written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate etcommon-trie-test 0.3.12 on toolchain beta-2025-09-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "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" "+beta-2025-09-21" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 23 packages to latest compatible versions
[INFO] [stderr]       Adding sha3 v0.6.0 (available: v0.10.8)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] e94a4539d351396a183d159e337986c08fdbf63aa963b043ca97722d4c395a4a
[INFO] running `Command { std: "docker" "start" "-a" "e94a4539d351396a183d159e337986c08fdbf63aa963b043ca97722d4c395a4a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "e94a4539d351396a183d159e337986c08fdbf63aa963b043ca97722d4c395a4a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e94a4539d351396a183d159e337986c08fdbf63aa963b043ca97722d4c395a4a", kill_on_drop: false }`
[INFO] [stdout] e94a4539d351396a183d159e337986c08fdbf63aa963b043ca97722d4c395a4a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a7603d0fcc59fe23f9af082a5004a09505ec9f7e6921f9487bbfe497a5bbb0c4
[INFO] running `Command { std: "docker" "start" "-a" "a7603d0fcc59fe23f9af082a5004a09505ec9f7e6921f9487bbfe497a5bbb0c4", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]    Compiling nodrop v0.1.14
[INFO] [stderr]    Compiling rand v0.4.6
[INFO] [stderr]    Compiling etcommon-hexutil v0.2.4
[INFO] [stderr]    Compiling elastic-array-plus v0.10.0
[INFO] [stderr]    Compiling byte-tools v0.2.0
[INFO] [stderr]    Compiling generic-array v0.8.4
[INFO] [stderr]    Compiling block-buffer v0.2.0
[INFO] [stderr]    Compiling digest v0.6.1
[INFO] [stderr]    Compiling sha3 v0.6.0
[INFO] [stderr]    Compiling rand v0.3.23
[INFO] [stderr]    Compiling etcommon-rlp v0.2.5
[INFO] [stderr]    Compiling etcommon-bigint v0.2.10
[INFO] [stderr]    Compiling etcommon-trie-test v0.3.12 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `DerefMut` and `Deref`
[INFO] [stdout]   --> src/lib.rs:12:16
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::ops::{Deref, DerefMut};
[INFO] [stdout]    |                ^^^^^  ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Decodable`, `Encodable`, and `Prototype`
[INFO] [stdout]  --> src/merkle/nibble.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use rlp::{RlpStream, Encodable, Decodable, Rlp, Prototype};
[INFO] [stdout]   |                      ^^^^^^^^^  ^^^^^^^^^       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Deref`
[INFO] [stdout]  --> src/merkle/nibble.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ops::Deref;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Formatter` and `self`
[INFO] [stdout]  --> src/merkle/nibble.rs:5:16
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::fmt::{self, Debug, Formatter};
[INFO] [stdout]   |                ^^^^         ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NibbleSlice` and `Nibble`
[INFO] [stdout]  --> src/merkle/node.rs:1:27
[INFO] [stdout]   |
[INFO] [stdout] 1 | use super::nibble::{self, Nibble, NibbleVec, NibbleSlice, NibbleType};
[INFO] [stdout]   |                           ^^^^^^             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NibbleSlice`, `NibbleType`, `NibbleVec`, and `Nibble`
[INFO] [stdout]  --> src/merkle/mod.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use self::nibble::{Nibble, NibbleVec, NibbleSlice, NibbleType};
[INFO] [stdout]   |                    ^^^^^^  ^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `::Trie`
[INFO] [stdout]  --> src/database/memory.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use ::Trie;
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DatabaseOwned`
[INFO] [stdout]  --> src/database/memory.rs:2:23
[INFO] [stdout]   |
[INFO] [stdout] 2 | use super::{Database, DatabaseOwned, DatabaseGuard};
[INFO] [stdout]   |                       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hasher`
[INFO] [stdout]  --> src/merkle/nibble.rs:4:23
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::hash::{Hash, Hasher};
[INFO] [stdout]   |                       ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Decodable`
[INFO] [stdout]  --> src/merkle/node.rs:3:39
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rlp::{self, RlpStream, Encodable, Decodable, Rlp, Prototype};
[INFO] [stdout]   |                                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `value`
[INFO] [stdout]    --> src/lib.rs:283:74
[INFO] [stdout]     |
[INFO] [stdout] 283 |             let submap = Self::build_submap(1, map.iter().filter(|&(key, value)| {
[INFO] [stdout]     |                                                                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_value`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `value`
[INFO] [stdout]    --> src/lib.rs:296:29
[INFO] [stdout]     |
[INFO] [stdout] 296 |             .filter(|&(key, value)| key.len() == 0).next()
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_value`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `key`
[INFO] [stdout]    --> src/lib.rs:297:20
[INFO] [stdout]     |
[INFO] [stdout] 297 |             .map(|(key, value)| value.clone());
[INFO] [stdout]     |                    ^^^ help: if this is intentional, prefix it with an underscore: `_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sub_nodes`
[INFO] [stdout]    --> src/lib.rs:632:44
[INFO] [stdout]     |
[INFO] [stdout] 632 |                         MerkleNode::Branch(sub_nodes, sub_additional) => {
[INFO] [stdout]     |                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_nodes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sub_additional`
[INFO] [stdout]    --> src/lib.rs:632:55
[INFO] [stdout]     |
[INFO] [stdout] 632 |                         MerkleNode::Branch(sub_nodes, sub_additional) => {
[INFO] [stdout]     |                                                       ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_additional`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `free` is never used
[INFO] [stdout]   --> src/database/mod.rs:96:12
[INFO] [stdout]    |
[INFO] [stdout] 68 | impl<'a, D: DatabaseGuard> Change<'a, D> {
[INFO] [stdout]    | ---------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub fn free<'b>(&'b mut self, hash: H256) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `freed` is never read
[INFO] [stdout]    --> src/database/mod.rs:123:5
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub struct ChangeSet {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 123 |     freed: Vec<H256>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/lib.rs:89:17
[INFO] [stdout]    |
[INFO] [stdout] 89 |     pub fn iter(&self) -> FixedMerkleIterator<D, K, V> {
[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] 89 |     pub fn iter(&self) -> FixedMerkleIterator<'_, D, K, V> {
[INFO] [stdout]    |                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:190:17
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter(&self) -> MerkleIterator<D> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter(&self) -> MerkleIterator<'_, D> {
[INFO] [stdout]     |                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:251:67
[INFO] [stdout]     |
[INFO] [stdout] 251 |             submap.insert(key.split_at(common_len).1.into(), value.clone());
[INFO] [stdout]     |                                                                   ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(suspicious_double_ref_op)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:263:71
[INFO] [stdout]     |
[INFO] [stdout] 263 |             return MerkleNode::Leaf(key.clone(), map.get(key).unwrap().clone());
[INFO] [stdout]     |                                                                       ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:297:38
[INFO] [stdout]     |
[INFO] [stdout] 297 |             .map(|(key, value)| value.clone());
[INFO] [stdout]     |                                      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:433:64
[INFO] [stdout]     |
[INFO] [stdout] 433 |                 node_map.insert(node_nibble.clone(), node_value.clone());
[INFO] [stdout]     |                                                                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/lib.rs:503:61
[INFO] [stdout]     |
[INFO] [stdout] 503 |                 node_map.insert(nibble::from_key(key), value.clone());
[INFO] [stdout]     |                                                             ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `[u8]` does not implement `Clone`, so calling `clone` on `&[u8]` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:651:74
[INFO] [stdout]     |
[INFO] [stdout] 651 |                     Some(MerkleNode::Leaf(node_nibble.clone(), node_value.clone()))
[INFO] [stdout]     |                                                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]   --> src/merkle/node.rs:60:55
[INFO] [stdout]    |
[INFO] [stdout] 60 |                 MerkleNode::Leaf(nibble.clone(), value.clone())
[INFO] [stdout]    |                                                       ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 3.49s
[INFO] running `Command { std: "docker" "inspect" "a7603d0fcc59fe23f9af082a5004a09505ec9f7e6921f9487bbfe497a5bbb0c4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a7603d0fcc59fe23f9af082a5004a09505ec9f7e6921f9487bbfe497a5bbb0c4", kill_on_drop: false }`
[INFO] [stdout] a7603d0fcc59fe23f9af082a5004a09505ec9f7e6921f9487bbfe497a5bbb0c4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0f782f283e6ac4ba24cf72feafd4f0cbf85dc8c194b524475fc06acda2ee0a25
[INFO] running `Command { std: "docker" "start" "-a" "0f782f283e6ac4ba24cf72feafd4f0cbf85dc8c194b524475fc06acda2ee0a25", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stdout] warning: unused imports: `DerefMut` and `Deref`
[INFO] [stdout]   --> src/lib.rs:12:16
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::ops::{Deref, DerefMut};
[INFO] [stdout]    |                ^^^^^  ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Decodable`, `Encodable`, and `Prototype`
[INFO] [stdout]  --> src/merkle/nibble.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use rlp::{RlpStream, Encodable, Decodable, Rlp, Prototype};
[INFO] [stdout]   |                      ^^^^^^^^^  ^^^^^^^^^       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Deref`
[INFO] [stdout]  --> src/merkle/nibble.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ops::Deref;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Formatter` and `self`
[INFO] [stdout]  --> src/merkle/nibble.rs:5:16
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::fmt::{self, Debug, Formatter};
[INFO] [stdout]   |                ^^^^         ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NibbleSlice` and `Nibble`
[INFO] [stdout]  --> src/merkle/node.rs:1:27
[INFO] [stdout]   |
[INFO] [stdout] 1 | use super::nibble::{self, Nibble, NibbleVec, NibbleSlice, NibbleType};
[INFO] [stdout]   |                           ^^^^^^             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NibbleSlice`, `NibbleType`, `NibbleVec`, and `Nibble`
[INFO] [stdout]  --> src/merkle/mod.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use self::nibble::{Nibble, NibbleVec, NibbleSlice, NibbleType};
[INFO] [stdout]   |                    ^^^^^^  ^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `::Trie`
[INFO] [stdout]  --> src/database/memory.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use ::Trie;
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DatabaseOwned`
[INFO] [stdout]  --> src/database/memory.rs:2:23
[INFO] [stdout]   |
[INFO] [stdout] 2 | use super::{Database, DatabaseOwned, DatabaseGuard};
[INFO] [stdout]   |                       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hasher`
[INFO] [stdout]  --> src/merkle/nibble.rs:4:23
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::hash::{Hash, Hasher};
[INFO] [stdout]   |                       ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Decodable`
[INFO] [stdout]  --> src/merkle/node.rs:3:39
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rlp::{self, RlpStream, Encodable, Decodable, Rlp, Prototype};
[INFO] [stdout]   |                                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `value`
[INFO] [stdout]    --> src/lib.rs:283:74
[INFO] [stdout]     |
[INFO] [stdout] 283 |             let submap = Self::build_submap(1, map.iter().filter(|&(key, value)| {
[INFO] [stdout]     |                                                                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_value`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `value`
[INFO] [stdout]    --> src/lib.rs:296:29
[INFO] [stdout]     |
[INFO] [stdout] 296 |             .filter(|&(key, value)| key.len() == 0).next()
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_value`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `key`
[INFO] [stdout]    --> src/lib.rs:297:20
[INFO] [stdout]     |
[INFO] [stdout] 297 |             .map(|(key, value)| value.clone());
[INFO] [stdout]     |                    ^^^ help: if this is intentional, prefix it with an underscore: `_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sub_nodes`
[INFO] [stdout]    --> src/lib.rs:632:44
[INFO] [stdout]     |
[INFO] [stdout] 632 |                         MerkleNode::Branch(sub_nodes, sub_additional) => {
[INFO] [stdout]     |                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_nodes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sub_additional`
[INFO] [stdout]    --> src/lib.rs:632:55
[INFO] [stdout]     |
[INFO] [stdout] 632 |                         MerkleNode::Branch(sub_nodes, sub_additional) => {
[INFO] [stdout]     |                                                       ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_additional`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `free` is never used
[INFO] [stdout]   --> src/database/mod.rs:96:12
[INFO] [stdout]    |
[INFO] [stdout] 68 | impl<'a, D: DatabaseGuard> Change<'a, D> {
[INFO] [stdout]    | ---------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub fn free<'b>(&'b mut self, hash: H256) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `freed` is never read
[INFO] [stdout]    --> src/database/mod.rs:123:5
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub struct ChangeSet {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 123 |     freed: Vec<H256>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/lib.rs:89:17
[INFO] [stdout]    |
[INFO] [stdout] 89 |     pub fn iter(&self) -> FixedMerkleIterator<D, K, V> {
[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] 89 |     pub fn iter(&self) -> FixedMerkleIterator<'_, D, K, V> {
[INFO] [stdout]    |                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:190:17
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter(&self) -> MerkleIterator<D> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter(&self) -> MerkleIterator<'_, D> {
[INFO] [stdout]     |                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:251:67
[INFO] [stdout]     |
[INFO] [stdout] 251 |             submap.insert(key.split_at(common_len).1.into(), value.clone());
[INFO] [stdout]     |                                                                   ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(suspicious_double_ref_op)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:263:71
[INFO] [stdout]     |
[INFO] [stdout] 263 |             return MerkleNode::Leaf(key.clone(), map.get(key).unwrap().clone());
[INFO] [stdout]     |                                                                       ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:297:38
[INFO] [stdout]     |
[INFO] [stdout] 297 |             .map(|(key, value)| value.clone());
[INFO] [stdout]     |                                      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:433:64
[INFO] [stdout]     |
[INFO] [stdout] 433 |                 node_map.insert(node_nibble.clone(), node_value.clone());
[INFO] [stdout]     |                                                                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/lib.rs:503:61
[INFO] [stdout]     |
[INFO] [stdout] 503 |                 node_map.insert(nibble::from_key(key), value.clone());
[INFO] [stdout]     |                                                             ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `[u8]` does not implement `Clone`, so calling `clone` on `&[u8]` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:651:74
[INFO] [stdout]     |
[INFO] [stdout] 651 |                     Some(MerkleNode::Leaf(node_nibble.clone(), node_value.clone()))
[INFO] [stdout]     |                                                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]   --> src/merkle/node.rs:60:55
[INFO] [stdout]    |
[INFO] [stdout] 60 |                 MerkleNode::Leaf(nibble.clone(), value.clone())
[INFO] [stdout]    |                                                       ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling etcommon-trie-test v0.3.12 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `DerefMut` and `Deref`
[INFO] [stdout]   --> src/lib.rs:12:16
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::ops::{Deref, DerefMut};
[INFO] [stdout]    |                ^^^^^  ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Decodable`, `Encodable`, and `Prototype`
[INFO] [stdout]  --> src/merkle/nibble.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use rlp::{RlpStream, Encodable, Decodable, Rlp, Prototype};
[INFO] [stdout]   |                      ^^^^^^^^^  ^^^^^^^^^       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Deref`
[INFO] [stdout]  --> src/merkle/nibble.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ops::Deref;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Formatter` and `self`
[INFO] [stdout]  --> src/merkle/nibble.rs:5:16
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::fmt::{self, Debug, Formatter};
[INFO] [stdout]   |                ^^^^         ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NibbleSlice` and `Nibble`
[INFO] [stdout]  --> src/merkle/node.rs:1:27
[INFO] [stdout]   |
[INFO] [stdout] 1 | use super::nibble::{self, Nibble, NibbleVec, NibbleSlice, NibbleType};
[INFO] [stdout]   |                           ^^^^^^             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Keccak256`
[INFO] [stdout]    --> src/merkle/node.rs:157:24
[INFO] [stdout]     |
[INFO] [stdout] 157 |     use sha3::{Digest, Keccak256};
[INFO] [stdout]     |                        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NibbleSlice`, `NibbleVec`, and `Nibble`
[INFO] [stdout]    --> src/merkle/node.rs:158:32
[INFO] [stdout]     |
[INFO] [stdout] 158 |     use merkle::nibble::{self, NibbleVec, NibbleSlice, Nibble};
[INFO] [stdout]     |                                ^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `NibbleSlice`, `NibbleType`, `NibbleVec`, and `Nibble`
[INFO] [stdout]  --> src/merkle/mod.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use self::nibble::{Nibble, NibbleVec, NibbleSlice, NibbleType};
[INFO] [stdout]   |                    ^^^^^^  ^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `::Trie`
[INFO] [stdout]  --> src/database/memory.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use ::Trie;
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DatabaseOwned`
[INFO] [stdout]  --> src/database/memory.rs:2:23
[INFO] [stdout]   |
[INFO] [stdout] 2 | use super::{Database, DatabaseOwned, DatabaseGuard};
[INFO] [stdout]   |                       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cell::UnsafeCell`
[INFO] [stdout]    --> src/lib.rs:726:9
[INFO] [stdout]     |
[INFO] [stdout] 726 |     use std::cell::UnsafeCell;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Hasher`
[INFO] [stdout]  --> src/merkle/nibble.rs:4:23
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::hash::{Hash, Hasher};
[INFO] [stdout]   |                       ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Decodable`
[INFO] [stdout]  --> src/merkle/node.rs:3:39
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rlp::{self, RlpStream, Encodable, Decodable, Rlp, Prototype};
[INFO] [stdout]   |                                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Digest`
[INFO] [stdout]    --> src/merkle/node.rs:157:16
[INFO] [stdout]     |
[INFO] [stdout] 157 |     use sha3::{Digest, Keccak256};
[INFO] [stdout]     |                ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DatabaseGuard`
[INFO] [stdout]    --> src/lib.rs:723:17
[INFO] [stdout]     |
[INFO] [stdout] 723 |     use super::{DatabaseGuard, Trie};
[INFO] [stdout]     |                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `value`
[INFO] [stdout]    --> src/lib.rs:283:74
[INFO] [stdout]     |
[INFO] [stdout] 283 |             let submap = Self::build_submap(1, map.iter().filter(|&(key, value)| {
[INFO] [stdout]     |                                                                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_value`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `value`
[INFO] [stdout]    --> src/lib.rs:296:29
[INFO] [stdout]     |
[INFO] [stdout] 296 |             .filter(|&(key, value)| key.len() == 0).next()
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_value`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `key`
[INFO] [stdout]    --> src/lib.rs:297:20
[INFO] [stdout]     |
[INFO] [stdout] 297 |             .map(|(key, value)| value.clone());
[INFO] [stdout]     |                    ^^^ help: if this is intentional, prefix it with an underscore: `_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sub_nodes`
[INFO] [stdout]    --> src/lib.rs:632:44
[INFO] [stdout]     |
[INFO] [stdout] 632 |                         MerkleNode::Branch(sub_nodes, sub_additional) => {
[INFO] [stdout]     |                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_nodes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sub_additional`
[INFO] [stdout]    --> src/lib.rs:632:55
[INFO] [stdout]     |
[INFO] [stdout] 632 |                         MerkleNode::Branch(sub_nodes, sub_additional) => {
[INFO] [stdout]     |                                                       ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_additional`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:740:13
[INFO] [stdout]     |
[INFO] [stdout] 740 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[INFO] [stdout]     |             ----^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:756:13
[INFO] [stdout]     |
[INFO] [stdout] 756 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[INFO] [stdout]     |             ----^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:776:13
[INFO] [stdout]     |
[INFO] [stdout] 776 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[INFO] [stdout]     |             ----^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:801:13
[INFO] [stdout]     |
[INFO] [stdout] 801 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[INFO] [stdout]     |             ----^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:812:13
[INFO] [stdout]     |
[INFO] [stdout] 812 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[INFO] [stdout]     |             ----^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:825:13
[INFO] [stdout]     |
[INFO] [stdout] 825 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[INFO] [stdout]     |             ----^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:841:13
[INFO] [stdout]     |
[INFO] [stdout] 841 |         let mut map = HashMap::new();
[INFO] [stdout]     |             ----^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:843:13
[INFO] [stdout]     |
[INFO] [stdout] 843 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[INFO] [stdout]     |             ----^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:854:13
[INFO] [stdout]     |
[INFO] [stdout] 854 |         let mut map = HashMap::new();
[INFO] [stdout]     |             ----^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:856:13
[INFO] [stdout]     |
[INFO] [stdout] 856 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[INFO] [stdout]     |             ----^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:869:13
[INFO] [stdout]     |
[INFO] [stdout] 869 |         let mut map = HashMap::new();
[INFO] [stdout]     |             ----^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:871:13
[INFO] [stdout]     |
[INFO] [stdout] 871 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[INFO] [stdout]     |             ----^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lib.rs:872:13
[INFO] [stdout]     |
[INFO] [stdout] 872 |         let mut trie: Trie<HashMap<H256, Vec<u8>>> = Trie::build(database, &map);
[INFO] [stdout]     |             ----^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `free` is never used
[INFO] [stdout]   --> src/database/mod.rs:96:12
[INFO] [stdout]    |
[INFO] [stdout] 68 | impl<'a, D: DatabaseGuard> Change<'a, D> {
[INFO] [stdout]    | ---------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub fn free<'b>(&'b mut self, hash: H256) {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `freed` is never read
[INFO] [stdout]    --> src/database/mod.rs:123:5
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub struct ChangeSet {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 123 |     freed: Vec<H256>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/lib.rs:89:17
[INFO] [stdout]    |
[INFO] [stdout] 89 |     pub fn iter(&self) -> FixedMerkleIterator<D, K, V> {
[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] 89 |     pub fn iter(&self) -> FixedMerkleIterator<'_, D, K, V> {
[INFO] [stdout]    |                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lib.rs:190:17
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter(&self) -> MerkleIterator<D> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub fn iter(&self) -> MerkleIterator<'_, D> {
[INFO] [stdout]     |                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:251:67
[INFO] [stdout]     |
[INFO] [stdout] 251 |             submap.insert(key.split_at(common_len).1.into(), value.clone());
[INFO] [stdout]     |                                                                   ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(suspicious_double_ref_op)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:263:71
[INFO] [stdout]     |
[INFO] [stdout] 263 |             return MerkleNode::Leaf(key.clone(), map.get(key).unwrap().clone());
[INFO] [stdout]     |                                                                       ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:297:38
[INFO] [stdout]     |
[INFO] [stdout] 297 |             .map(|(key, value)| value.clone());
[INFO] [stdout]     |                                      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:433:64
[INFO] [stdout]     |
[INFO] [stdout] 433 |                 node_map.insert(node_nibble.clone(), node_value.clone());
[INFO] [stdout]     |                                                                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/lib.rs:503:61
[INFO] [stdout]     |
[INFO] [stdout] 503 |                 node_map.insert(nibble::from_key(key), value.clone());
[INFO] [stdout]     |                                                             ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `[u8]` does not implement `Clone`, so calling `clone` on `&[u8]` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]    --> src/lib.rs:651:74
[INFO] [stdout]     |
[INFO] [stdout] 651 |                     Some(MerkleNode::Leaf(node_nibble.clone(), node_value.clone()))
[INFO] [stdout]     |                                                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stdout]   --> src/merkle/node.rs:60:55
[INFO] [stdout]    |
[INFO] [stdout] 60 |                 MerkleNode::Leaf(nibble.clone(), value.clone())
[INFO] [stdout]    |                                                       ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.46s
[INFO] running `Command { std: "docker" "inspect" "0f782f283e6ac4ba24cf72feafd4f0cbf85dc8c194b524475fc06acda2ee0a25", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0f782f283e6ac4ba24cf72feafd4f0cbf85dc8c194b524475fc06acda2ee0a25", kill_on_drop: false }`
[INFO] [stdout] 0f782f283e6ac4ba24cf72feafd4f0cbf85dc8c194b524475fc06acda2ee0a25
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] b1f91e3670d90a1508e2802de0cc778dd3e85a0c4614a5117129d4a19f38bdd2
[INFO] running `Command { std: "docker" "start" "-a" "b1f91e3670d90a1508e2802de0cc778dd3e85a0c4614a5117129d4a19f38bdd2", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr] warning: unused imports: `DerefMut` and `Deref`
[INFO] [stderr]   --> src/lib.rs:12:16
[INFO] [stderr]    |
[INFO] [stderr] 12 | use std::ops::{Deref, DerefMut};
[INFO] [stderr]    |                ^^^^^  ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Decodable`, `Encodable`, and `Prototype`
[INFO] [stderr]  --> src/merkle/nibble.rs:1:22
[INFO] [stderr]   |
[INFO] [stderr] 1 | use rlp::{RlpStream, Encodable, Decodable, Rlp, Prototype};
[INFO] [stderr]   |                      ^^^^^^^^^  ^^^^^^^^^       ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::ops::Deref`
[INFO] [stderr]  --> src/merkle/nibble.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::ops::Deref;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Formatter` and `self`
[INFO] [stderr]  --> src/merkle/nibble.rs:5:16
[INFO] [stderr]   |
[INFO] [stderr] 5 | use std::fmt::{self, Debug, Formatter};
[INFO] [stderr]   |                ^^^^         ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `NibbleSlice` and `Nibble`
[INFO] [stderr]  --> src/merkle/node.rs:1:27
[INFO] [stderr]   |
[INFO] [stderr] 1 | use super::nibble::{self, Nibble, NibbleVec, NibbleSlice, NibbleType};
[INFO] [stderr]   |                           ^^^^^^             ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `NibbleSlice`, `NibbleType`, `NibbleVec`, and `Nibble`
[INFO] [stderr]  --> src/merkle/mod.rs:4:20
[INFO] [stderr]   |
[INFO] [stderr] 4 | use self::nibble::{Nibble, NibbleVec, NibbleSlice, NibbleType};
[INFO] [stderr]   |                    ^^^^^^  ^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `::Trie`
[INFO] [stderr]  --> src/database/memory.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use ::Trie;
[INFO] [stderr]   |     ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `DatabaseOwned`
[INFO] [stderr]  --> src/database/memory.rs:2:23
[INFO] [stderr]   |
[INFO] [stderr] 2 | use super::{Database, DatabaseOwned, DatabaseGuard};
[INFO] [stderr]   |                       ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Hasher`
[INFO] [stderr]  --> src/merkle/nibble.rs:4:23
[INFO] [stderr]   |
[INFO] [stderr] 4 | use std::hash::{Hash, Hasher};
[INFO] [stderr]   |                       ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Decodable`
[INFO] [stderr]  --> src/merkle/node.rs:3:39
[INFO] [stderr]   |
[INFO] [stderr] 3 | use rlp::{self, RlpStream, Encodable, Decodable, Rlp, Prototype};
[INFO] [stderr]   |                                       ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `value`
[INFO] [stderr]    --> src/lib.rs:283:74
[INFO] [stderr]     |
[INFO] [stderr] 283 |             let submap = Self::build_submap(1, map.iter().filter(|&(key, value)| {
[INFO] [stderr]     |                                                                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_value`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `value`
[INFO] [stderr]    --> src/lib.rs:296:29
[INFO] [stderr]     |
[INFO] [stderr] 296 |             .filter(|&(key, value)| key.len() == 0).next()
[INFO] [stderr]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_value`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `key`
[INFO] [stderr]    --> src/lib.rs:297:20
[INFO] [stderr]     |
[INFO] [stderr] 297 |             .map(|(key, value)| value.clone());
[INFO] [stderr]     |                    ^^^ help: if this is intentional, prefix it with an underscore: `_key`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `sub_nodes`
[INFO] [stderr]    --> src/lib.rs:632:44
[INFO] [stderr]     |
[INFO] [stderr] 632 |                         MerkleNode::Branch(sub_nodes, sub_additional) => {
[INFO] [stderr]     |                                            ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_nodes`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `sub_additional`
[INFO] [stderr]    --> src/lib.rs:632:55
[INFO] [stderr]     |
[INFO] [stderr] 632 |                         MerkleNode::Branch(sub_nodes, sub_additional) => {
[INFO] [stderr]     |                                                       ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sub_additional`
[INFO] [stderr] 
[INFO] [stderr] warning: method `free` is never used
[INFO] [stderr]   --> src/database/mod.rs:96:12
[INFO] [stderr]    |
[INFO] [stderr] 68 | impl<'a, D: DatabaseGuard> Change<'a, D> {
[INFO] [stderr]    | ---------------------------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 96 |     pub fn free<'b>(&'b mut self, hash: H256) {
[INFO] [stderr]    |            ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `freed` is never read
[INFO] [stderr]    --> src/database/mod.rs:123:5
[INFO] [stderr]     |
[INFO] [stderr] 119 | pub struct ChangeSet {
[INFO] [stderr]     |            --------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 123 |     freed: Vec<H256>,
[INFO] [stderr]     |     ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/lib.rs:89:17
[INFO] [stderr]    |
[INFO] [stderr] 89 |     pub fn iter(&self) -> FixedMerkleIterator<D, K, V> {
[INFO] [stderr]    |                 ^^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 89 |     pub fn iter(&self) -> FixedMerkleIterator<'_, D, K, V> {
[INFO] [stderr]    |                                               +++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/lib.rs:190:17
[INFO] [stderr]     |
[INFO] [stderr] 190 |     pub fn iter(&self) -> MerkleIterator<D> {
[INFO] [stderr]     |                 ^^^^^     ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 190 |     pub fn iter(&self) -> MerkleIterator<'_, D> {
[INFO] [stderr]     |                                          +++
[INFO] [stderr] 
[INFO] [stderr] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stderr]    --> src/lib.rs:251:67
[INFO] [stderr]     |
[INFO] [stderr] 251 |             submap.insert(key.split_at(common_len).1.into(), value.clone());
[INFO] [stderr]     |                                                                   ^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(suspicious_double_ref_op)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stderr]    --> src/lib.rs:263:71
[INFO] [stderr]     |
[INFO] [stderr] 263 |             return MerkleNode::Leaf(key.clone(), map.get(key).unwrap().clone());
[INFO] [stderr]     |                                                                       ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stderr]    --> src/lib.rs:297:38
[INFO] [stderr]     |
[INFO] [stderr] 297 |             .map(|(key, value)| value.clone());
[INFO] [stderr]     |                                      ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stderr]    --> src/lib.rs:433:64
[INFO] [stderr]     |
[INFO] [stderr] 433 |                 node_map.insert(node_nibble.clone(), node_value.clone());
[INFO] [stderr]     |                                                                ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stderr]    --> src/lib.rs:503:61
[INFO] [stderr]     |
[INFO] [stderr] 503 |                 node_map.insert(nibble::from_key(key), value.clone());
[INFO] [stderr]     |                                                             ^^^^^^^^ help: remove this redundant call
[INFO] [stderr]     |
[INFO] [stderr]     = note: the type `[u8]` does not implement `Clone`, so calling `clone` on `&[u8]` copies the reference, which does not do anything and can be removed
[INFO] [stderr]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stderr]    --> src/lib.rs:651:74
[INFO] [stderr]     |
[INFO] [stderr] 651 |                     Some(MerkleNode::Leaf(node_nibble.clone(), node_value.clone()))
[INFO] [stderr]     |                                                                          ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: using `.clone()` on a double reference, which returns `&[u8]` instead of cloning the inner type
[INFO] [stderr]   --> src/merkle/node.rs:60:55
[INFO] [stderr]    |
[INFO] [stderr] 60 |                 MerkleNode::Leaf(nibble.clone(), value.clone())
[INFO] [stderr]    |                                                       ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Keccak256`
[INFO] [stderr]    --> src/merkle/node.rs:157:24
[INFO] [stderr]     |
[INFO] [stderr] 157 |     use sha3::{Digest, Keccak256};
[INFO] [stderr]     |                        ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `NibbleSlice`, `NibbleVec`, and `Nibble`
[INFO] [stderr]    --> src/merkle/node.rs:158:32
[INFO] [stderr]     |
[INFO] [stderr] 158 |     use merkle::nibble::{self, NibbleVec, NibbleSlice, Nibble};
[INFO] [stderr]     |                                ^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::cell::UnsafeCell`
[INFO] [stderr]    --> src/lib.rs:726:9
[INFO] [stderr]     |
[INFO] [stderr] 726 |     use std::cell::UnsafeCell;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Digest`
[INFO] [stderr]    --> src/merkle/node.rs:157:16
[INFO] [stderr]     |
[INFO] [stderr] 157 |     use sha3::{Digest, Keccak256};
[INFO] [stderr]     |                ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `DatabaseGuard`
[INFO] [stderr]    --> src/lib.rs:723:17
[INFO] [stderr]     |
[INFO] [stderr] 723 |     use super::{DatabaseGuard, Trie};
[INFO] [stderr]     |                 ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/lib.rs:740:13
[INFO] [stderr]     |
[INFO] [stderr] 740 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[INFO] [stderr]     |             ----^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/lib.rs:756:13
[INFO] [stderr]     |
[INFO] [stderr] 756 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[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/lib.rs:776:13
[INFO] [stderr]     |
[INFO] [stderr] 776 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[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/lib.rs:801:13
[INFO] [stderr]     |
[INFO] [stderr] 801 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[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/lib.rs:812:13
[INFO] [stderr]     |
[INFO] [stderr] 812 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[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/lib.rs:825:13
[INFO] [stderr]     |
[INFO] [stderr] 825 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[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/lib.rs:841:13
[INFO] [stderr]     |
[INFO] [stderr] 841 |         let mut map = HashMap::new();
[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/lib.rs:843:13
[INFO] [stderr]     |
[INFO] [stderr] 843 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[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/lib.rs:854:13
[INFO] [stderr]     |
[INFO] [stderr] 854 |         let mut map = HashMap::new();
[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/lib.rs:856:13
[INFO] [stderr]     |
[INFO] [stderr] 856 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[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/lib.rs:869:13
[INFO] [stderr]     |
[INFO] [stderr] 869 |         let mut map = HashMap::new();
[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/lib.rs:871:13
[INFO] [stderr]     |
[INFO] [stderr] 871 |         let mut database: HashMap<H256, Vec<u8>> = HashMap::new();
[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/lib.rs:872:13
[INFO] [stderr]     |
[INFO] [stderr] 872 |         let mut trie: Trie<HashMap<H256, Vec<u8>>> = Trie::build(database, &map);
[INFO] [stderr]     |             ----^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: `etcommon-trie-test` (lib) generated 26 warnings (run `cargo fix --lib -p etcommon-trie-test` to apply 11 suggestions)
[INFO] [stderr] warning: `etcommon-trie-test` (lib test) generated 44 warnings (26 duplicates) (run `cargo fix --lib -p etcommon-trie-test --tests` to apply 16 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.09s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/trie_test-a4239a9df90ce2cc)
[INFO] [stdout] 
[INFO] [stdout] running 12 tests
[INFO] [stdout] test tests::insert_single_item ... ok
[INFO] [stdout] test merkle::node::tests::encode_decode ... ok
[INFO] [stdout] test tests::sub_genesis ... ok
[INFO] [stdout] test tests::insert_middle_leaf ... ok
[INFO] [stdout] test merkle::node::tests::decode_genesis_state ... ok
[INFO] [stdout] test tests::insert_animals ... ok
[INFO] [stdout] test merkle::nibble::tests::from_into_key ... ok
[INFO] [stdout] test tests::trie_empty ... ok
[INFO] [stdout] test tests::testy ... ok
[INFO] [stdout] test tests::trie_insert ... ok
[INFO] [stdout] test tests::trie_delete ... ok
[INFO] [stdout] test tests::trie_middle_leaf ... ok
[INFO] [stderr]    Doc-tests trie_test
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 12 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "b1f91e3670d90a1508e2802de0cc778dd3e85a0c4614a5117129d4a19f38bdd2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b1f91e3670d90a1508e2802de0cc778dd3e85a0c4614a5117129d4a19f38bdd2", kill_on_drop: false }`
[INFO] [stdout] b1f91e3670d90a1508e2802de0cc778dd3e85a0c4614a5117129d4a19f38bdd2
