[INFO] cloning repository https://github.com/vioWard95/blockchain-from-scratch
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/vioWard95/blockchain-from-scratch" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FvioWard95%2Fblockchain-from-scratch", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FvioWard95%2Fblockchain-from-scratch'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 749a5cb99f0866caa32f7c8e050ba6658bbfb595
[INFO] testing vioWard95/blockchain-from-scratch against 1.94.0 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FvioWard95%2Fblockchain-from-scratch" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/vioWard95/blockchain-from-scratch
[INFO] finished tweaking git repo https://github.com/vioWard95/blockchain-from-scratch
[INFO] tweaked toml for git repo https://github.com/vioWard95/blockchain-from-scratch written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/vioWard95/blockchain-from-scratch on toolchain 1.94.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.94.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/vioWard95/blockchain-from-scratch already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.94.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 99d4e7aa0da99f0abccca4297af4a7b5602f9a140ae52281b1f1e8417db05817
[INFO] running `Command { std: "docker" "start" "-a" "99d4e7aa0da99f0abccca4297af4a7b5602f9a140ae52281b1f1e8417db05817", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "99d4e7aa0da99f0abccca4297af4a7b5602f9a140ae52281b1f1e8417db05817", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "99d4e7aa0da99f0abccca4297af4a7b5602f9a140ae52281b1f1e8417db05817", kill_on_drop: false }`
[INFO] [stdout] 99d4e7aa0da99f0abccca4297af4a7b5602f9a140ae52281b1f1e8417db05817
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cf311ebe74d3b75d74ebead277da2adc54459e2719dd78a83841a37103c2de8b
[INFO] running `Command { std: "docker" "start" "-a" "cf311ebe74d3b75d74ebead277da2adc54459e2719dd78a83841a37103c2de8b", kill_on_drop: false }`
[INFO] [stderr]    Compiling diy-blockchain v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Block` and `Header`
[INFO] [stdout]  --> src/c2_blockchain/mod.rs:7:25
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use p6_rich_state::{Block, Header};
[INFO] [stdout]   |                         ^^^^^  ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]  --> src/c2_blockchain/p1_header_chain.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::hash;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::hash;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]  --> src/c2_blockchain/p3_consensus.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::hash;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]  --> src/c2_blockchain/p4_batched_extrinsics.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::hash;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::p3_consensus::THRESHOLD`
[INFO] [stdout]  --> src/c2_blockchain/p4_batched_extrinsics.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use super::p3_consensus::THRESHOLD;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use crate::hash;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::p3_consensus::THRESHOLD`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use super::p3_consensus::THRESHOLD;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::hash;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::p3_consensus::THRESHOLD`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use super::p3_consensus::THRESHOLD;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/c3_consensus/p4_even_only.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:46:1
[INFO] [stdout]    |
[INFO] [stdout] 46 | / fn change_authorities(
[INFO] [stdout] 47 | |     fork_height: u64,
[INFO] [stdout] 48 | |     initial_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout] 49 | |     final_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout] 50 | | ) -> impl Consensus {
[INFO] [stdout]    | |___________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:50:6
[INFO] [stdout]    |
[INFO] [stdout] 50 | ) -> impl Consensus {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(dependency_on_unit_never_type_fallback)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:55:1
[INFO] [stdout]    |
[INFO] [stdout] 55 | / fn change_difficulty(
[INFO] [stdout] 56 | |     fork_height: u64,
[INFO] [stdout] 57 | |     initial_difficulty: u64,
[INFO] [stdout] 58 | |     final_difficulty: u64,
[INFO] [stdout] 59 | | ) -> impl Consensus {
[INFO] [stdout]    | |___________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:59:6
[INFO] [stdout]    |
[INFO] [stdout] 59 | ) -> impl Consensus {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:1
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:70
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    |                                                                      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:80:1
[INFO] [stdout]    |
[INFO] [stdout] 80 | / fn pow_to_poa(
[INFO] [stdout] 81 | |     fork_height: u64,
[INFO] [stdout] 82 | |     difficulty: u64,
[INFO] [stdout] 83 | |     authorities: Vec<ConsensusAuthority>,
[INFO] [stdout] 84 | | ) -> impl Consensus {
[INFO] [stdout]    | |___________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:84:6
[INFO] [stdout]    |
[INFO] [stdout] 84 | ) -> impl Consensus {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:17:19
[INFO] [stdout]    |
[INFO] [stdout] 17 |     fn next_state(starting_state: &bool, t: &()) -> bool {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:17:42
[INFO] [stdout]    |
[INFO] [stdout] 17 |     fn next_state(starting_state: &bool, t: &()) -> bool {
[INFO] [stdout]    |                                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:44:19
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn next_state(starting_state: &TwoSwitches, t: &Toggle) -> TwoSwitches {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:44:49
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn next_state(starting_state: &TwoSwitches, t: &Toggle) -> TwoSwitches {
[INFO] [stdout]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p2_laundry_machine.rs:42:19
[INFO] [stdout]    |
[INFO] [stdout] 42 |     fn next_state(starting_state: &ClothesState, t: &ClothesAction) -> ClothesState {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p2_laundry_machine.rs:42:50
[INFO] [stdout]    |
[INFO] [stdout] 42 |     fn next_state(starting_state: &ClothesState, t: &ClothesAction) -> ClothesState {
[INFO] [stdout]    |                                                  ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:60:19
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:60:49
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:47:19
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn next_state(starting_state: &Balances, t: &AccountingTransaction) -> Balances {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:47:46
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn next_state(starting_state: &Balances, t: &AccountingTransaction) -> Balances {
[INFO] [stdout]    |                                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:96:19
[INFO] [stdout]    |
[INFO] [stdout] 96 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:96:49
[INFO] [stdout]    |
[INFO] [stdout] 96 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:40:32
[INFO] [stdout]    |
[INFO] [stdout] 40 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsic`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:38:21
[INFO] [stdout]    |
[INFO] [stdout] 38 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsic`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:50:32
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:58:22
[INFO] [stdout]    |
[INFO] [stdout] 58 | fn build_valid_chain(n: u64) -> Vec<Header> {
[INFO] [stdout]    |                      ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsic`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:44:21
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsic`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:52:32
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:64:37
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn verify_sub_chain_even(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                     ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:70:36
[INFO] [stdout]    |
[INFO] [stdout] 70 |     fn verify_sub_chain_odd(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics_root`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:42:25
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:42:48
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stdout]    |                                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `child`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:53:28
[INFO] [stdout]    |
[INFO] [stdout] 53 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stdout]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:64:32
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:89:25
[INFO] [stdout]    |
[INFO] [stdout] 89 |     pub fn child(&self, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:96:36
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn verify_sub_chain(&self, chain: &[Block]) -> bool {
[INFO] [stdout]    |                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent`
[INFO] [stdout]    --> src/c2_blockchain/p4_batched_extrinsics.rs:109:48
[INFO] [stdout]     |
[INFO] [stdout] 109 | fn build_invalid_child_block_with_valid_header(parent: &Header) -> Block {
[INFO] [stdout]     |                                                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:34:23
[INFO] [stdout]    |
[INFO] [stdout] 34 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_1`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:43:30
[INFO] [stdout]    |
[INFO] [stdout] 43 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_2`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:43:50
[INFO] [stdout]    |
[INFO] [stdout] 43 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:47:23
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:69:20
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stdout]    |                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `threshold`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:69:39
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stdout]    |                                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_threshold`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_1`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:74:30
[INFO] [stdout]    |
[INFO] [stdout] 74 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_2`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:74:50
[INFO] [stdout]    |
[INFO] [stdout] 74 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:78:23
[INFO] [stdout]    |
[INFO] [stdout] 78 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_1`
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:100:30
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]     |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_2`
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:100:50
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]     |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:104:23
[INFO] [stdout]     |
[INFO] [stdout] 104 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state_root`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:49:16
[INFO] [stdout]    |
[INFO] [stdout] 49 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics_root`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:57:21
[INFO] [stdout]    |
[INFO] [stdout] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state_root`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:57:44
[INFO] [stdout]    |
[INFO] [stdout] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stdout]    |                                            ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `child`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:62:28
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stdout]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:67:32
[INFO] [stdout]    |
[INFO] [stdout] 67 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:91:20
[INFO] [stdout]    |
[INFO] [stdout] 91 |     pub fn genesis(genesis_state: &State) -> Self {
[INFO] [stdout]    |                    ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:96:25
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:96:44
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |                                            ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:105:36
[INFO] [stdout]     |
[INFO] [stdout] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stdout]     |                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:105:55
[INFO] [stdout]     |
[INFO] [stdout] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stdout]     |                                                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:121:48
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stdout]     |                                                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:121:65
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stdout]     |                                                                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:21:42
[INFO] [stdout]    |
[INFO] [stdout] 21 |     fn validate(&self, _: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:27:38
[INFO] [stdout]    |
[INFO] [stdout] 27 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p2_dictator.rs:23:42
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn validate(&self, _: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p2_dictator.rs:28:38
[INFO] [stdout]    |
[INFO] [stdout] 28 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:22:24
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:22:54
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 28 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 29 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:45:24
[INFO] [stdout]    |
[INFO] [stdout] 45 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:45:54
[INFO] [stdout]    |
[INFO] [stdout] 45 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:51:9
[INFO] [stdout]    |
[INFO] [stdout] 51 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:52:9
[INFO] [stdout]    |
[INFO] [stdout] 52 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:82:24
[INFO] [stdout]    |
[INFO] [stdout] 82 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:82:54
[INFO] [stdout]    |
[INFO] [stdout] 82 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:88:9
[INFO] [stdout]    |
[INFO] [stdout] 88 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:89:9
[INFO] [stdout]    |
[INFO] [stdout] 89 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:19:24
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:19:54
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 25 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:52:24
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:52:54
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:58:9
[INFO] [stdout]    |
[INFO] [stdout] 58 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:59:9
[INFO] [stdout]    |
[INFO] [stdout] 59 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:31:24
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:31:54
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:38:9
[INFO] [stdout]    |
[INFO] [stdout] 38 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fork_height: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `initial_authorities`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     initial_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_initial_authorities`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `final_authorities`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:49:5
[INFO] [stdout]    |
[INFO] [stdout] 49 |     final_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_authorities`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:56:5
[INFO] [stdout]    |
[INFO] [stdout] 56 |     fork_height: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `initial_difficulty`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:57:5
[INFO] [stdout]    |
[INFO] [stdout] 57 |     initial_difficulty: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_initial_difficulty`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `final_difficulty`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:58:5
[INFO] [stdout]    |
[INFO] [stdout] 58 |     final_difficulty: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_difficulty`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:49
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    |                                                 ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:81:5
[INFO] [stdout]    |
[INFO] [stdout] 81 |     fork_height: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `difficulty`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 82 |     difficulty: u64,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_difficulty`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `authorities`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:83:5
[INFO] [stdout]    |
[INFO] [stdout] 83 |     authorities: Vec<ConsensusAuthority>,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_authorities`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/mod.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c3_consensus/mod.rs:77:9
[INFO] [stdout]    |
[INFO] [stdout] 77 |         chain: &[Header<Self::Digest>],
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]    --> src/c3_consensus/mod.rs:101:38
[INFO] [stdout]     |
[INFO] [stdout] 101 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state_root`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:26:16
[INFO] [stdout]    |
[INFO] [stdout] 26 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state_root`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:31:21
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics_root`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:31:39
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stdout]    |                                       ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `child`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:36:28
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn verify_child(&self, child: &Self) -> bool {
[INFO] [stdout]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:41:32
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn verify_sub_chain(&self, chain: &[Self]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:53:20
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn genesis(genesis_state: &SM::State) -> Self {
[INFO] [stdout]    |                    ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:58:25
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:58:48
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stdout]    |                                                ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:63:36
[INFO] [stdout]    |
[INFO] [stdout] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stdout]    |                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:63:59
[INFO] [stdout]    |
[INFO] [stdout] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stdout]    |                                                           ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     n: u64,
[INFO] [stdout]    |     ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:72:5
[INFO] [stdout]    |
[INFO] [stdout] 72 |     genesis_state: &SM::State,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:84:12
[INFO] [stdout]    |
[INFO] [stdout] 84 |     fn new(genesis_state: SM::State) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:41:25
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn get_block(&self, block_hash: u64) -> Option<Block<C, SM>> {
[INFO] [stdout]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:45:25
[INFO] [stdout]    |
[INFO] [stdout] 45 |     fn get_state(&self, block_hash: u64) -> Option<<SM as StateMachine>::State> {
[INFO] [stdout]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:49:23
[INFO] [stdout]    |
[INFO] [stdout] 49 |     fn is_leaf(&self, block_hash: u64) -> Option<bool> {
[INFO] [stdout]    |                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:32:26
[INFO] [stdout]    |
[INFO] [stdout] 32 |     fn best_block(&self, header: Header<C::Digest>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:36:31
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn import_hook(&mut self, header: Header<C::Digest>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:49:26
[INFO] [stdout]    |
[INFO] [stdout] 49 |     fn best_block(&self, header: Header<u64>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:53:31
[INFO] [stdout]    |
[INFO] [stdout] 53 |     fn import_hook(&mut self, header: Header<u64>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:66:26
[INFO] [stdout]    |
[INFO] [stdout] 66 |     fn best_block(&self, header: Header<ConsensusAuthority>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:70:31
[INFO] [stdout]    |
[INFO] [stdout] 70 |     fn import_hook(&mut self, header: Header<ConsensusAuthority>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:83:26
[INFO] [stdout]    |
[INFO] [stdout] 83 |     fn best_block(&self, header: Header<u64>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |     fn import_hook(&mut self, header: Header<u64>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:48:42
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub fn submit_transaction(&mut self, t: SM::Transition) {
[INFO] [stdout]    |                                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:59:33
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub fn pool_contains(&self, t: SM::Transition) -> bool {
[INFO] [stdout]    |                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:68:30
[INFO] [stdout]    |
[INFO] [stdout] 68 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]    |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:72:26
[INFO] [stdout]    |
[INFO] [stdout] 72 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stdout]    |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:80:24
[INFO] [stdout]    |
[INFO] [stdout] 80 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]    |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:110:30
[INFO] [stdout]     |
[INFO] [stdout] 110 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:114:26
[INFO] [stdout]     |
[INFO] [stdout] 114 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stdout]     |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:122:24
[INFO] [stdout]     |
[INFO] [stdout] 122 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:145:30
[INFO] [stdout]     |
[INFO] [stdout] 145 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:149:26
[INFO] [stdout]     |
[INFO] [stdout] 149 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stdout]     |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:157:24
[INFO] [stdout]     |
[INFO] [stdout] 157 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transactions`
[INFO] [stdout]   --> src/c4_client/p5_authoring_blocks.rs:13:54
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transactions`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_hash`
[INFO] [stdout]   --> src/c4_client/p5_authoring_blocks.rs:13:89
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stdout]    |                                                                                         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p6_finality.rs:13:47
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub fn manually_finalize_block(&mut self, block_hash: u64) -> bool {
[INFO] [stdout]    |                                               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hash` is never used
[INFO] [stdout]   --> src/lib.rs:10:4
[INFO] [stdout]    |
[INFO] [stdout] 10 | fn hash<T: Hash>(t: &T) -> u64 {
[INFO] [stdout]    |    ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `StateMachine` is never used
[INFO] [stdout]   --> src/c1_state_machine/mod.rs:12:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub trait StateMachine {
[INFO] [stdout]    |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `User` is never used
[INFO] [stdout]   --> src/c1_state_machine/mod.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub enum User {
[INFO] [stdout]    |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LightSwitch` is never constructed
[INFO] [stdout]  --> src/c1_state_machine/p1_switches.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct LightSwitch;
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WeirdSwitchMachine` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct WeirdSwitchMachine;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TwoSwitches` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct TwoSwitches {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Toggle` is never used
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:34:10
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub enum Toggle {
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ClothesMachine` is never constructed
[INFO] [stdout]  --> src/c1_state_machine/p2_laundry_machine.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ClothesMachine;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ClothesState` is never used
[INFO] [stdout]   --> src/c1_state_machine/p2_laundry_machine.rs:13:10
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub enum ClothesState {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ClothesAction` is never used
[INFO] [stdout]   --> src/c1_state_machine/p2_laundry_machine.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum ClothesAction {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Key` is never used
[INFO] [stdout]  --> src/c1_state_machine/p3_atm.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub enum Key {
[INFO] [stdout]   |          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Action` is never used
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:18:10
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub enum Action {
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Auth` is never used
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:28:6
[INFO] [stdout]    |
[INFO] [stdout] 28 | enum Auth {
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Atm` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct Atm {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountedCurrency` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct AccountedCurrency;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Balances` is never used
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:24:6
[INFO] [stdout]    |
[INFO] [stdout] 24 | type Balances = HashMap<User, u64>;
[INFO] [stdout]    |      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `AccountingTransaction` is never used
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum AccountingTransaction {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DigitalCashSystem` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct DigitalCashSystem;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Bill` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct Bill {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `State` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub struct State {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `set_serial`, `next_serial`, `increment_serial`, and `add_bill` are never used
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | impl State {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 34 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn set_serial(&mut self, serial: u64) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn next_serial(&self) -> u64 {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     fn increment_serial(&mut self) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     fn add_bill(&mut self, elem: Bill) {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CashTransaction` is never used
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:77:10
[INFO] [stdout]    |
[INFO] [stdout] 77 | pub enum CashTransaction {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `State` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p6_open_ended.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct State {}
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Transition` is never used
[INFO] [stdout]   --> src/c1_state_machine/p6_open_ended.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum Transition {}
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:10:6
[INFO] [stdout]    |
[INFO] [stdout] 10 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct Header {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl Header {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 26 |     /// Returns a new valid genesis header.
[INFO] [stdout] 27 |     fn genesis() -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |     fn child(&self) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_valid_chain_length_5` is never used
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:48:4
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn build_valid_chain_length_5() -> Vec<Header> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_an_invalid_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:55:4
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn build_an_invalid_chain() -> Vec<Header> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:14:6
[INFO] [stdout]    |
[INFO] [stdout] 14 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct Header {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:33:8
[INFO] [stdout]    |
[INFO] [stdout] 31 | impl Header {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 32 |     /// Returns a new valid genesis header.
[INFO] [stdout] 33 |     fn genesis() -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 50 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_valid_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:58:4
[INFO] [stdout]    |
[INFO] [stdout] 58 | fn build_valid_chain(n: u64) -> Vec<Header> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_an_invalid_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:72:4
[INFO] [stdout]    |
[INFO] [stdout] 72 | fn build_an_invalid_chain() -> Vec<Header> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_forked_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:87:4
[INFO] [stdout]    |
[INFO] [stdout] 87 | fn build_forked_chain() -> (Vec<Header>, Vec<Header>) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:11:6
[INFO] [stdout]    |
[INFO] [stdout] 11 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `THRESHOLD` is never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:16:11
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub const THRESHOLD: u64 = u64::max_value() / 100;
[INFO] [stdout]    |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORK_HEIGHT` is never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:20:7
[INFO] [stdout]    |
[INFO] [stdout] 20 | const FORK_HEIGHT: u64 = 2;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct Header {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, `verify_sub_chain`, `verify_sub_chain_even`, and `verify_sub_chain_odd` are never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 37 | impl Header {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 38 |     /// Returns a new valid genesis header.
[INFO] [stdout] 39 |     fn genesis() -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     fn verify_sub_chain_even(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 |     fn verify_sub_chain_odd(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_contentious_forked_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:91:4
[INFO] [stdout]    |
[INFO] [stdout] 91 | fn build_contentious_forked_chain() -> (Vec<Header>, Vec<Header>, Vec<Header>) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]  --> src/c2_blockchain/p4_batched_extrinsics.rs:6:6
[INFO] [stdout]   |
[INFO] [stdout] 6 | type Hash = u64;
[INFO] [stdout]   |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct Header {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, `verify_child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | impl Header {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 34 |     /// Returns a new valid genesis header.
[INFO] [stdout] 35 |     pub fn genesis() -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Block` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:71:12
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub struct Block {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:83:12
[INFO] [stdout]    |
[INFO] [stdout] 81 | impl Block {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 82 |     /// Returns a new valid genesis block. By convention this block has no extrinsics.
[INFO] [stdout] 83 |     pub fn genesis() -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 89 |     pub fn child(&self, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub fn verify_sub_chain(&self, chain: &[Block]) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_invalid_child_block_with_valid_header` is never used
[INFO] [stdout]    --> src/c2_blockchain/p4_batched_extrinsics.rs:109:4
[INFO] [stdout]     |
[INFO] [stdout] 109 | fn build_invalid_child_block_with_valid_header(parent: &Header) -> Block {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ForkChoice` is never used
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub trait ForkChoice {
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LongestChainRule` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:40:12
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub struct LongestChainRule;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HeaviestChainRule` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:63:12
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct HeaviestChainRule;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mine_extra_hard` is never used
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:69:4
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MostBlocksWithEvenHash` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:97:12
[INFO] [stdout]    |
[INFO] [stdout] 97 | pub struct MostBlocksWithEvenHash;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_fork_one_side_longer_other_side_heavier` is never used
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:132:4
[INFO] [stdout]     |
[INFO] [stdout] 132 | fn create_fork_one_side_longer_other_side_heavier() -> (Vec<Header>, Vec<Header>, Vec<Header>) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:14:6
[INFO] [stdout]    |
[INFO] [stdout] 14 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `State` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct State {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct Header {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, `verify_child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:49:8
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl Header {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 48 |     /// Returns a new valid genesis header.
[INFO] [stdout] 49 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 67 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Block` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:74:12
[INFO] [stdout]    |
[INFO] [stdout] 74 | pub struct Block {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:91:12
[INFO] [stdout]     |
[INFO] [stdout]  89 | impl Block {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout]  90 |     /// Returns a new valid genesis block. By convention this block has no extrinsics.
[INFO] [stdout]  91 |     pub fn genesis(genesis_state: &State) -> Self {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_invalid_child_block_with_valid_header` is never used
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:121:4
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c3_consensus/mod.rs:16:6
[INFO] [stdout]    |
[INFO] [stdout] 16 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c3_consensus/mod.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct Header<Digest> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Consensus` is never used
[INFO] [stdout]   --> src/c3_consensus/mod.rs:38:11
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub trait Consensus {
[INFO] [stdout]    |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Alice`, `Bob`, and `Charlie` are never constructed
[INFO] [stdout]    --> src/c3_consensus/mod.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 109 | pub enum ConsensusAuthority {
[INFO] [stdout]     |          ------------------ variants in this enum
[INFO] [stdout] 110 |     Alice,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 111 |     Bob,
[INFO] [stdout]     |     ^^^
[INFO] [stdout] 112 |     Charlie,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ConsensusAuthority` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Pow` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct Pow {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `moderate_difficulty_pow` is never used
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub fn moderate_difficulty_pow() -> Pow {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `trivial_always_valid_pow` is never used
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:40:8
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub fn trivial_always_valid_pow() -> Pow {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DictatorConsensus` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p2_dictator.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | struct DictatorConsensus {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SimplePoa` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct SimplePoa {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PoaRoundRobinByHeight` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:38:8
[INFO] [stdout]    |
[INFO] [stdout] 38 | struct PoaRoundRobinByHeight {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PoaRoundRobinBySlot` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:66:8
[INFO] [stdout]    |
[INFO] [stdout] 66 | struct PoaRoundRobinBySlot {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SlotDigest` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:74:8
[INFO] [stdout]    |
[INFO] [stdout] 74 | struct SlotDigest {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `EvenOnly` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | struct EvenOnly<Inner: Consensus> {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `almost_valid_but_not_all_even` is never used
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:35:4
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn almost_valid_but_not_all_even() -> Vec<Header<u64>> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AlternatingPowPoa` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | struct AlternatingPowPoa;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Pow` and `Poa` are never constructed
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | enum PowOrPoaDigest {
[INFO] [stdout]    |      -------------- variants in this enum
[INFO] [stdout] 17 |     Pow(u64),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 18 |     Poa(ConsensusAuthority),
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PowOrPoaDigest` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Forked` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | struct Forked<D, Before, After> {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `change_authorities` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:46:4
[INFO] [stdout]    |
[INFO] [stdout] 46 | fn change_authorities(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `change_difficulty` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:55:4
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn change_difficulty(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `even_after_given_height` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:4
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pow_to_poa` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:80:4
[INFO] [stdout]    |
[INFO] [stdout] 80 | fn pow_to_poa(
[INFO] [stdout]    |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c4_client/mod.rs:29:6
[INFO] [stdout]    |
[INFO] [stdout] 29 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FullClient` is never constructed
[INFO] [stdout]   --> src/c4_client/mod.rs:52:12
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub struct FullClient<C, SM, FC, P>
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:22:6
[INFO] [stdout]    |
[INFO] [stdout] 22 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, `verify_child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:26:8
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl<Digest> Header<Digest> {
[INFO] [stdout]    | --------------------------- associated items in this implementation
[INFO] [stdout] 25 |     /// Returns a new valid genesis header.
[INFO] [stdout] 26 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     fn verify_child(&self, child: &Self) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     fn verify_sub_chain(&self, chain: &[Self]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Block` is never constructed
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct Block<C: Consensus, SM: StateMachine> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:53:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | impl<C: Consensus, SM: StateMachine> Block<C, SM> {
[INFO] [stdout]    | ------------------------------------------------- associated items in this implementation
[INFO] [stdout] 52 |     /// Returns a new valid genesis block. By convention this block has no extrinsics.
[INFO] [stdout] 53 |     pub fn genesis(genesis_state: &SM::State) -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_empty_chain` is never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:70:4
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn create_empty_chain<C: Consensus, SM: StateMachine>(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:84:8
[INFO] [stdout]    |
[INFO] [stdout] 80 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>
[INFO] [stdout] 81 | | where
[INFO] [stdout] 82 | |     SM: StateMachine,
[INFO] [stdout]    | |_____________________- associated function in this implementation
[INFO] [stdout] 83 |   {
[INFO] [stdout] 84 |       fn new(genesis_state: SM::State) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ImportBlock` is never used
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub trait ImportBlock<C: Consensus, SM: StateMachine> {
[INFO] [stdout]    |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ForkChoice` is never used
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:18:11
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub trait ForkChoice<C: Consensus> {
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LongestChain` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct LongestChain {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HeaviestChain` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct HeaviestChain {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MostAliceSigs` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:61:12
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub struct MostAliceSigs {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ghost` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:78:12
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub struct Ghost {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `best_block` is never used
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:97:8
[INFO] [stdout]    |
[INFO] [stdout] 95 | impl<C, SM, FC, P> FullClient<C, SM, FC, P> {
[INFO] [stdout]    | ------------------------------------------- method in this implementation
[INFO] [stdout] 96 |     /// Return the hash of the best block currently known to the client
[INFO] [stdout] 97 |     fn best_block(&self) -> u64 {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `TransactionPool` is never used
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub trait TransactionPool<SM: StateMachine> {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `submit_transaction`, `pool_size`, and `pool_contains` are never used
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>           
[INFO] [stdout] 43 | |     where
[INFO] [stdout] 44 | |     SM: StateMachine,
[INFO] [stdout]    | |_____________________- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 48 |       pub fn submit_transaction(&mut self, t: SM::Transition) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |       pub fn pool_size(&self) -> usize {
[INFO] [stdout]    |              ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |       pub fn pool_contains(&self, t: SM::Transition) -> bool {
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SimplePool` is never constructed
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout] 65 | pub struct SimplePool<SM: StateMachine>(VecDeque<SM::Transition>);
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PriorityPool` is never constructed
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:96:12
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub struct PriorityPool<T, P: Fn(T) -> u64> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CensoringPool` is never constructed
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:134:12
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub struct CensoringPool<T, P: Fn(T) -> bool> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `author_and_import_manual_block` and `author_and_import_automatic_block` are never used
[INFO] [stdout]   --> src/c4_client/p5_authoring_blocks.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>
[INFO] [stdout]  8 | |     where
[INFO] [stdout]  9 | |     SM: StateMachine,
[INFO] [stdout]    | |_____________________- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 13 |       pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 19 |       pub fn author_and_import_automatic_block(&self) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `manually_finalize_block` is never used
[INFO] [stdout]   --> src/c4_client/p6_finality.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | impl<C, SM, FC, P> FullClient<C, SM, FC, P> {
[INFO] [stdout]    | ------------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub fn manually_finalize_block(&mut self, block_hash: u64) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 0.49s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: diy-blockchain v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] running `Command { std: "docker" "inspect" "cf311ebe74d3b75d74ebead277da2adc54459e2719dd78a83841a37103c2de8b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cf311ebe74d3b75d74ebead277da2adc54459e2719dd78a83841a37103c2de8b", kill_on_drop: false }`
[INFO] [stdout] cf311ebe74d3b75d74ebead277da2adc54459e2719dd78a83841a37103c2de8b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 25708d9123ed40987527cb6e82e17f46dc4fd82fd3688e3a51f97106b7c1fbc6
[INFO] running `Command { std: "docker" "start" "-a" "25708d9123ed40987527cb6e82e17f46dc4fd82fd3688e3a51f97106b7c1fbc6", kill_on_drop: false }`
[INFO] [stdout] warning: unused imports: `Block` and `Header`
[INFO] [stdout]  --> src/c2_blockchain/mod.rs:7:25
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use p6_rich_state::{Block, Header};
[INFO] [stdout]   |                         ^^^^^  ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]  --> src/c2_blockchain/p1_header_chain.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::hash;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::hash;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]  --> src/c2_blockchain/p3_consensus.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::hash;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]  --> src/c2_blockchain/p4_batched_extrinsics.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::hash;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::p3_consensus::THRESHOLD`
[INFO] [stdout]  --> src/c2_blockchain/p4_batched_extrinsics.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use super::p3_consensus::THRESHOLD;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use crate::hash;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::p3_consensus::THRESHOLD`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use super::p3_consensus::THRESHOLD;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::hash`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::hash;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::p3_consensus::THRESHOLD`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use super::p3_consensus::THRESHOLD;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/c3_consensus/p4_even_only.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:46:1
[INFO] [stdout]    |
[INFO] [stdout] 46 | / fn change_authorities(
[INFO] [stdout] 47 | |     fork_height: u64,
[INFO] [stdout] 48 | |     initial_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout] 49 | |     final_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout] 50 | | ) -> impl Consensus {
[INFO] [stdout]    | |___________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:50:6
[INFO] [stdout]    |
[INFO] [stdout] 50 | ) -> impl Consensus {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(dependency_on_unit_never_type_fallback)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:55:1
[INFO] [stdout]    |
[INFO] [stdout] 55 | / fn change_difficulty(
[INFO] [stdout] 56 | |     fork_height: u64,
[INFO] [stdout] 57 | |     initial_difficulty: u64,
[INFO] [stdout] 58 | |     final_difficulty: u64,
[INFO] [stdout] 59 | | ) -> impl Consensus {
[INFO] [stdout]    | |___________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:59:6
[INFO] [stdout]    |
[INFO] [stdout] 59 | ) -> impl Consensus {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:1
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:70
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    |                                                                      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:80:1
[INFO] [stdout]    |
[INFO] [stdout] 80 | / fn pow_to_poa(
[INFO] [stdout] 81 | |     fork_height: u64,
[INFO] [stdout] 82 | |     difficulty: u64,
[INFO] [stdout] 83 | |     authorities: Vec<ConsensusAuthority>,
[INFO] [stdout] 84 | | ) -> impl Consensus {
[INFO] [stdout]    | |___________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:84:6
[INFO] [stdout]    |
[INFO] [stdout] 84 | ) -> impl Consensus {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:17:19
[INFO] [stdout]    |
[INFO] [stdout] 17 |     fn next_state(starting_state: &bool, t: &()) -> bool {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:17:42
[INFO] [stdout]    |
[INFO] [stdout] 17 |     fn next_state(starting_state: &bool, t: &()) -> bool {
[INFO] [stdout]    |                                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:44:19
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn next_state(starting_state: &TwoSwitches, t: &Toggle) -> TwoSwitches {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:44:49
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn next_state(starting_state: &TwoSwitches, t: &Toggle) -> TwoSwitches {
[INFO] [stdout]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p2_laundry_machine.rs:42:19
[INFO] [stdout]    |
[INFO] [stdout] 42 |     fn next_state(starting_state: &ClothesState, t: &ClothesAction) -> ClothesState {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p2_laundry_machine.rs:42:50
[INFO] [stdout]    |
[INFO] [stdout] 42 |     fn next_state(starting_state: &ClothesState, t: &ClothesAction) -> ClothesState {
[INFO] [stdout]    |                                                  ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:60:19
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:60:49
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:47:19
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn next_state(starting_state: &Balances, t: &AccountingTransaction) -> Balances {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:47:46
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn next_state(starting_state: &Balances, t: &AccountingTransaction) -> Balances {
[INFO] [stdout]    |                                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:96:19
[INFO] [stdout]    |
[INFO] [stdout] 96 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:96:49
[INFO] [stdout]    |
[INFO] [stdout] 96 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:40:32
[INFO] [stdout]    |
[INFO] [stdout] 40 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsic`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:38:21
[INFO] [stdout]    |
[INFO] [stdout] 38 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsic`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:50:32
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:58:22
[INFO] [stdout]    |
[INFO] [stdout] 58 | fn build_valid_chain(n: u64) -> Vec<Header> {
[INFO] [stdout]    |                      ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsic`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:44:21
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsic`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:52:32
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:64:37
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn verify_sub_chain_even(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                     ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:70:36
[INFO] [stdout]    |
[INFO] [stdout] 70 |     fn verify_sub_chain_odd(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics_root`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:42:25
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:42:48
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stdout]    |                                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `child`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:53:28
[INFO] [stdout]    |
[INFO] [stdout] 53 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stdout]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:64:32
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:89:25
[INFO] [stdout]    |
[INFO] [stdout] 89 |     pub fn child(&self, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:96:36
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn verify_sub_chain(&self, chain: &[Block]) -> bool {
[INFO] [stdout]    |                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent`
[INFO] [stdout]    --> src/c2_blockchain/p4_batched_extrinsics.rs:109:48
[INFO] [stdout]     |
[INFO] [stdout] 109 | fn build_invalid_child_block_with_valid_header(parent: &Header) -> Block {
[INFO] [stdout]     |                                                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:34:23
[INFO] [stdout]    |
[INFO] [stdout] 34 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_1`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:43:30
[INFO] [stdout]    |
[INFO] [stdout] 43 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_2`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:43:50
[INFO] [stdout]    |
[INFO] [stdout] 43 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:47:23
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:69:20
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stdout]    |                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `threshold`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:69:39
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stdout]    |                                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_threshold`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_1`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:74:30
[INFO] [stdout]    |
[INFO] [stdout] 74 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_2`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:74:50
[INFO] [stdout]    |
[INFO] [stdout] 74 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:78:23
[INFO] [stdout]    |
[INFO] [stdout] 78 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_1`
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:100:30
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]     |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_2`
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:100:50
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]     |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:104:23
[INFO] [stdout]     |
[INFO] [stdout] 104 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state_root`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:49:16
[INFO] [stdout]    |
[INFO] [stdout] 49 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics_root`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:57:21
[INFO] [stdout]    |
[INFO] [stdout] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state_root`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:57:44
[INFO] [stdout]    |
[INFO] [stdout] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stdout]    |                                            ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `child`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:62:28
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stdout]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:67:32
[INFO] [stdout]    |
[INFO] [stdout] 67 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:91:20
[INFO] [stdout]    |
[INFO] [stdout] 91 |     pub fn genesis(genesis_state: &State) -> Self {
[INFO] [stdout]    |                    ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:96:25
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:96:44
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |                                            ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:105:36
[INFO] [stdout]     |
[INFO] [stdout] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stdout]     |                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:105:55
[INFO] [stdout]     |
[INFO] [stdout] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stdout]     |                                                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:121:48
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stdout]     |                                                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:121:65
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stdout]     |                                                                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:21:42
[INFO] [stdout]    |
[INFO] [stdout] 21 |     fn validate(&self, _: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:27:38
[INFO] [stdout]    |
[INFO] [stdout] 27 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p2_dictator.rs:23:42
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn validate(&self, _: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p2_dictator.rs:28:38
[INFO] [stdout]    |
[INFO] [stdout] 28 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:22:24
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:22:54
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 28 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 29 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:45:24
[INFO] [stdout]    |
[INFO] [stdout] 45 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:45:54
[INFO] [stdout]    |
[INFO] [stdout] 45 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:51:9
[INFO] [stdout]    |
[INFO] [stdout] 51 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:52:9
[INFO] [stdout]    |
[INFO] [stdout] 52 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:82:24
[INFO] [stdout]    |
[INFO] [stdout] 82 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:82:54
[INFO] [stdout]    |
[INFO] [stdout] 82 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:88:9
[INFO] [stdout]    |
[INFO] [stdout] 88 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:89:9
[INFO] [stdout]    |
[INFO] [stdout] 89 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:19:24
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:19:54
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 25 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:52:24
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:52:54
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:58:9
[INFO] [stdout]    |
[INFO] [stdout] 58 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:59:9
[INFO] [stdout]    |
[INFO] [stdout] 59 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:31:24
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:31:54
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:38:9
[INFO] [stdout]    |
[INFO] [stdout] 38 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fork_height: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `initial_authorities`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     initial_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_initial_authorities`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `final_authorities`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:49:5
[INFO] [stdout]    |
[INFO] [stdout] 49 |     final_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_authorities`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:56:5
[INFO] [stdout]    |
[INFO] [stdout] 56 |     fork_height: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `initial_difficulty`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:57:5
[INFO] [stdout]    |
[INFO] [stdout] 57 |     initial_difficulty: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_initial_difficulty`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `final_difficulty`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:58:5
[INFO] [stdout]    |
[INFO] [stdout] 58 |     final_difficulty: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_difficulty`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:49
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    |                                                 ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:81:5
[INFO] [stdout]    |
[INFO] [stdout] 81 |     fork_height: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `difficulty`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 82 |     difficulty: u64,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_difficulty`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `authorities`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:83:5
[INFO] [stdout]    |
[INFO] [stdout] 83 |     authorities: Vec<ConsensusAuthority>,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_authorities`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/mod.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c3_consensus/mod.rs:77:9
[INFO] [stdout]    |
[INFO] [stdout] 77 |         chain: &[Header<Self::Digest>],
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]    --> src/c3_consensus/mod.rs:101:38
[INFO] [stdout]     |
[INFO] [stdout] 101 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state_root`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:26:16
[INFO] [stdout]    |
[INFO] [stdout] 26 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state_root`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:31:21
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics_root`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:31:39
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stdout]    |                                       ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `child`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:36:28
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn verify_child(&self, child: &Self) -> bool {
[INFO] [stdout]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:41:32
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn verify_sub_chain(&self, chain: &[Self]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:53:20
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn genesis(genesis_state: &SM::State) -> Self {
[INFO] [stdout]    |                    ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:58:25
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:58:48
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stdout]    |                                                ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:63:36
[INFO] [stdout]    |
[INFO] [stdout] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stdout]    |                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:63:59
[INFO] [stdout]    |
[INFO] [stdout] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stdout]    |                                                           ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     n: u64,
[INFO] [stdout]    |     ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:72:5
[INFO] [stdout]    |
[INFO] [stdout] 72 |     genesis_state: &SM::State,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:84:12
[INFO] [stdout]    |
[INFO] [stdout] 84 |     fn new(genesis_state: SM::State) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:41:25
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn get_block(&self, block_hash: u64) -> Option<Block<C, SM>> {
[INFO] [stdout]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:45:25
[INFO] [stdout]    |
[INFO] [stdout] 45 |     fn get_state(&self, block_hash: u64) -> Option<<SM as StateMachine>::State> {
[INFO] [stdout]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:49:23
[INFO] [stdout]    |
[INFO] [stdout] 49 |     fn is_leaf(&self, block_hash: u64) -> Option<bool> {
[INFO] [stdout]    |                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:32:26
[INFO] [stdout]    |
[INFO] [stdout] 32 |     fn best_block(&self, header: Header<C::Digest>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:36:31
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn import_hook(&mut self, header: Header<C::Digest>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:49:26
[INFO] [stdout]    |
[INFO] [stdout] 49 |     fn best_block(&self, header: Header<u64>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:53:31
[INFO] [stdout]    |
[INFO] [stdout] 53 |     fn import_hook(&mut self, header: Header<u64>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:66:26
[INFO] [stdout]    |
[INFO] [stdout] 66 |     fn best_block(&self, header: Header<ConsensusAuthority>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:70:31
[INFO] [stdout]    |
[INFO] [stdout] 70 |     fn import_hook(&mut self, header: Header<ConsensusAuthority>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:83:26
[INFO] [stdout]    |
[INFO] [stdout] 83 |     fn best_block(&self, header: Header<u64>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |     fn import_hook(&mut self, header: Header<u64>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:48:42
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub fn submit_transaction(&mut self, t: SM::Transition) {
[INFO] [stdout]    |                                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:59:33
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub fn pool_contains(&self, t: SM::Transition) -> bool {
[INFO] [stdout]    |                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:68:30
[INFO] [stdout]    |
[INFO] [stdout] 68 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]    |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:72:26
[INFO] [stdout]    |
[INFO] [stdout] 72 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stdout]    |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:80:24
[INFO] [stdout]    |
[INFO] [stdout] 80 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]    |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:110:30
[INFO] [stdout]     |
[INFO] [stdout] 110 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:114:26
[INFO] [stdout]     |
[INFO] [stdout] 114 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stdout]     |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:122:24
[INFO] [stdout]     |
[INFO] [stdout] 122 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:145:30
[INFO] [stdout]     |
[INFO] [stdout] 145 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:149:26
[INFO] [stdout]     |
[INFO] [stdout] 149 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stdout]     |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:157:24
[INFO] [stdout]     |
[INFO] [stdout] 157 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transactions`
[INFO] [stdout]   --> src/c4_client/p5_authoring_blocks.rs:13:54
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transactions`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_hash`
[INFO] [stdout]   --> src/c4_client/p5_authoring_blocks.rs:13:89
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stdout]    |                                                                                         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p6_finality.rs:13:47
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub fn manually_finalize_block(&mut self, block_hash: u64) -> bool {
[INFO] [stdout]    |                                               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hash` is never used
[INFO] [stdout]   --> src/lib.rs:10:4
[INFO] [stdout]    |
[INFO] [stdout] 10 | fn hash<T: Hash>(t: &T) -> u64 {
[INFO] [stdout]    |    ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `StateMachine` is never used
[INFO] [stdout]   --> src/c1_state_machine/mod.rs:12:11
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub trait StateMachine {
[INFO] [stdout]    |           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `User` is never used
[INFO] [stdout]   --> src/c1_state_machine/mod.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub enum User {
[INFO] [stdout]    |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LightSwitch` is never constructed
[INFO] [stdout]  --> src/c1_state_machine/p1_switches.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct LightSwitch;
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `WeirdSwitchMachine` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct WeirdSwitchMachine;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TwoSwitches` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct TwoSwitches {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Toggle` is never used
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:34:10
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub enum Toggle {
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ClothesMachine` is never constructed
[INFO] [stdout]  --> src/c1_state_machine/p2_laundry_machine.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ClothesMachine;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ClothesState` is never used
[INFO] [stdout]   --> src/c1_state_machine/p2_laundry_machine.rs:13:10
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub enum ClothesState {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ClothesAction` is never used
[INFO] [stdout]   --> src/c1_state_machine/p2_laundry_machine.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum ClothesAction {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Key` is never used
[INFO] [stdout]  --> src/c1_state_machine/p3_atm.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub enum Key {
[INFO] [stdout]   |          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Action` is never used
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:18:10
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub enum Action {
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Auth` is never used
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:28:6
[INFO] [stdout]    |
[INFO] [stdout] 28 | enum Auth {
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Atm` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct Atm {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AccountedCurrency` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct AccountedCurrency;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Balances` is never used
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:24:6
[INFO] [stdout]    |
[INFO] [stdout] 24 | type Balances = HashMap<User, u64>;
[INFO] [stdout]    |      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `AccountingTransaction` is never used
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum AccountingTransaction {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DigitalCashSystem` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct DigitalCashSystem;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Bill` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct Bill {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `State` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub struct State {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `set_serial`, `next_serial`, `increment_serial`, and `add_bill` are never used
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | impl State {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 34 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn set_serial(&mut self, serial: u64) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn next_serial(&self) -> u64 {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     fn increment_serial(&mut self) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     fn add_bill(&mut self, elem: Bill) {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CashTransaction` is never used
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:77:10
[INFO] [stdout]    |
[INFO] [stdout] 77 | pub enum CashTransaction {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `State` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p6_open_ended.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct State {}
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Transition` is never used
[INFO] [stdout]   --> src/c1_state_machine/p6_open_ended.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum Transition {}
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:10:6
[INFO] [stdout]    |
[INFO] [stdout] 10 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct Header {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl Header {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 26 |     /// Returns a new valid genesis header.
[INFO] [stdout] 27 |     fn genesis() -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |     fn child(&self) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_valid_chain_length_5` is never used
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:48:4
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn build_valid_chain_length_5() -> Vec<Header> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_an_invalid_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:55:4
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn build_an_invalid_chain() -> Vec<Header> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:14:6
[INFO] [stdout]    |
[INFO] [stdout] 14 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct Header {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:33:8
[INFO] [stdout]    |
[INFO] [stdout] 31 | impl Header {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 32 |     /// Returns a new valid genesis header.
[INFO] [stdout] 33 |     fn genesis() -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 50 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_valid_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:58:4
[INFO] [stdout]    |
[INFO] [stdout] 58 | fn build_valid_chain(n: u64) -> Vec<Header> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_an_invalid_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:72:4
[INFO] [stdout]    |
[INFO] [stdout] 72 | fn build_an_invalid_chain() -> Vec<Header> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_forked_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:87:4
[INFO] [stdout]    |
[INFO] [stdout] 87 | fn build_forked_chain() -> (Vec<Header>, Vec<Header>) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:11:6
[INFO] [stdout]    |
[INFO] [stdout] 11 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `THRESHOLD` is never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:16:11
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub const THRESHOLD: u64 = u64::max_value() / 100;
[INFO] [stdout]    |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORK_HEIGHT` is never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:20:7
[INFO] [stdout]    |
[INFO] [stdout] 20 | const FORK_HEIGHT: u64 = 2;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct Header {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, `verify_sub_chain`, `verify_sub_chain_even`, and `verify_sub_chain_odd` are never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 37 | impl Header {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 38 |     /// Returns a new valid genesis header.
[INFO] [stdout] 39 |     fn genesis() -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     fn verify_sub_chain_even(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 |     fn verify_sub_chain_odd(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_contentious_forked_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:91:4
[INFO] [stdout]    |
[INFO] [stdout] 91 | fn build_contentious_forked_chain() -> (Vec<Header>, Vec<Header>, Vec<Header>) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]  --> src/c2_blockchain/p4_batched_extrinsics.rs:6:6
[INFO] [stdout]   |
[INFO] [stdout] 6 | type Hash = u64;
[INFO] [stdout]   |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct Header {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, `verify_child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | impl Header {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 34 |     /// Returns a new valid genesis header.
[INFO] [stdout] 35 |     pub fn genesis() -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Block` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:71:12
[INFO] [stdout]    |
[INFO] [stdout] 71 | pub struct Block {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:83:12
[INFO] [stdout]    |
[INFO] [stdout] 81 | impl Block {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 82 |     /// Returns a new valid genesis block. By convention this block has no extrinsics.
[INFO] [stdout] 83 |     pub fn genesis() -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 89 |     pub fn child(&self, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 96 |     pub fn verify_sub_chain(&self, chain: &[Block]) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_invalid_child_block_with_valid_header` is never used
[INFO] [stdout]    --> src/c2_blockchain/p4_batched_extrinsics.rs:109:4
[INFO] [stdout]     |
[INFO] [stdout] 109 | fn build_invalid_child_block_with_valid_header(parent: &Header) -> Block {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ForkChoice` is never used
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub trait ForkChoice {
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LongestChainRule` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:40:12
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub struct LongestChainRule;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HeaviestChainRule` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:63:12
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct HeaviestChainRule;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mine_extra_hard` is never used
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:69:4
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MostBlocksWithEvenHash` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:97:12
[INFO] [stdout]    |
[INFO] [stdout] 97 | pub struct MostBlocksWithEvenHash;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_fork_one_side_longer_other_side_heavier` is never used
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:132:4
[INFO] [stdout]     |
[INFO] [stdout] 132 | fn create_fork_one_side_longer_other_side_heavier() -> (Vec<Header>, Vec<Header>, Vec<Header>) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:14:6
[INFO] [stdout]    |
[INFO] [stdout] 14 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `State` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct State {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct Header {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, `verify_child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:49:8
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl Header {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 48 |     /// Returns a new valid genesis header.
[INFO] [stdout] 49 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 67 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Block` is never constructed
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:74:12
[INFO] [stdout]    |
[INFO] [stdout] 74 | pub struct Block {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:91:12
[INFO] [stdout]     |
[INFO] [stdout]  89 | impl Block {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout]  90 |     /// Returns a new valid genesis block. By convention this block has no extrinsics.
[INFO] [stdout]  91 |     pub fn genesis(genesis_state: &State) -> Self {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_invalid_child_block_with_valid_header` is never used
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:121:4
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c3_consensus/mod.rs:16:6
[INFO] [stdout]    |
[INFO] [stdout] 16 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c3_consensus/mod.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct Header<Digest> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Consensus` is never used
[INFO] [stdout]   --> src/c3_consensus/mod.rs:38:11
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub trait Consensus {
[INFO] [stdout]    |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Alice`, `Bob`, and `Charlie` are never constructed
[INFO] [stdout]    --> src/c3_consensus/mod.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 109 | pub enum ConsensusAuthority {
[INFO] [stdout]     |          ------------------ variants in this enum
[INFO] [stdout] 110 |     Alice,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 111 |     Bob,
[INFO] [stdout]     |     ^^^
[INFO] [stdout] 112 |     Charlie,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ConsensusAuthority` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Pow` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct Pow {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `moderate_difficulty_pow` is never used
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub fn moderate_difficulty_pow() -> Pow {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `trivial_always_valid_pow` is never used
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:40:8
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub fn trivial_always_valid_pow() -> Pow {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DictatorConsensus` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p2_dictator.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | struct DictatorConsensus {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SimplePoa` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct SimplePoa {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PoaRoundRobinByHeight` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:38:8
[INFO] [stdout]    |
[INFO] [stdout] 38 | struct PoaRoundRobinByHeight {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PoaRoundRobinBySlot` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:66:8
[INFO] [stdout]    |
[INFO] [stdout] 66 | struct PoaRoundRobinBySlot {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SlotDigest` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:74:8
[INFO] [stdout]    |
[INFO] [stdout] 74 | struct SlotDigest {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `EvenOnly` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | struct EvenOnly<Inner: Consensus> {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `almost_valid_but_not_all_even` is never used
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:35:4
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn almost_valid_but_not_all_even() -> Vec<Header<u64>> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AlternatingPowPoa` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | struct AlternatingPowPoa;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Pow` and `Poa` are never constructed
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | enum PowOrPoaDigest {
[INFO] [stdout]    |      -------------- variants in this enum
[INFO] [stdout] 17 |     Pow(u64),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 18 |     Poa(ConsensusAuthority),
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PowOrPoaDigest` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Forked` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | struct Forked<D, Before, After> {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `change_authorities` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:46:4
[INFO] [stdout]    |
[INFO] [stdout] 46 | fn change_authorities(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `change_difficulty` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:55:4
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn change_difficulty(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `even_after_given_height` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:4
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pow_to_poa` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:80:4
[INFO] [stdout]    |
[INFO] [stdout] 80 | fn pow_to_poa(
[INFO] [stdout]    |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c4_client/mod.rs:29:6
[INFO] [stdout]    |
[INFO] [stdout] 29 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FullClient` is never constructed
[INFO] [stdout]   --> src/c4_client/mod.rs:52:12
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub struct FullClient<C, SM, FC, P>
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:22:6
[INFO] [stdout]    |
[INFO] [stdout] 22 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, `verify_child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:26:8
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl<Digest> Header<Digest> {
[INFO] [stdout]    | --------------------------- associated items in this implementation
[INFO] [stdout] 25 |     /// Returns a new valid genesis header.
[INFO] [stdout] 26 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     fn verify_child(&self, child: &Self) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     fn verify_sub_chain(&self, chain: &[Self]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Block` is never constructed
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct Block<C: Consensus, SM: StateMachine> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:53:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | impl<C: Consensus, SM: StateMachine> Block<C, SM> {
[INFO] [stdout]    | ------------------------------------------------- associated items in this implementation
[INFO] [stdout] 52 |     /// Returns a new valid genesis block. By convention this block has no extrinsics.
[INFO] [stdout] 53 |     pub fn genesis(genesis_state: &SM::State) -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_empty_chain` is never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:70:4
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn create_empty_chain<C: Consensus, SM: StateMachine>(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:84:8
[INFO] [stdout]    |
[INFO] [stdout] 80 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>
[INFO] [stdout] 81 | | where
[INFO] [stdout] 82 | |     SM: StateMachine,
[INFO] [stdout]    | |_____________________- associated function in this implementation
[INFO] [stdout] 83 |   {
[INFO] [stdout] 84 |       fn new(genesis_state: SM::State) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ImportBlock` is never used
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub trait ImportBlock<C: Consensus, SM: StateMachine> {
[INFO] [stdout]    |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ForkChoice` is never used
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:18:11
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub trait ForkChoice<C: Consensus> {
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LongestChain` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct LongestChain {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HeaviestChain` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct HeaviestChain {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MostAliceSigs` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:61:12
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub struct MostAliceSigs {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ghost` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:78:12
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub struct Ghost {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `best_block` is never used
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:97:8
[INFO] [stdout]    |
[INFO] [stdout] 95 | impl<C, SM, FC, P> FullClient<C, SM, FC, P> {
[INFO] [stdout]    | ------------------------------------------- method in this implementation
[INFO] [stdout] 96 |     /// Return the hash of the best block currently known to the client
[INFO] [stdout] 97 |     fn best_block(&self) -> u64 {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `TransactionPool` is never used
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub trait TransactionPool<SM: StateMachine> {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `submit_transaction`, `pool_size`, and `pool_contains` are never used
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>           
[INFO] [stdout] 43 | |     where
[INFO] [stdout] 44 | |     SM: StateMachine,
[INFO] [stdout]    | |_____________________- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 48 |       pub fn submit_transaction(&mut self, t: SM::Transition) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |       pub fn pool_size(&self) -> usize {
[INFO] [stdout]    |              ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |       pub fn pool_contains(&self, t: SM::Transition) -> bool {
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SimplePool` is never constructed
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout] 65 | pub struct SimplePool<SM: StateMachine>(VecDeque<SM::Transition>);
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PriorityPool` is never constructed
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:96:12
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub struct PriorityPool<T, P: Fn(T) -> u64> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CensoringPool` is never constructed
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:134:12
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub struct CensoringPool<T, P: Fn(T) -> bool> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `author_and_import_manual_block` and `author_and_import_automatic_block` are never used
[INFO] [stdout]   --> src/c4_client/p5_authoring_blocks.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>
[INFO] [stdout]  8 | |     where
[INFO] [stdout]  9 | |     SM: StateMachine,
[INFO] [stdout]    | |_____________________- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 13 |       pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 19 |       pub fn author_and_import_automatic_block(&self) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `manually_finalize_block` is never used
[INFO] [stdout]   --> src/c4_client/p6_finality.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | impl<C, SM, FC, P> FullClient<C, SM, FC, P> {
[INFO] [stdout]    | ------------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub fn manually_finalize_block(&mut self, block_hash: u64) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling diy-blockchain v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Block` and `Header`
[INFO] [stdout]  --> src/c2_blockchain/mod.rs:7:25
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use p6_rich_state::{Block, Header};
[INFO] [stdout]   |                         ^^^^^  ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::p3_consensus::THRESHOLD`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use super::p3_consensus::THRESHOLD;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/c3_consensus/p4_even_only.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:46:1
[INFO] [stdout]    |
[INFO] [stdout] 46 | / fn change_authorities(
[INFO] [stdout] 47 | |     fork_height: u64,
[INFO] [stdout] 48 | |     initial_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout] 49 | |     final_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout] 50 | | ) -> impl Consensus {
[INFO] [stdout]    | |___________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:50:6
[INFO] [stdout]    |
[INFO] [stdout] 50 | ) -> impl Consensus {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(dependency_on_unit_never_type_fallback)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:55:1
[INFO] [stdout]    |
[INFO] [stdout] 55 | / fn change_difficulty(
[INFO] [stdout] 56 | |     fork_height: u64,
[INFO] [stdout] 57 | |     initial_difficulty: u64,
[INFO] [stdout] 58 | |     final_difficulty: u64,
[INFO] [stdout] 59 | | ) -> impl Consensus {
[INFO] [stdout]    | |___________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:59:6
[INFO] [stdout]    |
[INFO] [stdout] 59 | ) -> impl Consensus {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:1
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:70
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    |                                                                      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this function depends on never type fallback being `()`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:80:1
[INFO] [stdout]    |
[INFO] [stdout] 80 | / fn pow_to_poa(
[INFO] [stdout] 81 | |     fork_height: u64,
[INFO] [stdout] 82 | |     difficulty: u64,
[INFO] [stdout] 83 | |     authorities: Vec<ConsensusAuthority>,
[INFO] [stdout] 84 | | ) -> impl Consensus {
[INFO] [stdout]    | |___________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stdout]    = help: specify the types explicitly
[INFO] [stdout] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:84:6
[INFO] [stdout]    |
[INFO] [stdout] 84 | ) -> impl Consensus {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:17:19
[INFO] [stdout]    |
[INFO] [stdout] 17 |     fn next_state(starting_state: &bool, t: &()) -> bool {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:17:42
[INFO] [stdout]    |
[INFO] [stdout] 17 |     fn next_state(starting_state: &bool, t: &()) -> bool {
[INFO] [stdout]    |                                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:44:19
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn next_state(starting_state: &TwoSwitches, t: &Toggle) -> TwoSwitches {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p1_switches.rs:44:49
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn next_state(starting_state: &TwoSwitches, t: &Toggle) -> TwoSwitches {
[INFO] [stdout]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p2_laundry_machine.rs:42:19
[INFO] [stdout]    |
[INFO] [stdout] 42 |     fn next_state(starting_state: &ClothesState, t: &ClothesAction) -> ClothesState {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p2_laundry_machine.rs:42:50
[INFO] [stdout]    |
[INFO] [stdout] 42 |     fn next_state(starting_state: &ClothesState, t: &ClothesAction) -> ClothesState {
[INFO] [stdout]    |                                                  ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:60:19
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:60:49
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:47:19
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn next_state(starting_state: &Balances, t: &AccountingTransaction) -> Balances {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:47:46
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn next_state(starting_state: &Balances, t: &AccountingTransaction) -> Balances {
[INFO] [stdout]    |                                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `starting_state`
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:96:19
[INFO] [stdout]    |
[INFO] [stdout] 96 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:96:49
[INFO] [stdout]    |
[INFO] [stdout] 96 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stdout]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p1_header_chain.rs:40:32
[INFO] [stdout]    |
[INFO] [stdout] 40 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsic`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:38:21
[INFO] [stdout]    |
[INFO] [stdout] 38 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsic`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:50:32
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:58:22
[INFO] [stdout]    |
[INFO] [stdout] 58 | fn build_valid_chain(n: u64) -> Vec<Header> {
[INFO] [stdout]    |                      ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsic`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:44:21
[INFO] [stdout]    |
[INFO] [stdout] 44 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsic`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:52:32
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:64:37
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn verify_sub_chain_even(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                     ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:70:36
[INFO] [stdout]    |
[INFO] [stdout] 70 |     fn verify_sub_chain_odd(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics_root`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:42:25
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:42:48
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stdout]    |                                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `child`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:53:28
[INFO] [stdout]    |
[INFO] [stdout] 53 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stdout]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:64:32
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:89:25
[INFO] [stdout]    |
[INFO] [stdout] 89 |     pub fn child(&self, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:96:36
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn verify_sub_chain(&self, chain: &[Block]) -> bool {
[INFO] [stdout]    |                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent`
[INFO] [stdout]    --> src/c2_blockchain/p4_batched_extrinsics.rs:109:48
[INFO] [stdout]     |
[INFO] [stdout] 109 | fn build_invalid_child_block_with_valid_header(parent: &Header) -> Block {
[INFO] [stdout]     |                                                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:34:23
[INFO] [stdout]    |
[INFO] [stdout] 34 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_1`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:43:30
[INFO] [stdout]    |
[INFO] [stdout] 43 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_2`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:43:50
[INFO] [stdout]    |
[INFO] [stdout] 43 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:47:23
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:69:20
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stdout]    |                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_block`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `threshold`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:69:39
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stdout]    |                                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_threshold`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_1`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:74:30
[INFO] [stdout]    |
[INFO] [stdout] 74 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_2`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:74:50
[INFO] [stdout]    |
[INFO] [stdout] 74 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]    |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]   --> src/c2_blockchain/p5_fork_choice.rs:78:23
[INFO] [stdout]    |
[INFO] [stdout] 78 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_1`
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:100:30
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]     |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain_2`
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:100:50
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stdout]     |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `candidate_chains`
[INFO] [stdout]    --> src/c2_blockchain/p5_fork_choice.rs:104:23
[INFO] [stdout]     |
[INFO] [stdout] 104 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state_root`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:49:16
[INFO] [stdout]    |
[INFO] [stdout] 49 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics_root`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:57:21
[INFO] [stdout]    |
[INFO] [stdout] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state_root`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:57:44
[INFO] [stdout]    |
[INFO] [stdout] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stdout]    |                                            ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `child`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:62:28
[INFO] [stdout]    |
[INFO] [stdout] 62 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stdout]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:67:32
[INFO] [stdout]    |
[INFO] [stdout] 67 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:91:20
[INFO] [stdout]    |
[INFO] [stdout] 91 |     pub fn genesis(genesis_state: &State) -> Self {
[INFO] [stdout]    |                    ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:96:25
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics`
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:96:44
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stdout]    |                                            ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:105:36
[INFO] [stdout]     |
[INFO] [stdout] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stdout]     |                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:105:55
[INFO] [stdout]     |
[INFO] [stdout] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stdout]     |                                                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:121:48
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stdout]     |                                                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]    --> src/c2_blockchain/p6_rich_state.rs:121:65
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stdout]     |                                                                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:21:42
[INFO] [stdout]    |
[INFO] [stdout] 21 |     fn validate(&self, _: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:27:38
[INFO] [stdout]    |
[INFO] [stdout] 27 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p2_dictator.rs:23:42
[INFO] [stdout]    |
[INFO] [stdout] 23 |     fn validate(&self, _: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p2_dictator.rs:28:38
[INFO] [stdout]    |
[INFO] [stdout] 28 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:22:24
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:22:54
[INFO] [stdout]    |
[INFO] [stdout] 22 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 28 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 29 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:45:24
[INFO] [stdout]    |
[INFO] [stdout] 45 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:45:54
[INFO] [stdout]    |
[INFO] [stdout] 45 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:51:9
[INFO] [stdout]    |
[INFO] [stdout] 51 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:52:9
[INFO] [stdout]    |
[INFO] [stdout] 52 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:82:24
[INFO] [stdout]    |
[INFO] [stdout] 82 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:82:54
[INFO] [stdout]    |
[INFO] [stdout] 82 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:88:9
[INFO] [stdout]    |
[INFO] [stdout] 88 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:89:9
[INFO] [stdout]    |
[INFO] [stdout] 89 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:19:24
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:19:54
[INFO] [stdout]    |
[INFO] [stdout] 19 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 25 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:52:24
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:52:54
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:58:9
[INFO] [stdout]    |
[INFO] [stdout] 58 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:59:9
[INFO] [stdout]    |
[INFO] [stdout] 59 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:31:24
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:31:54
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stdout]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 37 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:38:9
[INFO] [stdout]    |
[INFO] [stdout] 38 |         partial_header: Header<()>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fork_height: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `initial_authorities`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     initial_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_initial_authorities`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `final_authorities`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:49:5
[INFO] [stdout]    |
[INFO] [stdout] 49 |     final_authorities: Vec<ConsensusAuthority>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_authorities`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:56:5
[INFO] [stdout]    |
[INFO] [stdout] 56 |     fork_height: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `initial_difficulty`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:57:5
[INFO] [stdout]    |
[INFO] [stdout] 57 |     initial_difficulty: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_initial_difficulty`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `final_difficulty`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:58:5
[INFO] [stdout]    |
[INFO] [stdout] 58 |     final_difficulty: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_difficulty`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:49
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    |                                                 ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fork_height`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:81:5
[INFO] [stdout]    |
[INFO] [stdout] 81 |     fork_height: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `difficulty`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 82 |     difficulty: u64,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_difficulty`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `authorities`
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:83:5
[INFO] [stdout]    |
[INFO] [stdout] 83 |     authorities: Vec<ConsensusAuthority>,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_authorities`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_digest`
[INFO] [stdout]   --> src/c3_consensus/mod.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |         parent_digest: &Self::Digest,
[INFO] [stdout]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c3_consensus/mod.rs:77:9
[INFO] [stdout]    |
[INFO] [stdout] 77 |         chain: &[Header<Self::Digest>],
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `partial_header`
[INFO] [stdout]    --> src/c3_consensus/mod.rs:101:38
[INFO] [stdout]     |
[INFO] [stdout] 101 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state_root`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:26:16
[INFO] [stdout]    |
[INFO] [stdout] 26 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `state_root`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:31:21
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stdout]    |                     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_state_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics_root`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:31:39
[INFO] [stdout]    |
[INFO] [stdout] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stdout]    |                                       ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `child`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:36:28
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn verify_child(&self, child: &Self) -> bool {
[INFO] [stdout]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:41:32
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn verify_sub_chain(&self, chain: &[Self]) -> bool {
[INFO] [stdout]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:53:20
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub fn genesis(genesis_state: &SM::State) -> Self {
[INFO] [stdout]    |                    ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:58:25
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stdout]    |                         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `extrinsics`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:58:48
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stdout]    |                                                ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `pre_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:63:36
[INFO] [stdout]    |
[INFO] [stdout] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stdout]    |                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chain`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:63:59
[INFO] [stdout]    |
[INFO] [stdout] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stdout]    |                                                           ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     n: u64,
[INFO] [stdout]    |     ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:72:5
[INFO] [stdout]    |
[INFO] [stdout] 72 |     genesis_state: &SM::State,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `genesis_state`
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:84:12
[INFO] [stdout]    |
[INFO] [stdout] 84 |     fn new(genesis_state: SM::State) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:41:25
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn get_block(&self, block_hash: u64) -> Option<Block<C, SM>> {
[INFO] [stdout]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:45:25
[INFO] [stdout]    |
[INFO] [stdout] 45 |     fn get_state(&self, block_hash: u64) -> Option<<SM as StateMachine>::State> {
[INFO] [stdout]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:49:23
[INFO] [stdout]    |
[INFO] [stdout] 49 |     fn is_leaf(&self, block_hash: u64) -> Option<bool> {
[INFO] [stdout]    |                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:32:26
[INFO] [stdout]    |
[INFO] [stdout] 32 |     fn best_block(&self, header: Header<C::Digest>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:36:31
[INFO] [stdout]    |
[INFO] [stdout] 36 |     fn import_hook(&mut self, header: Header<C::Digest>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:49:26
[INFO] [stdout]    |
[INFO] [stdout] 49 |     fn best_block(&self, header: Header<u64>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:53:31
[INFO] [stdout]    |
[INFO] [stdout] 53 |     fn import_hook(&mut self, header: Header<u64>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:66:26
[INFO] [stdout]    |
[INFO] [stdout] 66 |     fn best_block(&self, header: Header<ConsensusAuthority>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:70:31
[INFO] [stdout]    |
[INFO] [stdout] 70 |     fn import_hook(&mut self, header: Header<ConsensusAuthority>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:83:26
[INFO] [stdout]    |
[INFO] [stdout] 83 |     fn best_block(&self, header: Header<u64>) -> Option<u64> {
[INFO] [stdout]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `header`
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:87:31
[INFO] [stdout]    |
[INFO] [stdout] 87 |     fn import_hook(&mut self, header: Header<u64>) {
[INFO] [stdout]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:48:42
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub fn submit_transaction(&mut self, t: SM::Transition) {
[INFO] [stdout]    |                                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:59:33
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub fn pool_contains(&self, t: SM::Transition) -> bool {
[INFO] [stdout]    |                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:68:30
[INFO] [stdout]    |
[INFO] [stdout] 68 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]    |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:72:26
[INFO] [stdout]    |
[INFO] [stdout] 72 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stdout]    |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:80:24
[INFO] [stdout]    |
[INFO] [stdout] 80 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]    |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:110:30
[INFO] [stdout]     |
[INFO] [stdout] 110 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:114:26
[INFO] [stdout]     |
[INFO] [stdout] 114 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stdout]     |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:122:24
[INFO] [stdout]     |
[INFO] [stdout] 122 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:145:30
[INFO] [stdout]     |
[INFO] [stdout] 145 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:149:26
[INFO] [stdout]     |
[INFO] [stdout] 149 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stdout]     |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `t`
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:157:24
[INFO] [stdout]     |
[INFO] [stdout] 157 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stdout]     |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `transactions`
[INFO] [stdout]   --> src/c4_client/p5_authoring_blocks.rs:13:54
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transactions`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parent_hash`
[INFO] [stdout]   --> src/c4_client/p5_authoring_blocks.rs:13:89
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stdout]    |                                                                                         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `block_hash`
[INFO] [stdout]   --> src/c4_client/p6_finality.rs:13:47
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub fn manually_finalize_block(&mut self, block_hash: u64) -> bool {
[INFO] [stdout]    |                                               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `human_name` is never used
[INFO] [stdout]   --> src/c1_state_machine/mod.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub trait StateMachine {
[INFO] [stdout]    |           ------------ associated function in this trait
[INFO] [stdout] ...
[INFO] [stdout] 25 |     fn human_name() -> String {
[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 `0` is never read
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:21:15
[INFO] [stdout]    |
[INFO] [stdout] 21 |     SwipeCard(u64),
[INFO] [stdout]    |     --------- ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 21 -     SwipeCard(u64),
[INFO] [stdout] 21 +     SwipeCard(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/c1_state_machine/p3_atm.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |     PressKey(Key),
[INFO] [stdout]    |     -------- ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 23 -     PressKey(Key),
[INFO] [stdout] 23 +     PressKey(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `minter` and `amount` are never read
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 29 |     Mint { minter: User, amount: u64 },
[INFO] [stdout]    |     ----   ^^^^^^        ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     fields in this variant
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `burner` and `amount` are never read
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 |     Burn { burner: User, amount: u64 },
[INFO] [stdout]    |     ----   ^^^^^^        ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     fields in this variant
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `sender`, `receiver`, and `amount` are never read
[INFO] [stdout]   --> src/c1_state_machine/p4_accounted_currency.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 35 |     Transfer {
[INFO] [stdout]    |     -------- fields in this variant
[INFO] [stdout] 36 |         sender: User,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 37 |         receiver: User,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 38 |         amount: u64,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `next_serial` is never used
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | impl State {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn next_serial(&self) -> u64 {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `minter` and `amount` are never read
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:79:12
[INFO] [stdout]    |
[INFO] [stdout] 79 |     Mint { minter: User, amount: u64 },
[INFO] [stdout]    |     ----   ^^^^^^        ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     fields in this variant
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `spends` and `receives` are never read
[INFO] [stdout]   --> src/c1_state_machine/p5_digital_cash.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 85 |     Transfer {
[INFO] [stdout]    |     -------- fields in this variant
[INFO] [stdout] 86 |         spends: Vec<Bill>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 87 |         receives: Vec<Bill>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `State` is never constructed
[INFO] [stdout]   --> src/c1_state_machine/p6_open_ended.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct State {}
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Transition` is never used
[INFO] [stdout]   --> src/c1_state_machine/p6_open_ended.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum Transition {}
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_valid_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p2_extrinsic_state.rs:58:4
[INFO] [stdout]    |
[INFO] [stdout] 58 | fn build_valid_chain(n: u64) -> Vec<Header> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORK_HEIGHT` is never used
[INFO] [stdout]   --> src/c2_blockchain/p3_consensus.rs:20:7
[INFO] [stdout]    |
[INFO] [stdout] 20 | const FORK_HEIGHT: u64 = 2;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `verify_sub_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p4_batched_extrinsics.rs:64:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | impl Header {
[INFO] [stdout]    | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 64 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `verify_sub_chain` is never used
[INFO] [stdout]   --> src/c2_blockchain/p6_rich_state.rs:67:8
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl Header {
[INFO] [stdout]    | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 67 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c3_consensus/mod.rs:16:6
[INFO] [stdout]    |
[INFO] [stdout] 16 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Header` is never constructed
[INFO] [stdout]   --> src/c3_consensus/mod.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct Header<Digest> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Consensus` is never used
[INFO] [stdout]   --> src/c3_consensus/mod.rs:38:11
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub trait Consensus {
[INFO] [stdout]    |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Alice`, `Bob`, and `Charlie` are never constructed
[INFO] [stdout]    --> src/c3_consensus/mod.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 109 | pub enum ConsensusAuthority {
[INFO] [stdout]     |          ------------------ variants in this enum
[INFO] [stdout] 110 |     Alice,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 111 |     Bob,
[INFO] [stdout]     |     ^^^
[INFO] [stdout] 112 |     Charlie,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ConsensusAuthority` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Pow` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct Pow {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `moderate_difficulty_pow` is never used
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub fn moderate_difficulty_pow() -> Pow {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `trivial_always_valid_pow` is never used
[INFO] [stdout]   --> src/c3_consensus/p1_pow.rs:40:8
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub fn trivial_always_valid_pow() -> Pow {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DictatorConsensus` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p2_dictator.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | struct DictatorConsensus {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SimplePoa` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct SimplePoa {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PoaRoundRobinByHeight` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:38:8
[INFO] [stdout]    |
[INFO] [stdout] 38 | struct PoaRoundRobinByHeight {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PoaRoundRobinBySlot` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:66:8
[INFO] [stdout]    |
[INFO] [stdout] 66 | struct PoaRoundRobinBySlot {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SlotDigest` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p3_poa.rs:74:8
[INFO] [stdout]    |
[INFO] [stdout] 74 | struct SlotDigest {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `EvenOnly` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | struct EvenOnly<Inner: Consensus> {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `almost_valid_but_not_all_even` is never used
[INFO] [stdout]   --> src/c3_consensus/p4_even_only.rs:35:4
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn almost_valid_but_not_all_even() -> Vec<Header<u64>> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AlternatingPowPoa` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | struct AlternatingPowPoa;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Pow` and `Poa` are never constructed
[INFO] [stdout]   --> src/c3_consensus/p5_interleave.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | enum PowOrPoaDigest {
[INFO] [stdout]    |      -------------- variants in this enum
[INFO] [stdout] 17 |     Pow(u64),
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 18 |     Poa(ConsensusAuthority),
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PowOrPoaDigest` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Forked` is never constructed
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | struct Forked<D, Before, After> {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `change_authorities` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:46:4
[INFO] [stdout]    |
[INFO] [stdout] 46 | fn change_authorities(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `change_difficulty` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:55:4
[INFO] [stdout]    |
[INFO] [stdout] 55 | fn change_difficulty(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `even_after_given_height` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:70:4
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pow_to_poa` is never used
[INFO] [stdout]   --> src/c3_consensus/p6_forking.rs:80:4
[INFO] [stdout]    |
[INFO] [stdout] 80 | fn pow_to_poa(
[INFO] [stdout]    |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c4_client/mod.rs:29:6
[INFO] [stdout]    |
[INFO] [stdout] 29 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FullClient` is never constructed
[INFO] [stdout]   --> src/c4_client/mod.rs:52:12
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub struct FullClient<C, SM, FC, P>
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Hash` is never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:22:6
[INFO] [stdout]    |
[INFO] [stdout] 22 | type Hash = u64;
[INFO] [stdout]    |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, `verify_child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:26:8
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl<Digest> Header<Digest> {
[INFO] [stdout]    | --------------------------- associated items in this implementation
[INFO] [stdout] 25 |     /// Returns a new valid genesis header.
[INFO] [stdout] 26 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     fn verify_child(&self, child: &Self) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     fn verify_sub_chain(&self, chain: &[Self]) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Block` is never constructed
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct Block<C: Consensus, SM: StateMachine> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:53:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | impl<C: Consensus, SM: StateMachine> Block<C, SM> {
[INFO] [stdout]    | ------------------------------------------------- associated items in this implementation
[INFO] [stdout] 52 |     /// Returns a new valid genesis block. By convention this block has no extrinsics.
[INFO] [stdout] 53 |     pub fn genesis(genesis_state: &SM::State) -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_empty_chain` is never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:70:4
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn create_empty_chain<C: Consensus, SM: StateMachine>(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/c4_client/p1_data_structure.rs:84:8
[INFO] [stdout]    |
[INFO] [stdout] 80 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>
[INFO] [stdout] 81 | | where
[INFO] [stdout] 82 | |     SM: StateMachine,
[INFO] [stdout]    | |_____________________- associated function in this implementation
[INFO] [stdout] 83 |   {
[INFO] [stdout] 84 |       fn new(genesis_state: SM::State) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ImportBlock` is never used
[INFO] [stdout]   --> src/c4_client/p2_importing_blocks.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub trait ImportBlock<C: Consensus, SM: StateMachine> {
[INFO] [stdout]    |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ForkChoice` is never used
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:18:11
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub trait ForkChoice<C: Consensus> {
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LongestChain` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct LongestChain {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HeaviestChain` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct HeaviestChain {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MostAliceSigs` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:61:12
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub struct MostAliceSigs {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ghost` is never constructed
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:78:12
[INFO] [stdout]    |
[INFO] [stdout] 78 | pub struct Ghost {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `best_block` is never used
[INFO] [stdout]   --> src/c4_client/p3_fork_choice.rs:97:8
[INFO] [stdout]    |
[INFO] [stdout] 95 | impl<C, SM, FC, P> FullClient<C, SM, FC, P> {
[INFO] [stdout]    | ------------------------------------------- method in this implementation
[INFO] [stdout] 96 |     /// Return the hash of the best block currently known to the client
[INFO] [stdout] 97 |     fn best_block(&self) -> u64 {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `TransactionPool` is never used
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub trait TransactionPool<SM: StateMachine> {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `submit_transaction`, `pool_size`, and `pool_contains` are never used
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>           
[INFO] [stdout] 43 | |     where
[INFO] [stdout] 44 | |     SM: StateMachine,
[INFO] [stdout]    | |_____________________- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 48 |       pub fn submit_transaction(&mut self, t: SM::Transition) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |       pub fn pool_size(&self) -> usize {
[INFO] [stdout]    |              ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |       pub fn pool_contains(&self, t: SM::Transition) -> bool {
[INFO] [stdout]    |              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SimplePool` is never constructed
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout] 65 | pub struct SimplePool<SM: StateMachine>(VecDeque<SM::Transition>);
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PriorityPool` is never constructed
[INFO] [stdout]   --> src/c4_client/p4_transaction_pool.rs:96:12
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub struct PriorityPool<T, P: Fn(T) -> u64> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CensoringPool` is never constructed
[INFO] [stdout]    --> src/c4_client/p4_transaction_pool.rs:134:12
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub struct CensoringPool<T, P: Fn(T) -> bool> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `author_and_import_manual_block` and `author_and_import_automatic_block` are never used
[INFO] [stdout]   --> src/c4_client/p5_authoring_blocks.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>
[INFO] [stdout]  8 | |     where
[INFO] [stdout]  9 | |     SM: StateMachine,
[INFO] [stdout]    | |_____________________- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 13 |       pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 19 |       pub fn author_and_import_automatic_block(&self) {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `manually_finalize_block` is never used
[INFO] [stdout]   --> src/c4_client/p6_finality.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | impl<C, SM, FC, P> FullClient<C, SM, FC, P> {
[INFO] [stdout]    | ------------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub fn manually_finalize_block(&mut self, block_hash: u64) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.52s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: diy-blockchain v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] running `Command { std: "docker" "inspect" "25708d9123ed40987527cb6e82e17f46dc4fd82fd3688e3a51f97106b7c1fbc6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "25708d9123ed40987527cb6e82e17f46dc4fd82fd3688e3a51f97106b7c1fbc6", kill_on_drop: false }`
[INFO] [stdout] 25708d9123ed40987527cb6e82e17f46dc4fd82fd3688e3a51f97106b7c1fbc6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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=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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.94.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 5e8ed0a04652a223e4d81f830af04d01ced7aa64e5eddda4f377200222235f02
[INFO] running `Command { std: "docker" "start" "-a" "5e8ed0a04652a223e4d81f830af04d01ced7aa64e5eddda4f377200222235f02", kill_on_drop: false }`
[INFO] [stderr] warning: unused imports: `Block` and `Header`
[INFO] [stderr]  --> src/c2_blockchain/mod.rs:7:25
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub use p6_rich_state::{Block, Header};
[INFO] [stderr]   |                         ^^^^^  ^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::hash`
[INFO] [stderr]  --> src/c2_blockchain/p1_header_chain.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use crate::hash;
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::hash`
[INFO] [stderr]   --> src/c2_blockchain/p2_extrinsic_state.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use crate::hash;
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::hash`
[INFO] [stderr]  --> src/c2_blockchain/p3_consensus.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use crate::hash;
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::hash`
[INFO] [stderr]  --> src/c2_blockchain/p4_batched_extrinsics.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use crate::hash;
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::p3_consensus::THRESHOLD`
[INFO] [stderr]  --> src/c2_blockchain/p4_batched_extrinsics.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use super::p3_consensus::THRESHOLD;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::hash`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:11:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | use crate::hash;
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::p3_consensus::THRESHOLD`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 12 | use super::p3_consensus::THRESHOLD;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::hash`
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | use crate::hash;
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `super::p3_consensus::THRESHOLD`
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 16 | use super::p3_consensus::THRESHOLD;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::marker::PhantomData`
[INFO] [stderr]  --> src/c3_consensus/p4_even_only.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use std::marker::PhantomData;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: this function depends on never type fallback being `()`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:46:1
[INFO] [stderr]    |
[INFO] [stderr] 46 | / fn change_authorities(
[INFO] [stderr] 47 | |     fork_height: u64,
[INFO] [stderr] 48 | |     initial_authorities: Vec<ConsensusAuthority>,
[INFO] [stderr] 49 | |     final_authorities: Vec<ConsensusAuthority>,
[INFO] [stderr] 50 | | ) -> impl Consensus {
[INFO] [stderr]    | |___________________^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stderr]    = help: specify the types explicitly
[INFO] [stderr] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:50:6
[INFO] [stderr]    |
[INFO] [stderr] 50 | ) -> impl Consensus {
[INFO] [stderr]    |      ^^^^^^^^^^^^^^
[INFO] [stderr]    = note: `#[warn(dependency_on_unit_never_type_fallback)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: this function depends on never type fallback being `()`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:55:1
[INFO] [stderr]    |
[INFO] [stderr] 55 | / fn change_difficulty(
[INFO] [stderr] 56 | |     fork_height: u64,
[INFO] [stderr] 57 | |     initial_difficulty: u64,
[INFO] [stderr] 58 | |     final_difficulty: u64,
[INFO] [stderr] 59 | | ) -> impl Consensus {
[INFO] [stderr]    | |___________________^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stderr]    = help: specify the types explicitly
[INFO] [stderr] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:59:6
[INFO] [stderr]    |
[INFO] [stderr] 59 | ) -> impl Consensus {
[INFO] [stderr]    |      ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: this function depends on never type fallback being `()`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:70:1
[INFO] [stderr]    |
[INFO] [stderr] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stderr]    = help: specify the types explicitly
[INFO] [stderr] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:70:70
[INFO] [stderr]    |
[INFO] [stderr] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stderr]    |                                                                      ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: this function depends on never type fallback being `()`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:80:1
[INFO] [stderr]    |
[INFO] [stderr] 80 | / fn pow_to_poa(
[INFO] [stderr] 81 | |     fork_height: u64,
[INFO] [stderr] 82 | |     difficulty: u64,
[INFO] [stderr] 83 | |     authorities: Vec<ConsensusAuthority>,
[INFO] [stderr] 84 | | ) -> impl Consensus {
[INFO] [stderr]    | |___________________^
[INFO] [stderr]    |
[INFO] [stderr]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in Rust 2024 and in a future release in all editions!
[INFO] [stderr]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/never-type-fallback.html>
[INFO] [stderr]    = help: specify the types explicitly
[INFO] [stderr] note: in edition 2024, the requirement `!: Consensus` will fail
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:84:6
[INFO] [stderr]    |
[INFO] [stderr] 84 | ) -> impl Consensus {
[INFO] [stderr]    |      ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `starting_state`
[INFO] [stderr]   --> src/c1_state_machine/p1_switches.rs:17:19
[INFO] [stderr]    |
[INFO] [stderr] 17 |     fn next_state(starting_state: &bool, t: &()) -> bool {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c1_state_machine/p1_switches.rs:17:42
[INFO] [stderr]    |
[INFO] [stderr] 17 |     fn next_state(starting_state: &bool, t: &()) -> bool {
[INFO] [stderr]    |                                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `starting_state`
[INFO] [stderr]   --> src/c1_state_machine/p1_switches.rs:44:19
[INFO] [stderr]    |
[INFO] [stderr] 44 |     fn next_state(starting_state: &TwoSwitches, t: &Toggle) -> TwoSwitches {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c1_state_machine/p1_switches.rs:44:49
[INFO] [stderr]    |
[INFO] [stderr] 44 |     fn next_state(starting_state: &TwoSwitches, t: &Toggle) -> TwoSwitches {
[INFO] [stderr]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `starting_state`
[INFO] [stderr]   --> src/c1_state_machine/p2_laundry_machine.rs:42:19
[INFO] [stderr]    |
[INFO] [stderr] 42 |     fn next_state(starting_state: &ClothesState, t: &ClothesAction) -> ClothesState {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c1_state_machine/p2_laundry_machine.rs:42:50
[INFO] [stderr]    |
[INFO] [stderr] 42 |     fn next_state(starting_state: &ClothesState, t: &ClothesAction) -> ClothesState {
[INFO] [stderr]    |                                                  ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `starting_state`
[INFO] [stderr]   --> src/c1_state_machine/p3_atm.rs:60:19
[INFO] [stderr]    |
[INFO] [stderr] 60 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c1_state_machine/p3_atm.rs:60:49
[INFO] [stderr]    |
[INFO] [stderr] 60 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stderr]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `starting_state`
[INFO] [stderr]   --> src/c1_state_machine/p4_accounted_currency.rs:47:19
[INFO] [stderr]    |
[INFO] [stderr] 47 |     fn next_state(starting_state: &Balances, t: &AccountingTransaction) -> Balances {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c1_state_machine/p4_accounted_currency.rs:47:46
[INFO] [stderr]    |
[INFO] [stderr] 47 |     fn next_state(starting_state: &Balances, t: &AccountingTransaction) -> Balances {
[INFO] [stderr]    |                                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `starting_state`
[INFO] [stderr]   --> src/c1_state_machine/p5_digital_cash.rs:96:19
[INFO] [stderr]    |
[INFO] [stderr] 96 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_starting_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c1_state_machine/p5_digital_cash.rs:96:49
[INFO] [stderr]    |
[INFO] [stderr] 96 |     fn next_state(starting_state: &Self::State, t: &Self::Transition) -> Self::State {
[INFO] [stderr]    |                                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c2_blockchain/p1_header_chain.rs:40:32
[INFO] [stderr]    |
[INFO] [stderr] 40 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `extrinsic`
[INFO] [stderr]   --> src/c2_blockchain/p2_extrinsic_state.rs:38:21
[INFO] [stderr]    |
[INFO] [stderr] 38 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stderr]    |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsic`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c2_blockchain/p2_extrinsic_state.rs:50:32
[INFO] [stderr]    |
[INFO] [stderr] 50 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `n`
[INFO] [stderr]   --> src/c2_blockchain/p2_extrinsic_state.rs:58:22
[INFO] [stderr]    |
[INFO] [stderr] 58 | fn build_valid_chain(n: u64) -> Vec<Header> {
[INFO] [stderr]    |                      ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `extrinsic`
[INFO] [stderr]   --> src/c2_blockchain/p3_consensus.rs:44:21
[INFO] [stderr]    |
[INFO] [stderr] 44 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stderr]    |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsic`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c2_blockchain/p3_consensus.rs:52:32
[INFO] [stderr]    |
[INFO] [stderr] 52 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c2_blockchain/p3_consensus.rs:64:37
[INFO] [stderr]    |
[INFO] [stderr] 64 |     fn verify_sub_chain_even(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |                                     ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c2_blockchain/p3_consensus.rs:70:36
[INFO] [stderr]    |
[INFO] [stderr] 70 |     fn verify_sub_chain_odd(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `extrinsics_root`
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:42:25
[INFO] [stderr]    |
[INFO] [stderr] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stderr]    |                         ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `state`
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:42:48
[INFO] [stderr]    |
[INFO] [stderr] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stderr]    |                                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `child`
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:53:28
[INFO] [stderr]    |
[INFO] [stderr] 53 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stderr]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:64:32
[INFO] [stderr]    |
[INFO] [stderr] 64 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `extrinsics`
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:89:25
[INFO] [stderr]    |
[INFO] [stderr] 89 |     pub fn child(&self, extrinsics: Vec<u64>) -> Self {
[INFO] [stderr]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:96:36
[INFO] [stderr]    |
[INFO] [stderr] 96 |     pub fn verify_sub_chain(&self, chain: &[Block]) -> bool {
[INFO] [stderr]    |                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent`
[INFO] [stderr]    --> src/c2_blockchain/p4_batched_extrinsics.rs:109:48
[INFO] [stderr]     |
[INFO] [stderr] 109 | fn build_invalid_child_block_with_valid_header(parent: &Header) -> Block {
[INFO] [stderr]     |                                                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `candidate_chains`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:34:23
[INFO] [stderr]    |
[INFO] [stderr] 34 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stderr]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain_1`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:43:30
[INFO] [stderr]    |
[INFO] [stderr] 43 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stderr]    |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain_2`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:43:50
[INFO] [stderr]    |
[INFO] [stderr] 43 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stderr]    |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `candidate_chains`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:47:23
[INFO] [stderr]    |
[INFO] [stderr] 47 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stderr]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `block`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:69:20
[INFO] [stderr]    |
[INFO] [stderr] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stderr]    |                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_block`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `threshold`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:69:39
[INFO] [stderr]    |
[INFO] [stderr] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stderr]    |                                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_threshold`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain_1`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:74:30
[INFO] [stderr]    |
[INFO] [stderr] 74 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stderr]    |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain_2`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:74:50
[INFO] [stderr]    |
[INFO] [stderr] 74 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stderr]    |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `candidate_chains`
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:78:23
[INFO] [stderr]    |
[INFO] [stderr] 78 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stderr]    |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain_1`
[INFO] [stderr]    --> src/c2_blockchain/p5_fork_choice.rs:100:30
[INFO] [stderr]     |
[INFO] [stderr] 100 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stderr]     |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_1`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain_2`
[INFO] [stderr]    --> src/c2_blockchain/p5_fork_choice.rs:100:50
[INFO] [stderr]     |
[INFO] [stderr] 100 |     fn first_chain_is_better(chain_1: &[Header], chain_2: &[Header]) -> bool {
[INFO] [stderr]     |                                                  ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_chain_2`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `candidate_chains`
[INFO] [stderr]    --> src/c2_blockchain/p5_fork_choice.rs:104:23
[INFO] [stderr]     |
[INFO] [stderr] 104 |     fn best_chain<'a>(candidate_chains: &[&'a [Header]]) -> &'a [Header] {
[INFO] [stderr]     |                       ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_candidate_chains`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `genesis_state_root`
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:49:16
[INFO] [stderr]    |
[INFO] [stderr] 49 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stderr]    |                ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state_root`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `extrinsics_root`
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:57:21
[INFO] [stderr]    |
[INFO] [stderr] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stderr]    |                     ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `state_root`
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:57:44
[INFO] [stderr]    |
[INFO] [stderr] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stderr]    |                                            ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_state_root`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `child`
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:62:28
[INFO] [stderr]    |
[INFO] [stderr] 62 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stderr]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:67:32
[INFO] [stderr]    |
[INFO] [stderr] 67 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `genesis_state`
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:91:20
[INFO] [stderr]    |
[INFO] [stderr] 91 |     pub fn genesis(genesis_state: &State) -> Self {
[INFO] [stderr]    |                    ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `pre_state`
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:96:25
[INFO] [stderr]    |
[INFO] [stderr] 96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stderr]    |                         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `extrinsics`
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:96:44
[INFO] [stderr]    |
[INFO] [stderr] 96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stderr]    |                                            ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `pre_state`
[INFO] [stderr]    --> src/c2_blockchain/p6_rich_state.rs:105:36
[INFO] [stderr]     |
[INFO] [stderr] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stderr]     |                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]    --> src/c2_blockchain/p6_rich_state.rs:105:55
[INFO] [stderr]     |
[INFO] [stderr] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stderr]     |                                                       ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent`
[INFO] [stderr]    --> src/c2_blockchain/p6_rich_state.rs:121:48
[INFO] [stderr]     |
[INFO] [stderr] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stderr]     |                                                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `pre_state`
[INFO] [stderr]    --> src/c2_blockchain/p6_rich_state.rs:121:65
[INFO] [stderr]     |
[INFO] [stderr] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stderr]     |                                                                 ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c3_consensus/p1_pow.rs:21:42
[INFO] [stderr]    |
[INFO] [stderr] 21 |     fn validate(&self, _: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `partial_header`
[INFO] [stderr]   --> src/c3_consensus/p1_pow.rs:27:38
[INFO] [stderr]    |
[INFO] [stderr] 27 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stderr]    |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c3_consensus/p2_dictator.rs:23:42
[INFO] [stderr]    |
[INFO] [stderr] 23 |     fn validate(&self, _: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `partial_header`
[INFO] [stderr]   --> src/c3_consensus/p2_dictator.rs:28:38
[INFO] [stderr]    |
[INFO] [stderr] 28 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stderr]    |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:22:24
[INFO] [stderr]    |
[INFO] [stderr] 22 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:22:54
[INFO] [stderr]    |
[INFO] [stderr] 22 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:28:9
[INFO] [stderr]    |
[INFO] [stderr] 28 |         parent_digest: &Self::Digest,
[INFO] [stderr]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `partial_header`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:29:9
[INFO] [stderr]    |
[INFO] [stderr] 29 |         partial_header: Header<()>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:45:24
[INFO] [stderr]    |
[INFO] [stderr] 45 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:45:54
[INFO] [stderr]    |
[INFO] [stderr] 45 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:51:9
[INFO] [stderr]    |
[INFO] [stderr] 51 |         parent_digest: &Self::Digest,
[INFO] [stderr]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `partial_header`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:52:9
[INFO] [stderr]    |
[INFO] [stderr] 52 |         partial_header: Header<()>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:82:24
[INFO] [stderr]    |
[INFO] [stderr] 82 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:82:54
[INFO] [stderr]    |
[INFO] [stderr] 82 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:88:9
[INFO] [stderr]    |
[INFO] [stderr] 88 |         parent_digest: &Self::Digest,
[INFO] [stderr]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `partial_header`
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:89:9
[INFO] [stderr]    |
[INFO] [stderr] 89 |         partial_header: Header<()>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p4_even_only.rs:19:24
[INFO] [stderr]    |
[INFO] [stderr] 19 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c3_consensus/p4_even_only.rs:19:54
[INFO] [stderr]    |
[INFO] [stderr] 19 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p4_even_only.rs:25:9
[INFO] [stderr]    |
[INFO] [stderr] 25 |         parent_digest: &Self::Digest,
[INFO] [stderr]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `partial_header`
[INFO] [stderr]   --> src/c3_consensus/p4_even_only.rs:26:9
[INFO] [stderr]    |
[INFO] [stderr] 26 |         partial_header: Header<()>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p5_interleave.rs:52:24
[INFO] [stderr]    |
[INFO] [stderr] 52 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c3_consensus/p5_interleave.rs:52:54
[INFO] [stderr]    |
[INFO] [stderr] 52 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p5_interleave.rs:58:9
[INFO] [stderr]    |
[INFO] [stderr] 58 |         parent_digest: &Self::Digest,
[INFO] [stderr]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `partial_header`
[INFO] [stderr]   --> src/c3_consensus/p5_interleave.rs:59:9
[INFO] [stderr]    |
[INFO] [stderr] 59 |         partial_header: Header<()>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:31:24
[INFO] [stderr]    |
[INFO] [stderr] 31 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                        ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:31:54
[INFO] [stderr]    |
[INFO] [stderr] 31 |     fn validate(&self, parent_digest: &Self::Digest, header: &Header<Self::Digest>) -> bool {
[INFO] [stderr]    |                                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:37:9
[INFO] [stderr]    |
[INFO] [stderr] 37 |         parent_digest: &Self::Digest,
[INFO] [stderr]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `partial_header`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:38:9
[INFO] [stderr]    |
[INFO] [stderr] 38 |         partial_header: Header<()>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `fork_height`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:47:5
[INFO] [stderr]    |
[INFO] [stderr] 47 |     fork_height: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `initial_authorities`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:48:5
[INFO] [stderr]    |
[INFO] [stderr] 48 |     initial_authorities: Vec<ConsensusAuthority>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_initial_authorities`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `final_authorities`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:49:5
[INFO] [stderr]    |
[INFO] [stderr] 49 |     final_authorities: Vec<ConsensusAuthority>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_authorities`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `fork_height`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:56:5
[INFO] [stderr]    |
[INFO] [stderr] 56 |     fork_height: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `initial_difficulty`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:57:5
[INFO] [stderr]    |
[INFO] [stderr] 57 |     initial_difficulty: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_initial_difficulty`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `final_difficulty`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:58:5
[INFO] [stderr]    |
[INFO] [stderr] 58 |     final_difficulty: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_final_difficulty`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `fork_height`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:70:49
[INFO] [stderr]    |
[INFO] [stderr] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stderr]    |                                                 ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `fork_height`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:81:5
[INFO] [stderr]    |
[INFO] [stderr] 81 |     fork_height: u64,
[INFO] [stderr]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fork_height`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `difficulty`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:82:5
[INFO] [stderr]    |
[INFO] [stderr] 82 |     difficulty: u64,
[INFO] [stderr]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_difficulty`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `authorities`
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:83:5
[INFO] [stderr]    |
[INFO] [stderr] 83 |     authorities: Vec<ConsensusAuthority>,
[INFO] [stderr]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_authorities`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_digest`
[INFO] [stderr]   --> src/c3_consensus/mod.rs:76:9
[INFO] [stderr]    |
[INFO] [stderr] 76 |         parent_digest: &Self::Digest,
[INFO] [stderr]    |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_digest`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c3_consensus/mod.rs:77:9
[INFO] [stderr]    |
[INFO] [stderr] 77 |         chain: &[Header<Self::Digest>],
[INFO] [stderr]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `partial_header`
[INFO] [stderr]    --> src/c3_consensus/mod.rs:101:38
[INFO] [stderr]     |
[INFO] [stderr] 101 |     fn seal(&self, _: &Self::Digest, partial_header: Header<()>) -> Option<Header<Self::Digest>> {
[INFO] [stderr]     |                                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_partial_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `genesis_state_root`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:26:16
[INFO] [stderr]    |
[INFO] [stderr] 26 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stderr]    |                ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state_root`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `state_root`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:31:21
[INFO] [stderr]    |
[INFO] [stderr] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stderr]    |                     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_state_root`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `extrinsics_root`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:31:39
[INFO] [stderr]    |
[INFO] [stderr] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stderr]    |                                       ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics_root`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `child`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:36:28
[INFO] [stderr]    |
[INFO] [stderr] 36 |     fn verify_child(&self, child: &Self) -> bool {
[INFO] [stderr]    |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_child`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:41:32
[INFO] [stderr]    |
[INFO] [stderr] 41 |     fn verify_sub_chain(&self, chain: &[Self]) -> bool {
[INFO] [stderr]    |                                ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `genesis_state`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:53:20
[INFO] [stderr]    |
[INFO] [stderr] 53 |     pub fn genesis(genesis_state: &SM::State) -> Self {
[INFO] [stderr]    |                    ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `pre_state`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:58:25
[INFO] [stderr]    |
[INFO] [stderr] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stderr]    |                         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `extrinsics`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:58:48
[INFO] [stderr]    |
[INFO] [stderr] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stderr]    |                                                ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_extrinsics`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `pre_state`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:63:36
[INFO] [stderr]    |
[INFO] [stderr] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stderr]    |                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pre_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `chain`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:63:59
[INFO] [stderr]    |
[INFO] [stderr] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stderr]    |                                                           ^^^^^ help: if this is intentional, prefix it with an underscore: `_chain`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `n`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:71:5
[INFO] [stderr]    |
[INFO] [stderr] 71 |     n: u64,
[INFO] [stderr]    |     ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `genesis_state`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:72:5
[INFO] [stderr]    |
[INFO] [stderr] 72 |     genesis_state: &SM::State,
[INFO] [stderr]    |     ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `genesis_state`
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:84:12
[INFO] [stderr]    |
[INFO] [stderr] 84 |     fn new(genesis_state: SM::State) -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_genesis_state`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `block_hash`
[INFO] [stderr]   --> src/c4_client/p2_importing_blocks.rs:41:25
[INFO] [stderr]    |
[INFO] [stderr] 41 |     fn get_block(&self, block_hash: u64) -> Option<Block<C, SM>> {
[INFO] [stderr]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `block_hash`
[INFO] [stderr]   --> src/c4_client/p2_importing_blocks.rs:45:25
[INFO] [stderr]    |
[INFO] [stderr] 45 |     fn get_state(&self, block_hash: u64) -> Option<<SM as StateMachine>::State> {
[INFO] [stderr]    |                         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `block_hash`
[INFO] [stderr]   --> src/c4_client/p2_importing_blocks.rs:49:23
[INFO] [stderr]    |
[INFO] [stderr] 49 |     fn is_leaf(&self, block_hash: u64) -> Option<bool> {
[INFO] [stderr]    |                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:32:26
[INFO] [stderr]    |
[INFO] [stderr] 32 |     fn best_block(&self, header: Header<C::Digest>) -> Option<u64> {
[INFO] [stderr]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:36:31
[INFO] [stderr]    |
[INFO] [stderr] 36 |     fn import_hook(&mut self, header: Header<C::Digest>) {
[INFO] [stderr]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:49:26
[INFO] [stderr]    |
[INFO] [stderr] 49 |     fn best_block(&self, header: Header<u64>) -> Option<u64> {
[INFO] [stderr]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:53:31
[INFO] [stderr]    |
[INFO] [stderr] 53 |     fn import_hook(&mut self, header: Header<u64>) {
[INFO] [stderr]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:66:26
[INFO] [stderr]    |
[INFO] [stderr] 66 |     fn best_block(&self, header: Header<ConsensusAuthority>) -> Option<u64> {
[INFO] [stderr]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:70:31
[INFO] [stderr]    |
[INFO] [stderr] 70 |     fn import_hook(&mut self, header: Header<ConsensusAuthority>) {
[INFO] [stderr]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:83:26
[INFO] [stderr]    |
[INFO] [stderr] 83 |     fn best_block(&self, header: Header<u64>) -> Option<u64> {
[INFO] [stderr]    |                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `header`
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:87:31
[INFO] [stderr]    |
[INFO] [stderr] 87 |     fn import_hook(&mut self, header: Header<u64>) {
[INFO] [stderr]    |                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_header`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c4_client/p4_transaction_pool.rs:48:42
[INFO] [stderr]    |
[INFO] [stderr] 48 |     pub fn submit_transaction(&mut self, t: SM::Transition) {
[INFO] [stderr]    |                                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c4_client/p4_transaction_pool.rs:59:33
[INFO] [stderr]    |
[INFO] [stderr] 59 |     pub fn pool_contains(&self, t: SM::Transition) -> bool {
[INFO] [stderr]    |                                 ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c4_client/p4_transaction_pool.rs:68:30
[INFO] [stderr]    |
[INFO] [stderr] 68 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stderr]    |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c4_client/p4_transaction_pool.rs:72:26
[INFO] [stderr]    |
[INFO] [stderr] 72 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stderr]    |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]   --> src/c4_client/p4_transaction_pool.rs:80:24
[INFO] [stderr]    |
[INFO] [stderr] 80 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stderr]    |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]    --> src/c4_client/p4_transaction_pool.rs:110:30
[INFO] [stderr]     |
[INFO] [stderr] 110 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stderr]     |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]    --> src/c4_client/p4_transaction_pool.rs:114:26
[INFO] [stderr]     |
[INFO] [stderr] 114 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stderr]     |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]    --> src/c4_client/p4_transaction_pool.rs:122:24
[INFO] [stderr]     |
[INFO] [stderr] 122 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stderr]     |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]    --> src/c4_client/p4_transaction_pool.rs:145:30
[INFO] [stderr]     |
[INFO] [stderr] 145 |     fn try_insert(&mut self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stderr]     |                              ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]    --> src/c4_client/p4_transaction_pool.rs:149:26
[INFO] [stderr]     |
[INFO] [stderr] 149 |     fn remove(&mut self, t: <SM as StateMachine>::Transition) {
[INFO] [stderr]     |                          ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `t`
[INFO] [stderr]    --> src/c4_client/p4_transaction_pool.rs:157:24
[INFO] [stderr]     |
[INFO] [stderr] 157 |     fn contains(&self, t: <SM as StateMachine>::Transition) -> bool {
[INFO] [stderr]     |                        ^ help: if this is intentional, prefix it with an underscore: `_t`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `transactions`
[INFO] [stderr]   --> src/c4_client/p5_authoring_blocks.rs:13:54
[INFO] [stderr]    |
[INFO] [stderr] 13 |     pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stderr]    |                                                      ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_transactions`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parent_hash`
[INFO] [stderr]   --> src/c4_client/p5_authoring_blocks.rs:13:89
[INFO] [stderr]    |
[INFO] [stderr] 13 |     pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stderr]    |                                                                                         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_parent_hash`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `block_hash`
[INFO] [stderr]   --> src/c4_client/p6_finality.rs:13:47
[INFO] [stderr]    |
[INFO] [stderr] 13 |     pub fn manually_finalize_block(&mut self, block_hash: u64) -> bool {
[INFO] [stderr]    |                                               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_block_hash`
[INFO] [stderr] 
[INFO] [stderr] warning: function `hash` is never used
[INFO] [stderr]   --> src/lib.rs:10:4
[INFO] [stderr]    |
[INFO] [stderr] 10 | fn hash<T: Hash>(t: &T) -> u64 {
[INFO] [stderr]    |    ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait `StateMachine` is never used
[INFO] [stderr]   --> src/c1_state_machine/mod.rs:12:11
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub trait StateMachine {
[INFO] [stderr]    |           ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `User` is never used
[INFO] [stderr]   --> src/c1_state_machine/mod.rs:32:10
[INFO] [stderr]    |
[INFO] [stderr] 32 | pub enum User {
[INFO] [stderr]    |          ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `LightSwitch` is never constructed
[INFO] [stderr]  --> src/c1_state_machine/p1_switches.rs:9:12
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub struct LightSwitch;
[INFO] [stderr]   |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `WeirdSwitchMachine` is never constructed
[INFO] [stderr]   --> src/c1_state_machine/p1_switches.rs:24:12
[INFO] [stderr]    |
[INFO] [stderr] 24 | pub struct WeirdSwitchMachine;
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `TwoSwitches` is never constructed
[INFO] [stderr]   --> src/c1_state_machine/p1_switches.rs:28:12
[INFO] [stderr]    |
[INFO] [stderr] 28 | pub struct TwoSwitches {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `Toggle` is never used
[INFO] [stderr]   --> src/c1_state_machine/p1_switches.rs:34:10
[INFO] [stderr]    |
[INFO] [stderr] 34 | pub enum Toggle {
[INFO] [stderr]    |          ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ClothesMachine` is never constructed
[INFO] [stderr]  --> src/c1_state_machine/p2_laundry_machine.rs:9:12
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub struct ClothesMachine;
[INFO] [stderr]   |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `ClothesState` is never used
[INFO] [stderr]   --> src/c1_state_machine/p2_laundry_machine.rs:13:10
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub enum ClothesState {
[INFO] [stderr]    |          ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `ClothesAction` is never used
[INFO] [stderr]   --> src/c1_state_machine/p2_laundry_machine.rs:27:10
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub enum ClothesAction {
[INFO] [stderr]    |          ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `Key` is never used
[INFO] [stderr]  --> src/c1_state_machine/p3_atm.rs:9:10
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub enum Key {
[INFO] [stderr]   |          ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `Action` is never used
[INFO] [stderr]   --> src/c1_state_machine/p3_atm.rs:18:10
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub enum Action {
[INFO] [stderr]    |          ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `Auth` is never used
[INFO] [stderr]   --> src/c1_state_machine/p3_atm.rs:28:6
[INFO] [stderr]    |
[INFO] [stderr] 28 | enum Auth {
[INFO] [stderr]    |      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Atm` is never constructed
[INFO] [stderr]   --> src/c1_state_machine/p3_atm.rs:46:12
[INFO] [stderr]    |
[INFO] [stderr] 46 | pub struct Atm {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `AccountedCurrency` is never constructed
[INFO] [stderr]   --> src/c1_state_machine/p4_accounted_currency.rs:16:12
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub struct AccountedCurrency;
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Balances` is never used
[INFO] [stderr]   --> src/c1_state_machine/p4_accounted_currency.rs:24:6
[INFO] [stderr]    |
[INFO] [stderr] 24 | type Balances = HashMap<User, u64>;
[INFO] [stderr]    |      ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `AccountingTransaction` is never used
[INFO] [stderr]   --> src/c1_state_machine/p4_accounted_currency.rs:27:10
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub enum AccountingTransaction {
[INFO] [stderr]    |          ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `DigitalCashSystem` is never constructed
[INFO] [stderr]   --> src/c1_state_machine/p5_digital_cash.rs:11:12
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub struct DigitalCashSystem;
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Bill` is never constructed
[INFO] [stderr]   --> src/c1_state_machine/p5_digital_cash.rs:17:12
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub struct Bill {
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `State` is never constructed
[INFO] [stderr]   --> src/c1_state_machine/p5_digital_cash.rs:26:12
[INFO] [stderr]    |
[INFO] [stderr] 26 | pub struct State {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `set_serial`, `next_serial`, `increment_serial`, and `add_bill` are never used
[INFO] [stderr]   --> src/c1_state_machine/p5_digital_cash.rs:34:12
[INFO] [stderr]    |
[INFO] [stderr] 33 | impl State {
[INFO] [stderr]    | ---------- associated items in this implementation
[INFO] [stderr] 34 |     pub fn new() -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 41 |     pub fn set_serial(&mut self, serial: u64) {
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 45 |     pub fn next_serial(&self) -> u64 {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 49 |     fn increment_serial(&mut self) {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 53 |     fn add_bill(&mut self, elem: Bill) {
[INFO] [stderr]    |        ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `CashTransaction` is never used
[INFO] [stderr]   --> src/c1_state_machine/p5_digital_cash.rs:77:10
[INFO] [stderr]    |
[INFO] [stderr] 77 | pub enum CashTransaction {
[INFO] [stderr]    |          ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `State` is never constructed
[INFO] [stderr]   --> src/c1_state_machine/p6_open_ended.rs:25:12
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub struct State {}
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `Transition` is never used
[INFO] [stderr]   --> src/c1_state_machine/p6_open_ended.rs:27:10
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub enum Transition {}
[INFO] [stderr]    |          ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Hash` is never used
[INFO] [stderr]   --> src/c2_blockchain/p1_header_chain.rs:10:6
[INFO] [stderr]    |
[INFO] [stderr] 10 | type Hash = u64;
[INFO] [stderr]    |      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Header` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p1_header_chain.rs:14:12
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub struct Header {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stderr]   --> src/c2_blockchain/p1_header_chain.rs:27:8
[INFO] [stderr]    |
[INFO] [stderr] 25 | impl Header {
[INFO] [stderr]    | ----------- associated items in this implementation
[INFO] [stderr] 26 |     /// Returns a new valid genesis header.
[INFO] [stderr] 27 |     fn genesis() -> Self {
[INFO] [stderr]    |        ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 32 |     fn child(&self) -> Self {
[INFO] [stderr]    |        ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 40 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_valid_chain_length_5` is never used
[INFO] [stderr]   --> src/c2_blockchain/p1_header_chain.rs:48:4
[INFO] [stderr]    |
[INFO] [stderr] 48 | fn build_valid_chain_length_5() -> Vec<Header> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_an_invalid_chain` is never used
[INFO] [stderr]   --> src/c2_blockchain/p1_header_chain.rs:55:4
[INFO] [stderr]    |
[INFO] [stderr] 55 | fn build_an_invalid_chain() -> Vec<Header> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Hash` is never used
[INFO] [stderr]   --> src/c2_blockchain/p2_extrinsic_state.rs:14:6
[INFO] [stderr]    |
[INFO] [stderr] 14 | type Hash = u64;
[INFO] [stderr]    |      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Header` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p2_extrinsic_state.rs:20:12
[INFO] [stderr]    |
[INFO] [stderr] 20 | pub struct Header {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stderr]   --> src/c2_blockchain/p2_extrinsic_state.rs:33:8
[INFO] [stderr]    |
[INFO] [stderr] 31 | impl Header {
[INFO] [stderr]    | ----------- associated items in this implementation
[INFO] [stderr] 32 |     /// Returns a new valid genesis header.
[INFO] [stderr] 33 |     fn genesis() -> Self {
[INFO] [stderr]    |        ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 38 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stderr]    |        ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 50 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_valid_chain` is never used
[INFO] [stderr]   --> src/c2_blockchain/p2_extrinsic_state.rs:58:4
[INFO] [stderr]    |
[INFO] [stderr] 58 | fn build_valid_chain(n: u64) -> Vec<Header> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_an_invalid_chain` is never used
[INFO] [stderr]   --> src/c2_blockchain/p2_extrinsic_state.rs:72:4
[INFO] [stderr]    |
[INFO] [stderr] 72 | fn build_an_invalid_chain() -> Vec<Header> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_forked_chain` is never used
[INFO] [stderr]   --> src/c2_blockchain/p2_extrinsic_state.rs:87:4
[INFO] [stderr]    |
[INFO] [stderr] 87 | fn build_forked_chain() -> (Vec<Header>, Vec<Header>) {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Hash` is never used
[INFO] [stderr]   --> src/c2_blockchain/p3_consensus.rs:11:6
[INFO] [stderr]    |
[INFO] [stderr] 11 | type Hash = u64;
[INFO] [stderr]    |      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `THRESHOLD` is never used
[INFO] [stderr]   --> src/c2_blockchain/p3_consensus.rs:16:11
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub const THRESHOLD: u64 = u64::max_value() / 100;
[INFO] [stderr]    |           ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `FORK_HEIGHT` is never used
[INFO] [stderr]   --> src/c2_blockchain/p3_consensus.rs:20:7
[INFO] [stderr]    |
[INFO] [stderr] 20 | const FORK_HEIGHT: u64 = 2;
[INFO] [stderr]    |       ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Header` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p3_consensus.rs:27:12
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub struct Header {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `genesis`, `child`, `verify_sub_chain`, `verify_sub_chain_even`, and `verify_sub_chain_odd` are never used
[INFO] [stderr]   --> src/c2_blockchain/p3_consensus.rs:39:8
[INFO] [stderr]    |
[INFO] [stderr] 37 | impl Header {
[INFO] [stderr]    | ----------- associated items in this implementation
[INFO] [stderr] 38 |     /// Returns a new valid genesis header.
[INFO] [stderr] 39 |     fn genesis() -> Self {
[INFO] [stderr]    |        ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 44 |     fn child(&self, extrinsic: u64) -> Self {
[INFO] [stderr]    |        ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 52 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 64 |     fn verify_sub_chain_even(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 70 |     fn verify_sub_chain_odd(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_contentious_forked_chain` is never used
[INFO] [stderr]   --> src/c2_blockchain/p3_consensus.rs:91:4
[INFO] [stderr]    |
[INFO] [stderr] 91 | fn build_contentious_forked_chain() -> (Vec<Header>, Vec<Header>, Vec<Header>) {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Hash` is never used
[INFO] [stderr]  --> src/c2_blockchain/p4_batched_extrinsics.rs:6:6
[INFO] [stderr]   |
[INFO] [stderr] 6 | type Hash = u64;
[INFO] [stderr]   |      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Header` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:16:12
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub struct Header {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `genesis`, `child`, `verify_child`, and `verify_sub_chain` are never used
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:35:12
[INFO] [stderr]    |
[INFO] [stderr] 33 | impl Header {
[INFO] [stderr]    | ----------- associated items in this implementation
[INFO] [stderr] 34 |     /// Returns a new valid genesis header.
[INFO] [stderr] 35 |     pub fn genesis() -> Self {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 42 |     pub fn child(&self, extrinsics_root: Hash, state: u64) -> Self {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 53 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 64 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Block` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:71:12
[INFO] [stderr]    |
[INFO] [stderr] 71 | pub struct Block {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:83:12
[INFO] [stderr]    |
[INFO] [stderr] 81 | impl Block {
[INFO] [stderr]    | ---------- associated items in this implementation
[INFO] [stderr] 82 |     /// Returns a new valid genesis block. By convention this block has no extrinsics.
[INFO] [stderr] 83 |     pub fn genesis() -> Self {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 89 |     pub fn child(&self, extrinsics: Vec<u64>) -> Self {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 96 |     pub fn verify_sub_chain(&self, chain: &[Block]) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_invalid_child_block_with_valid_header` is never used
[INFO] [stderr]    --> src/c2_blockchain/p4_batched_extrinsics.rs:109:4
[INFO] [stderr]     |
[INFO] [stderr] 109 | fn build_invalid_child_block_with_valid_header(parent: &Header) -> Block {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `ForkChoice` is never used
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:17:11
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub trait ForkChoice {
[INFO] [stderr]    |           ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `LongestChainRule` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:40:12
[INFO] [stderr]    |
[INFO] [stderr] 40 | pub struct LongestChainRule;
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `HeaviestChainRule` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:63:12
[INFO] [stderr]    |
[INFO] [stderr] 63 | pub struct HeaviestChainRule;
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `mine_extra_hard` is never used
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:69:4
[INFO] [stderr]    |
[INFO] [stderr] 69 | fn mine_extra_hard(block: &mut Block, threshold: u64) {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `MostBlocksWithEvenHash` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p5_fork_choice.rs:97:12
[INFO] [stderr]    |
[INFO] [stderr] 97 | pub struct MostBlocksWithEvenHash;
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_fork_one_side_longer_other_side_heavier` is never used
[INFO] [stderr]    --> src/c2_blockchain/p5_fork_choice.rs:132:4
[INFO] [stderr]     |
[INFO] [stderr] 132 | fn create_fork_one_side_longer_other_side_heavier() -> (Vec<Header>, Vec<Header>, Vec<Header>) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Hash` is never used
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:14:6
[INFO] [stderr]    |
[INFO] [stderr] 14 | type Hash = u64;
[INFO] [stderr]    |      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `State` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:21:12
[INFO] [stderr]    |
[INFO] [stderr] 21 | pub struct State {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Header` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:31:12
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub struct Header {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `genesis`, `child`, `verify_child`, and `verify_sub_chain` are never used
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:49:8
[INFO] [stderr]    |
[INFO] [stderr] 47 | impl Header {
[INFO] [stderr]    | ----------- associated items in this implementation
[INFO] [stderr] 48 |     /// Returns a new valid genesis header.
[INFO] [stderr] 49 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stderr]    |        ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 57 |     fn child(&self, extrinsics_root: Hash, state_root: Hash) -> Self {
[INFO] [stderr]    |        ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 62 |     fn verify_child(&self, child: &Header) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 67 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Block` is never constructed
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:74:12
[INFO] [stderr]    |
[INFO] [stderr] 74 | pub struct Block {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stderr]    --> src/c2_blockchain/p6_rich_state.rs:91:12
[INFO] [stderr]     |
[INFO] [stderr]  89 | impl Block {
[INFO] [stderr]     | ---------- associated items in this implementation
[INFO] [stderr]  90 |     /// Returns a new valid genesis block. By convention this block has no extrinsics.
[INFO] [stderr]  91 |     pub fn genesis(genesis_state: &State) -> Self {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  96 |     pub fn child(&self, pre_state: &State, extrinsics: Vec<u64>) -> Self {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 105 |     pub fn verify_sub_chain(&self, pre_state: &State, chain: &[Block]) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `build_invalid_child_block_with_valid_header` is never used
[INFO] [stderr]    --> src/c2_blockchain/p6_rich_state.rs:121:4
[INFO] [stderr]     |
[INFO] [stderr] 121 | fn build_invalid_child_block_with_valid_header(parent: &Header, pre_state: &State) -> Block {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Hash` is never used
[INFO] [stderr]   --> src/c3_consensus/mod.rs:16:6
[INFO] [stderr]    |
[INFO] [stderr] 16 | type Hash = u64;
[INFO] [stderr]    |      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Header` is never constructed
[INFO] [stderr]   --> src/c3_consensus/mod.rs:27:12
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub struct Header<Digest> {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `Consensus` is never used
[INFO] [stderr]   --> src/c3_consensus/mod.rs:38:11
[INFO] [stderr]    |
[INFO] [stderr] 38 | pub trait Consensus {
[INFO] [stderr]    |           ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Alice`, `Bob`, and `Charlie` are never constructed
[INFO] [stderr]    --> src/c3_consensus/mod.rs:110:5
[INFO] [stderr]     |
[INFO] [stderr] 109 | pub enum ConsensusAuthority {
[INFO] [stderr]     |          ------------------ variants in this enum
[INFO] [stderr] 110 |     Alice,
[INFO] [stderr]     |     ^^^^^
[INFO] [stderr] 111 |     Bob,
[INFO] [stderr]     |     ^^^
[INFO] [stderr] 112 |     Charlie,
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `ConsensusAuthority` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Pow` is never constructed
[INFO] [stderr]   --> src/c3_consensus/p1_pow.rs:12:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct Pow {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `moderate_difficulty_pow` is never used
[INFO] [stderr]   --> src/c3_consensus/p1_pow.rs:34:8
[INFO] [stderr]    |
[INFO] [stderr] 34 | pub fn moderate_difficulty_pow() -> Pow {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `trivial_always_valid_pow` is never used
[INFO] [stderr]   --> src/c3_consensus/p1_pow.rs:40:8
[INFO] [stderr]    |
[INFO] [stderr] 40 | pub fn trivial_always_valid_pow() -> Pow {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `DictatorConsensus` is never constructed
[INFO] [stderr]   --> src/c3_consensus/p2_dictator.rs:15:8
[INFO] [stderr]    |
[INFO] [stderr] 15 | struct DictatorConsensus {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SimplePoa` is never constructed
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:15:12
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub struct SimplePoa {
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PoaRoundRobinByHeight` is never constructed
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:38:8
[INFO] [stderr]    |
[INFO] [stderr] 38 | struct PoaRoundRobinByHeight {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PoaRoundRobinBySlot` is never constructed
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:66:8
[INFO] [stderr]    |
[INFO] [stderr] 66 | struct PoaRoundRobinBySlot {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SlotDigest` is never constructed
[INFO] [stderr]   --> src/c3_consensus/p3_poa.rs:74:8
[INFO] [stderr]    |
[INFO] [stderr] 74 | struct SlotDigest {
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `EvenOnly` is never constructed
[INFO] [stderr]   --> src/c3_consensus/p4_even_only.rs:11:8
[INFO] [stderr]    |
[INFO] [stderr] 11 | struct EvenOnly<Inner: Consensus> {
[INFO] [stderr]    |        ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `almost_valid_but_not_all_even` is never used
[INFO] [stderr]   --> src/c3_consensus/p4_even_only.rs:35:4
[INFO] [stderr]    |
[INFO] [stderr] 35 | fn almost_valid_but_not_all_even() -> Vec<Header<u64>> {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `AlternatingPowPoa` is never constructed
[INFO] [stderr]   --> src/c3_consensus/p5_interleave.rs:10:8
[INFO] [stderr]    |
[INFO] [stderr] 10 | struct AlternatingPowPoa;
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Pow` and `Poa` are never constructed
[INFO] [stderr]   --> src/c3_consensus/p5_interleave.rs:17:5
[INFO] [stderr]    |
[INFO] [stderr] 16 | enum PowOrPoaDigest {
[INFO] [stderr]    |      -------------- variants in this enum
[INFO] [stderr] 17 |     Pow(u64),
[INFO] [stderr]    |     ^^^
[INFO] [stderr] 18 |     Poa(ConsensusAuthority),
[INFO] [stderr]    |     ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `PowOrPoaDigest` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Forked` is never constructed
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:15:8
[INFO] [stderr]    |
[INFO] [stderr] 15 | struct Forked<D, Before, After> {
[INFO] [stderr]    |        ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `change_authorities` is never used
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:46:4
[INFO] [stderr]    |
[INFO] [stderr] 46 | fn change_authorities(
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `change_difficulty` is never used
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:55:4
[INFO] [stderr]    |
[INFO] [stderr] 55 | fn change_difficulty(
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `even_after_given_height` is never used
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:70:4
[INFO] [stderr]    |
[INFO] [stderr] 70 | fn even_after_given_height<Original: Consensus>(fork_height: u64) -> impl Consensus {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `pow_to_poa` is never used
[INFO] [stderr]   --> src/c3_consensus/p6_forking.rs:80:4
[INFO] [stderr]    |
[INFO] [stderr] 80 | fn pow_to_poa(
[INFO] [stderr]    |    ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Hash` is never used
[INFO] [stderr]   --> src/c4_client/mod.rs:29:6
[INFO] [stderr]    |
[INFO] [stderr] 29 | type Hash = u64;
[INFO] [stderr]    |      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `FullClient` is never constructed
[INFO] [stderr]   --> src/c4_client/mod.rs:52:12
[INFO] [stderr]    |
[INFO] [stderr] 52 | pub struct FullClient<C, SM, FC, P>
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `Hash` is never used
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:22:6
[INFO] [stderr]    |
[INFO] [stderr] 22 | type Hash = u64;
[INFO] [stderr]    |      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `genesis`, `child`, `verify_child`, and `verify_sub_chain` are never used
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:26:8
[INFO] [stderr]    |
[INFO] [stderr] 24 | impl<Digest> Header<Digest> {
[INFO] [stderr]    | --------------------------- associated items in this implementation
[INFO] [stderr] 25 |     /// Returns a new valid genesis header.
[INFO] [stderr] 26 |     fn genesis(genesis_state_root: Hash) -> Self {
[INFO] [stderr]    |        ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 31 |     fn child(&self, state_root: Hash, extrinsics_root: Hash) -> Self {
[INFO] [stderr]    |        ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 36 |     fn verify_child(&self, child: &Self) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 41 |     fn verify_sub_chain(&self, chain: &[Self]) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Block` is never constructed
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:46:12
[INFO] [stderr]    |
[INFO] [stderr] 46 | pub struct Block<C: Consensus, SM: StateMachine> {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `genesis`, `child`, and `verify_sub_chain` are never used
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:53:12
[INFO] [stderr]    |
[INFO] [stderr] 51 | impl<C: Consensus, SM: StateMachine> Block<C, SM> {
[INFO] [stderr]    | ------------------------------------------------- associated items in this implementation
[INFO] [stderr] 52 |     /// Returns a new valid genesis block. By convention this block has no extrinsics.
[INFO] [stderr] 53 |     pub fn genesis(genesis_state: &SM::State) -> Self {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 58 |     pub fn child(&self, pre_state: &SM::State, extrinsics: Vec<u8>) -> Self {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 63 |     pub fn verify_sub_chain(&self, pre_state: &SM::State, chain: &[Self]) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_empty_chain` is never used
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:70:4
[INFO] [stderr]    |
[INFO] [stderr] 70 | fn create_empty_chain<C: Consensus, SM: StateMachine>(
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> src/c4_client/p1_data_structure.rs:84:8
[INFO] [stderr]    |
[INFO] [stderr] 80 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>
[INFO] [stderr] 81 | | where
[INFO] [stderr] 82 | |     SM: StateMachine,
[INFO] [stderr]    | |_____________________- associated function in this implementation
[INFO] [stderr] 83 |   {
[INFO] [stderr] 84 |       fn new(genesis_state: SM::State) -> Self {
[INFO] [stderr]    |          ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `ImportBlock` is never used
[INFO] [stderr]   --> src/c4_client/p2_importing_blocks.rs:10:11
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub trait ImportBlock<C: Consensus, SM: StateMachine> {
[INFO] [stderr]    |           ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `ForkChoice` is never used
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:18:11
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub trait ForkChoice<C: Consensus> {
[INFO] [stderr]    |           ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `LongestChain` is never constructed
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:27:12
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub struct LongestChain {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `HeaviestChain` is never constructed
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:44:12
[INFO] [stderr]    |
[INFO] [stderr] 44 | pub struct HeaviestChain {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `MostAliceSigs` is never constructed
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:61:12
[INFO] [stderr]    |
[INFO] [stderr] 61 | pub struct MostAliceSigs {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Ghost` is never constructed
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:78:12
[INFO] [stderr]    |
[INFO] [stderr] 78 | pub struct Ghost {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `best_block` is never used
[INFO] [stderr]   --> src/c4_client/p3_fork_choice.rs:97:8
[INFO] [stderr]    |
[INFO] [stderr] 95 | impl<C, SM, FC, P> FullClient<C, SM, FC, P> {
[INFO] [stderr]    | ------------------------------------------- method in this implementation
[INFO] [stderr] 96 |     /// Return the hash of the best block currently known to the client
[INFO] [stderr] 97 |     fn best_block(&self) -> u64 {
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait `TransactionPool` is never used
[INFO] [stderr]   --> src/c4_client/p4_transaction_pool.rs:17:11
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub trait TransactionPool<SM: StateMachine> {
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `submit_transaction`, `pool_size`, and `pool_contains` are never used
[INFO] [stderr]   --> src/c4_client/p4_transaction_pool.rs:48:12
[INFO] [stderr]    |
[INFO] [stderr] 42 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>           
[INFO] [stderr] 43 | |     where
[INFO] [stderr] 44 | |     SM: StateMachine,
[INFO] [stderr]    | |_____________________- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 48 |       pub fn submit_transaction(&mut self, t: SM::Transition) {
[INFO] [stderr]    |              ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 54 |       pub fn pool_size(&self) -> usize {
[INFO] [stderr]    |              ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 59 |       pub fn pool_contains(&self, t: SM::Transition) -> bool {
[INFO] [stderr]    |              ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SimplePool` is never constructed
[INFO] [stderr]   --> src/c4_client/p4_transaction_pool.rs:65:12
[INFO] [stderr]    |
[INFO] [stderr] 65 | pub struct SimplePool<SM: StateMachine>(VecDeque<SM::Transition>);
[INFO] [stderr]    |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `PriorityPool` is never constructed
[INFO] [stderr]   --> src/c4_client/p4_transaction_pool.rs:96:12
[INFO] [stderr]    |
[INFO] [stderr] 96 | pub struct PriorityPool<T, P: Fn(T) -> u64> {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CensoringPool` is never constructed
[INFO] [stderr]    --> src/c4_client/p4_transaction_pool.rs:134:12
[INFO] [stderr]     |
[INFO] [stderr] 134 | pub struct CensoringPool<T, P: Fn(T) -> bool> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `author_and_import_manual_block` and `author_and_import_automatic_block` are never used
[INFO] [stderr]   --> src/c4_client/p5_authoring_blocks.rs:13:12
[INFO] [stderr]    |
[INFO] [stderr]  7 | / impl<C, SM, FC, P> FullClient<C, SM, FC, P>
[INFO] [stderr]  8 | |     where
[INFO] [stderr]  9 | |     SM: StateMachine,
[INFO] [stderr]    | |_____________________- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 13 |       pub fn author_and_import_manual_block(&mut self, transactions: Vec<SM::Transition>, parent_hash: u64) {
[INFO] [stderr]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 19 |       pub fn author_and_import_automatic_block(&self) {
[INFO] [stderr]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `manually_finalize_block` is never used
[INFO] [stderr]   --> src/c4_client/p6_finality.rs:13:12
[INFO] [stderr]    |
[INFO] [stderr] 10 | impl<C, SM, FC, P> FullClient<C, SM, FC, P> {
[INFO] [stderr]    | ------------------------------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 13 |     pub fn manually_finalize_block(&mut self, block_hash: u64) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `diy-blockchain` (lib) generated 248 warnings (run `cargo fix --lib -p diy-blockchain` to apply 141 suggestions)
[INFO] [stderr] warning: associated function `human_name` is never used
[INFO] [stderr]   --> src/c1_state_machine/mod.rs:25:8
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub trait StateMachine {
[INFO] [stderr]    |           ------------ associated function in this trait
[INFO] [stderr] ...
[INFO] [stderr] 25 |     fn human_name() -> String {
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/c1_state_machine/p3_atm.rs:21:15
[INFO] [stderr]    |
[INFO] [stderr] 21 |     SwipeCard(u64),
[INFO] [stderr]    |     --------- ^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 21 -     SwipeCard(u64),
[INFO] [stderr] 21 +     SwipeCard(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/c1_state_machine/p3_atm.rs:23:14
[INFO] [stderr]    |
[INFO] [stderr] 23 |     PressKey(Key),
[INFO] [stderr]    |     -------- ^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 23 -     PressKey(Key),
[INFO] [stderr] 23 +     PressKey(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: fields `minter` and `amount` are never read
[INFO] [stderr]   --> src/c1_state_machine/p4_accounted_currency.rs:29:12
[INFO] [stderr]    |
[INFO] [stderr] 29 |     Mint { minter: User, amount: u64 },
[INFO] [stderr]    |     ----   ^^^^^^        ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     fields in this variant
[INFO] [stderr] 
[INFO] [stderr] warning: fields `burner` and `amount` are never read
[INFO] [stderr]   --> src/c1_state_machine/p4_accounted_currency.rs:33:12
[INFO] [stderr]    |
[INFO] [stderr] 33 |     Burn { burner: User, amount: u64 },
[INFO] [stderr]    |     ----   ^^^^^^        ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     fields in this variant
[INFO] [stderr] 
[INFO] [stderr] warning: fields `sender`, `receiver`, and `amount` are never read
[INFO] [stderr]   --> src/c1_state_machine/p4_accounted_currency.rs:36:9
[INFO] [stderr]    |
[INFO] [stderr] 35 |     Transfer {
[INFO] [stderr]    |     -------- fields in this variant
[INFO] [stderr] 36 |         sender: User,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 37 |         receiver: User,
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] 38 |         amount: u64,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `next_serial` is never used
[INFO] [stderr]   --> src/c1_state_machine/p5_digital_cash.rs:45:12
[INFO] [stderr]    |
[INFO] [stderr] 33 | impl State {
[INFO] [stderr]    | ---------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 45 |     pub fn next_serial(&self) -> u64 {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `minter` and `amount` are never read
[INFO] [stderr]   --> src/c1_state_machine/p5_digital_cash.rs:79:12
[INFO] [stderr]    |
[INFO] [stderr] 79 |     Mint { minter: User, amount: u64 },
[INFO] [stderr]    |     ----   ^^^^^^        ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     fields in this variant
[INFO] [stderr] 
[INFO] [stderr] warning: fields `spends` and `receives` are never read
[INFO] [stderr]   --> src/c1_state_machine/p5_digital_cash.rs:86:9
[INFO] [stderr]    |
[INFO] [stderr] 85 |     Transfer {
[INFO] [stderr]    |     -------- fields in this variant
[INFO] [stderr] 86 |         spends: Vec<Bill>,
[INFO] [stderr]    |         ^^^^^^
[INFO] [stderr] 87 |         receives: Vec<Bill>,
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `verify_sub_chain` is never used
[INFO] [stderr]   --> src/c2_blockchain/p4_batched_extrinsics.rs:64:8
[INFO] [stderr]    |
[INFO] [stderr] 33 | impl Header {
[INFO] [stderr]    | ----------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 64 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `verify_sub_chain` is never used
[INFO] [stderr]   --> src/c2_blockchain/p6_rich_state.rs:67:8
[INFO] [stderr]    |
[INFO] [stderr] 47 | impl Header {
[INFO] [stderr]    | ----------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 67 |     fn verify_sub_chain(&self, chain: &[Header]) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `diy-blockchain` (lib test) generated 195 warnings (184 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.17s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: diy-blockchain v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/diy_blockchain-449c835185acdc62)
[INFO] [stdout] 
[INFO] [stdout] running 142 tests
[INFO] [stdout] test c1_state_machine::p1_switches::sm_1_light_switch_toggles_off ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_dry_clean_until_tattered ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_dry_cwet_until_tattered ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_dry_dirty_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_dry_dirty_until_tattered ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_dry_tattered_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p1_switches::sm_1_two_switches_first_goes_on ... FAILED
[INFO] [stdout] test c1_state_machine::p1_switches::sm_1_two_switches_first_goes_off_second_was_on ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wash_clean_until_tattered ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wash_dirty_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wash_dirty_until_tattered ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wash_tattered_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wash_wet_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wash_wet_until_tattered ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wear_clean_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wear_clean_until_tattered ... FAILED
[INFO] [stdout] test c1_state_machine::p1_switches::sm_1_two_switches_second_goes_on ... FAILED
[INFO] [stdout] test c1_state_machine::p1_switches::sm_1_two_switches_second_goes_off ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_dry_clean_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wear_dirty_until_tattered ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wear_tattered_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wear_wet_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_dry_wet_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p3_atm::sm_3_enter_single_digit_of_pin ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wash_clean_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p1_switches::sm_1_light_switch_toggles_on ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wear_dirty_clothes ... FAILED
[INFO] [stdout] test c1_state_machine::p2_laundry_machine::sm_2_wear_wet_until_tattered ... FAILED
[INFO] [stdout] test c1_state_machine::p3_atm::sm_3_enter_single_digit_of_withdraw_amount ... FAILED
[INFO] [stdout] test c1_state_machine::p3_atm::sm_3_swipe_card_again_part_way_through ... FAILED
[INFO] [stdout] test c1_state_machine::p3_atm::sm_3_enter_correct_pin ... FAILED
[INFO] [stdout] test c1_state_machine::p3_atm::sm_3_try_to_withdraw_too_much ... FAILED
[INFO] [stdout] test c1_state_machine::p3_atm::sm_3_simple_swipe_card ... FAILED
[INFO] [stdout] test c1_state_machine::p3_atm::sm_3_enter_wrong_pin ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_burn_no_existential_deposit_left ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_burner_does_not_exist ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_empty_burn ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_empty_mint ... FAILED
[INFO] [stdout] test c1_state_machine::p3_atm::sm_3_withdraw_acceptable_amount ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_insufficient_balance_transfer ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_burn_more_than_balance ... FAILED
[INFO] [stdout] test c1_state_machine::p3_atm::sm_3_press_key_before_card_swipe ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_receiver_not_registered ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_non_registered_burner ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_sender_not_registered ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_mint_increases_balance ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_mint_creates_second_account ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_send_to_same_user ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_mint_creates_account ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_simple_transfer ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_empty_spend_fails ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_simple_burn ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_output_value_0_fails ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_transfer ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_overflow_receives_fails ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_empty_receive_fails ... FAILED
[INFO] [stdout] test c1_state_machine::p4_accounted_currency::sm_4_sender_to_empty_balance ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_receiving_bill_with_incorrect_serial_fails ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_serial_number_already_seen_fails ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_spending_from_charlie_to_all ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_spending_more_than_bill_fails ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_spending_non_existent_bill_fails ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_spending_same_bill_fails ... FAILED
[INFO] [stdout] test c2_blockchain::p1_header_chain::bc_1_cant_verify_invalid_height ... FAILED
[INFO] [stdout] test c2_blockchain::p1_header_chain::bc_1_cant_verify_invalid_parent ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_spending_bill_with_incorrect_amount_fails ... FAILED
[INFO] [stdout] test c2_blockchain::p1_header_chain::bc_1_child_block_height ... FAILED
[INFO] [stdout] test c2_blockchain::p1_header_chain::bc_1_genesis_block_height ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_spending_from_alice_to_all ... FAILED
[INFO] [stdout] test c2_blockchain::p1_header_chain::bc_1_child_block_parent ... FAILED
[INFO] [stdout] test c2_blockchain::p1_header_chain::bc_1_verify_chain_length_five ... FAILED
[INFO] [stdout] test c2_blockchain::p1_header_chain::bc_1_invalid_chain_is_really_invalid ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_mint_new_cash ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_cant_verify_invalid_parent ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_cant_verify_invalid_state ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_child_block_extrinsic ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_child_block_height ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_child_block_parent ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_child_block_state ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_genesis_block_extrinsic ... FAILED
[INFO] [stdout] test c2_blockchain::p1_header_chain::bc_1_verify_genesis_only ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_genesis_block_height ... FAILED
[INFO] [stdout] test c1_state_machine::p1_switches::sm_1_two_switches_first_goes_off_second_was_off ... FAILED
[INFO] [stdout] test c2_blockchain::p1_header_chain::bc_1_verify_three_blocks ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_cant_verify_invalid_number ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_verify_forked_chain ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_genesis_block_state ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_invalid_chain_is_really_invalid ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_genesis_block_parent ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_verify_genesis_only ... FAILED
[INFO] [stdout] test c2_blockchain::p2_extrinsic_state::bc_2_verify_three_blocks ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_cant_verify_invalid_pow ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_child_block_consensus_digest ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_child_block_extrinsic ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_child_block_height ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_child_block_state ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_child_block_parent ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_even_chain_invalid_first_block_after_fork ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_even_chain_valid ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_genesis_block_extrinsic ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_cant_verify_invalid_parent ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_cant_verify_invalid_state ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_genesis_block_height ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_genesis_block_parent ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_genesis_block_state ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_odd_chain_invalid_first_block_after_fork ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_odd_chain_invalid_second_block_after_fork ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_odd_chain_valid ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_verify_forked_chain ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_verify_genesis_only ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_verify_three_blocks ... FAILED
[INFO] [stdout] test c2_blockchain::p4_batched_extrinsics::bc_4_block_with_invalid_header_does_not_check ... FAILED
[INFO] [stdout] test c2_blockchain::p4_batched_extrinsics::bc_4_child_block ... FAILED
[INFO] [stdout] test c2_blockchain::p4_batched_extrinsics::bc_4_child_block_empty ... FAILED
[INFO] [stdout] test c2_blockchain::p4_batched_extrinsics::bc_4_child_header ... FAILED
[INFO] [stdout] test c2_blockchain::p4_batched_extrinsics::bc_4_genesis_block ... FAILED
[INFO] [stdout] test c2_blockchain::p4_batched_extrinsics::bc_4_genesis_header ... FAILED
[INFO] [stdout] test c2_blockchain::p4_batched_extrinsics::bc_4_invalid_block_state_does_not_check ... FAILED
[INFO] [stdout] test c2_blockchain::p4_batched_extrinsics::bc_4_invalid_header_does_not_check ... FAILED
[INFO] [stdout] test c2_blockchain::p4_batched_extrinsics::bc_4_verify_three_blocks ... FAILED
[INFO] [stdout] test c2_blockchain::p5_fork_choice::bc_5_heaviest_chain ... FAILED
[INFO] [stdout] test c2_blockchain::p5_fork_choice::bc_5_longest_chain ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_genesis_consensus_digest ... FAILED
[INFO] [stdout] test c2_blockchain::p4_batched_extrinsics::bc_4_student_invalid_block_really_is_invalid ... FAILED
[INFO] [stdout] test c2_blockchain::p5_fork_choice::bc_5_longest_vs_heaviest ... FAILED
[INFO] [stdout] test c2_blockchain::p5_fork_choice::bc_5_mine_to_custom_difficulty ... FAILED
[INFO] [stdout] test c2_blockchain::p5_fork_choice::bc_5_most_even_blocks ... FAILED
[INFO] [stdout] test c2_blockchain::p6_rich_state::bc_6_block_with_invalid_header_doesnt_check ... FAILED
[INFO] [stdout] test c2_blockchain::p6_rich_state::bc_6_child_block ... FAILED
[INFO] [stdout] test c2_blockchain::p6_rich_state::bc_6_child_header ... FAILED
[INFO] [stdout] test c2_blockchain::p6_rich_state::bc_6_child_block_empty ... FAILED
[INFO] [stdout] test c2_blockchain::p6_rich_state::bc_6_genesis_header ... FAILED
[INFO] [stdout] test c2_blockchain::p6_rich_state::bc_6_invalid_block_state_doesnt_check ... FAILED
[INFO] [stdout] test c2_blockchain::p6_rich_state::bc_6_genesis_block ... FAILED
[INFO] [stdout] test c2_blockchain::p6_rich_state::bc_6_verify_three_blocks ... FAILED
[INFO] [stdout] test c2_blockchain::p6_rich_state::bc_6_invalid_header_doesnt_check ... FAILED
[INFO] [stdout] test c2_blockchain::p6_rich_state::bc_6_student_invalid_block_really_is_invalid ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_spending_and_receiving_same_bill_fails ... FAILED
[INFO] [stdout] test c1_state_machine::p5_digital_cash::sm_5_spending_from_bob_to_all ... FAILED
[INFO] [stdout] test c2_blockchain::p1_header_chain::bc_1_genesis_block_parent ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_cant_verify_invalid_number ... FAILED
[INFO] [stdout] test c2_blockchain::p3_consensus::bc_3_even_chain_invalid_second_block_after_fork ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p1_switches::sm_1_light_switch_toggles_off stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p1_switches::sm_1_light_switch_toggles_off' (17) panicked at src/c1_state_machine/p1_switches.rs:18:9:
[INFO] [stdout] not yet implemented: Exercise 1
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5005ec2 - <diy_blockchain::c1_state_machine::p1_switches::LightSwitch as diy_blockchain::c1_state_machine::StateMachine>::next_state::hb35adbd66f6d6a9d
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:18:9
[INFO] [stdout]   20:     0x570be50060a2 - diy_blockchain::c1_state_machine::p1_switches::sm_1_light_switch_toggles_off::h0dd25ee59002b7b9
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:51:14
[INFO] [stdout]   21:     0x570be50060e7 - diy_blockchain::c1_state_machine::p1_switches::sm_1_light_switch_toggles_off::{{closure}}::h1873d84f85a3e800
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:50:35
[INFO] [stdout]   22:     0x570be4ff1c26 - core::ops::function::FnOnce::call_once::h59521ca5b54af911
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_dry_clean_until_tattered stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_dry_clean_until_tattered' (25) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003f74 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_clean_until_tattered::h50fc5fe7c1bb3768
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:194:15
[INFO] [stdout]   21:     0x570be5003ff7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_clean_until_tattered::{{closure}}::h6de5e57c5458f787
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:192:35
[INFO] [stdout]   22:     0x570be4ff0f56 - core::ops::function::FnOnce::call_once::h0ba69f3f36bc9593
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_dry_cwet_until_tattered stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_dry_cwet_until_tattered' (26) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003d34 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_cwet_until_tattered::hfa644f3547385133
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:202:15
[INFO] [stdout]   21:     0x570be5003db7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_cwet_until_tattered::{{closure}}::h0a9c53626c590500
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:200:34
[INFO] [stdout]   22:     0x570be4ff1ab6 - core::ops::function::FnOnce::call_once::h4fc2e61bf57199a4
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_dry_dirty_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_dry_dirty_clothes' (27) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003764 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_dirty_clothes::ha2e4a568550bb171
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:170:15
[INFO] [stdout]   21:     0x570be50037e7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_dirty_clothes::{{closure}}::h61146d085859a38a
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:168:28
[INFO] [stdout]   22:     0x570be4ff1eb6 - core::ops::function::FnOnce::call_once::h6b5d382c76e4e14f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_dry_dirty_until_tattered stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_dry_dirty_until_tattered' (28) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5004034 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_dirty_until_tattered::h8289af104b3a2304
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:210:15
[INFO] [stdout]   21:     0x570be50040b7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_dirty_until_tattered::{{closure}}::h284920353db0c560
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:208:35
[INFO] [stdout]   22:     0x570be4ff1956 - core::ops::function::FnOnce::call_once::h4bee90fd3c6d4a88
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_dry_tattered_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_dry_tattered_clothes' (29) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003b1b - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_tattered_clothes::he993796bdd5e02d2
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:186:15
[INFO] [stdout]   21:     0x570be5003b97 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_tattered_clothes::{{closure}}::h575ef80bdd4fada7
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:184:31
[INFO] [stdout]   22:     0x570be4ff25d6 - core::ops::function::FnOnce::call_once::ha0c211d7d0749f98
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p1_switches::sm_1_two_switches_first_goes_on stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p1_switches::sm_1_two_switches_first_goes_on' (21) panicked at src/c1_state_machine/p1_switches.rs:45:9:
[INFO] [stdout] not yet implemented: Exercise 2
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5005f02 - <diy_blockchain::c1_state_machine::p1_switches::WeirdSwitchMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::h9cf98b67ff2f92f1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:45:9
[INFO] [stdout]   20:     0x570be500611f - diy_blockchain::c1_state_machine::p1_switches::sm_1_two_switches_first_goes_on::he1fffcdfdf785ff7
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:67:9
[INFO] [stdout]   21:     0x570be5006197 - diy_blockchain::c1_state_machine::p1_switches::sm_1_two_switches_first_goes_on::{{closure}}::h57c3c43052b67230
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:60:37
[INFO] [stdout]   22:     0x570be4ff31d6 - core::ops::function::FnOnce::call_once::hf118f8229c088afb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p1_switches::sm_1_two_switches_first_goes_off_second_was_on stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p1_switches::sm_1_two_switches_first_goes_off_second_was_on' (20) panicked at src/c1_state_machine/p1_switches.rs:45:9:
[INFO] [stdout] not yet implemented: Exercise 2
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5005f02 - <diy_blockchain::c1_state_machine::p1_switches::WeirdSwitchMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::h9cf98b67ff2f92f1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:45:9
[INFO] [stdout]   20:     0x570be500632f - diy_blockchain::c1_state_machine::p1_switches::sm_1_two_switches_first_goes_off_second_was_on::hbba6f12c28bd6a44
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:84:9
[INFO] [stdout]   21:     0x570be50063a7 - diy_blockchain::c1_state_machine::p1_switches::sm_1_two_switches_first_goes_off_second_was_on::{{closure}}::hc49af168dc4149ab
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:76:52
[INFO] [stdout]   22:     0x570be4ff2406 - core::ops::function::FnOnce::call_once::h92b5ef6209aa896a
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wash_clean_until_tattered stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wash_clean_until_tattered' (32) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be50040f4 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_clean_until_tattered::hc6cd9d5147a7ab01
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:138:15
[INFO] [stdout]   21:     0x570be5004177 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_clean_until_tattered::{{closure}}::h881462d2cc09df94
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:136:36
[INFO] [stdout]   22:     0x570be4ff20f6 - core::ops::function::FnOnce::call_once::h7fc9d740e54869ed
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wash_dirty_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wash_dirty_clothes' (33) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be50038e4 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_dirty_clothes::hf60eb5087ccbac95
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:114:15
[INFO] [stdout]   21:     0x570be5003967 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_dirty_clothes::{{closure}}::h8e07dca3a48f0b3c
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:112:29
[INFO] [stdout]   22:     0x570be4ff0df6 - core::ops::function::FnOnce::call_once::h0189382862f5ca5f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wash_dirty_until_tattered stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wash_dirty_until_tattered' (34) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be50041b4 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_dirty_until_tattered::hcc4110a6e2dc66b3
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:154:15
[INFO] [stdout]   21:     0x570be5004237 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_dirty_until_tattered::{{closure}}::h7ae0283454a35cc1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:152:36
[INFO] [stdout]   22:     0x570be4ff1396 - core::ops::function::FnOnce::call_once::h20ccadd2a3392428
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wash_tattered_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wash_tattered_clothes' (35) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003bcb - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_tattered_clothes::h842dde1eadba7e4c
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:130:15
[INFO] [stdout]   21:     0x570be5003c47 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_tattered_clothes::{{closure}}::hd2251a351bf4ec98
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:128:32
[INFO] [stdout]   22:     0x570be4ff24c6 - core::ops::function::FnOnce::call_once::h94dafc715794a701
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wash_wet_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wash_wet_clothes' (36) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003524 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_wet_clothes::h476b505ecac7a1f8
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:122:15
[INFO] [stdout]   21:     0x570be50035a7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_wet_clothes::{{closure}}::h8d1b0904f4ce1556
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:120:27
[INFO] [stdout]   22:     0x570be4ff1ff6 - core::ops::function::FnOnce::call_once::h74891453de4de01c
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wash_wet_until_tattered stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wash_wet_until_tattered' (37) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003df4 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_wet_until_tattered::hf47a71dfae3e25b1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:146:15
[INFO] [stdout]   21:     0x570be5003e77 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_wet_until_tattered::{{closure}}::h4564e54a5aa7b6e1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:144:34
[INFO] [stdout]   22:     0x570be4ff0fd6 - core::ops::function::FnOnce::call_once::h0db872a419e23578
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wear_clean_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wear_clean_clothes' (38) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be50039a4 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_clean_clothes::h403f70b678cc43d2
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:50:15
[INFO] [stdout]   21:     0x570be5003a27 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_clean_clothes::{{closure}}::h403e40035c52798e
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:48:29
[INFO] [stdout]   22:     0x570be4ff1456 - core::ops::function::FnOnce::call_once::h2381e910190b81df
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wear_clean_until_tattered stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wear_clean_until_tattered' (39) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5004274 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_clean_until_tattered::h699778c8989e356d
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:82:15
[INFO] [stdout]   21:     0x570be50042f7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_clean_until_tattered::{{closure}}::ha21094fbb32264f1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:80:36
[INFO] [stdout]   22:     0x570be4ff2506 - core::ops::function::FnOnce::call_once::h955c7cadc5e6f73d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p1_switches::sm_1_two_switches_second_goes_on stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p1_switches::sm_1_two_switches_second_goes_on' (23) panicked at src/c1_state_machine/p1_switches.rs:45:9:
[INFO] [stdout] not yet implemented: Exercise 2
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5005f02 - <diy_blockchain::c1_state_machine::p1_switches::WeirdSwitchMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::h9cf98b67ff2f92f1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:45:9
[INFO] [stdout]   20:     0x570be50061cf - diy_blockchain::c1_state_machine::p1_switches::sm_1_two_switches_second_goes_on::h6f7fb15e58bfa80d
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:117:9
[INFO] [stdout]   21:     0x570be5006247 - diy_blockchain::c1_state_machine::p1_switches::sm_1_two_switches_second_goes_on::{{closure}}::heb1f688ef0207a04
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:110:38
[INFO] [stdout]   22:     0x570be4ff1996 - core::ops::function::FnOnce::call_once::h4cfb03fcd048116c
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p1_switches::sm_1_two_switches_second_goes_off stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p1_switches::sm_1_two_switches_second_goes_off' (22) panicked at src/c1_state_machine/p1_switches.rs:45:9:
[INFO] [stdout] not yet implemented: Exercise 2
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5005f02 - <diy_blockchain::c1_state_machine::p1_switches::WeirdSwitchMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::h9cf98b67ff2f92f1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:45:9
[INFO] [stdout]   20:     0x570be500627f - diy_blockchain::c1_state_machine::p1_switches::sm_1_two_switches_second_goes_off::h0bd45107f054a851
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:133:9
[INFO] [stdout]   21:     0x570be50062f7 - diy_blockchain::c1_state_machine::p1_switches::sm_1_two_switches_second_goes_off::{{closure}}::h17cad375127f2220
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:126:39
[INFO] [stdout]   22:     0x570be4ff1256 - core::ops::function::FnOnce::call_once::h1cf0146ce01fa3ca
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_dry_clean_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_dry_clean_clothes' (24) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be50036a4 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_clean_clothes::h2177f5e8eeb4ec0c
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:162:15
[INFO] [stdout]   21:     0x570be5003727 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_clean_clothes::{{closure}}::h805626b8a0f135a3
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:160:28
[INFO] [stdout]   22:     0x570be4ff17d6 - core::ops::function::FnOnce::call_once::h41a4e2c1cc82f7a7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wear_dirty_until_tattered stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wear_dirty_until_tattered' (41) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5004334 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_dirty_until_tattered::h18c33ac1bb384880
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:98:15
[INFO] [stdout]   21:     0x570be50043b7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_dirty_until_tattered::{{closure}}::hdd239e26a18aa751
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:96:36
[INFO] [stdout]   22:     0x570be4ff3056 - core::ops::function::FnOnce::call_once::he55a734c6ce7c2bd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wear_tattered_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wear_tattered_clothes' (42) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003c7b - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_tattered_clothes::h536116fbc774d880
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:74:15
[INFO] [stdout]   21:     0x570be5003cf7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_tattered_clothes::{{closure}}::h8f5508dbca2a1d4b
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:72:32
[INFO] [stdout]   22:     0x570be4ff20b6 - core::ops::function::FnOnce::call_once::h787d220c331972d1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wear_wet_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wear_wet_clothes' (43) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be50035e4 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_wet_clothes::ha47ab92638802a0c
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:66:15
[INFO] [stdout]   21:     0x570be5003667 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_wet_clothes::{{closure}}::h4f306718311ea01a
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:64:27
[INFO] [stdout]   22:     0x570be4ff2fc6 - core::ops::function::FnOnce::call_once::he4d69ee0ac84392d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_dry_wet_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_dry_wet_clothes' (30) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003464 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_wet_clothes::h84ac447cdccc0243
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:178:15
[INFO] [stdout]   21:     0x570be50034e7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_dry_wet_clothes::{{closure}}::h28bba04b4ba4ab4f
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:176:26
[INFO] [stdout]   22:     0x570be4ff2306 - core::ops::function::FnOnce::call_once::h8d2064a5e184f39f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p3_atm::sm_3_enter_single_digit_of_pin stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p3_atm::sm_3_enter_single_digit_of_pin' (46) panicked at src/c1_state_machine/p3_atm.rs:61:9:
[INFO] [stdout] not yet implemented: Exercise 4
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be4ff5a02 - <diy_blockchain::c1_state_machine::p3_atm::Atm as diy_blockchain::c1_state_machine::StateMachine>::next_state::h5185008bdfcf09bf
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p3_atm.rs:61:9
[INFO] [stdout]   20:     0x570be4ff8326 - diy_blockchain::c1_state_machine::p3_atm::sm_3_enter_single_digit_of_pin::h175266b28101d30f
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p3_atm.rs:137:15
[INFO] [stdout]   21:     0x570be4ff87b7 - diy_blockchain::c1_state_machine::p3_atm::sm_3_enter_single_digit_of_pin::{{closure}}::hf8e641ab339261b8
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p3_atm.rs:131:36
[INFO] [stdout]   22:     0x570be4ff32d6 - core::ops::function::FnOnce::call_once::hf6e460c2374dfb95
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wash_clean_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wash_clean_clothes' (31) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003824 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_clean_clothes::h1d3cfc0bc0d7487c
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:106:15
[INFO] [stdout]   21:     0x570be50038a7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wash_clean_clothes::{{closure}}::h609c4b3a2422aaff
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:104:29
[INFO] [stdout]   22:     0x570be4ff1156 - core::ops::function::FnOnce::call_once::h18e40c957cbcec1a
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p1_switches::sm_1_light_switch_toggles_on stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p1_switches::sm_1_light_switch_toggles_on' (18) panicked at src/c1_state_machine/p1_switches.rs:18:9:
[INFO] [stdout] not yet implemented: Exercise 1
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5005ec2 - <diy_blockchain::c1_state_machine::p1_switches::LightSwitch as diy_blockchain::c1_state_machine::StateMachine>::next_state::hb35adbd66f6d6a9d
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:18:9
[INFO] [stdout]   20:     0x570be5006032 - diy_blockchain::c1_state_machine::p1_switches::sm_1_light_switch_toggles_on::h9df37cdbce4768b1
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:56:13
[INFO] [stdout]   21:     0x570be5006077 - diy_blockchain::c1_state_machine::p1_switches::sm_1_light_switch_toggles_on::{{closure}}::hc726d63a7c061e30
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p1_switches.rs:55:34
[INFO] [stdout]   22:     0x570be4ff0ed6 - core::ops::function::FnOnce::call_once::h0807b230c077dc55
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wear_dirty_clothes stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wear_dirty_clothes' (40) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x570be5061859 - std::sys::backtrace::__rust_end_short_backtrace::hb72197fa777c1785
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x570be504a89d - __rustc[4425a7e20b4c8619]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x570be509e65c - core::panicking::panic_fmt::ha59b517dd231f4da
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x570be5002102 - <diy_blockchain::c1_state_machine::p2_laundry_machine::ClothesMachine as diy_blockchain::c1_state_machine::StateMachine>::next_state::hcf378551741e6710
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:43:9
[INFO] [stdout]   20:     0x570be5003a64 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_dirty_clothes::h4b7559ea76a4a934
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:58:15
[INFO] [stdout]   21:     0x570be5003ae7 - diy_blockchain::c1_state_machine::p2_laundry_machine::sm_2_wear_dirty_clothes::{{closure}}::h8b07da1f6cb46e60
[INFO] [stdout]                                at /opt/rustwide/workdir/src/c1_state_machine/p2_laundry_machine.rs:56:29
[INFO] [stdout]   22:     0x570be4ff1616 - core::ops::function::FnOnce::call_once::h36d923e9507a5a63
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x570be502a50b - core::ops::function::FnOnce::call_once::hddb3cd395c36bfbb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x570be502a50b - test::__rust_begin_short_backtrace::h0b6a7601d9750bfa
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x570be503df1a - test::run_test_in_process::{{closure}}::h444209903f00b347
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x570be503df1a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hfb3ba8f46e537649
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x570be503df1a - std::panicking::catch_unwind::do_call::h1672a45911fcf9dc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x570be503df1a - std::panicking::catch_unwind::h0fadaee22787a6dd
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x570be503df1a - std::panic::catch_unwind::hc47ad190f2c8e188
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x570be503df1a - test::run_test_in_process::hcd7faaf934f29999
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x570be503df1a - test::run_test::{{closure}}::hddc4550da4871867
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x570be5018374 - test::run_test::{{closure}}::h98ae26689f13ed94
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x570be5018374 - std::sys::backtrace::__rust_begin_short_backtrace::h3ec4d1f21ad44588
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::{{closure}}::hd8bf2c73d479939f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x570be501bd12 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h3b4248f358af2491
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x570be501bd12 - std::panicking::catch_unwind::do_call::hda10a64f4b8daebe
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x570be501bd12 - std::panicking::catch_unwind::h659e5ee8336ec8c7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x570be501bd12 - std::panic::catch_unwind::h9d4d66a538912c18
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x570be501bd12 - std::thread::lifecycle::spawn_unchecked::{{closure}}::h7557906bb51d79f1
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x570be501bd12 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9e460d1d7fc83d35
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x570be505caef - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h61282da819d64ea9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x570be505caef - std::sys::thread::unix::Thread::new::thread_start::h982f9ea829d1b5fb
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/thread/unix.rs:127:17
[INFO] [stdout]   43:     0x7f3f861a1aa4 - <unknown>
[INFO] [stdout]   44:     0x7f3f8622ea64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- c1_state_machine::p2_laundry_machine::sm_2_wear_wet_until_tattered stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'c1_state_machine::p2_laundry_machine::sm_2_wear_wet_until_tattered' (44) panicked at src/c1_state_machine/p2_laundry_machine.rs:43:9:
[INFO] [stdout] not yet implemented: Exercise 3
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x570be5086d22 - std::backtrace_rs::backtrace::libunwind::trace::hff358a60abf734fc
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x570be5086d22 - std::backtrace_rs::backtrace::trace_unsynchronized::h3b121f916dd95ec6
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x570be5086d22 - std::sys::backtrace::_print_fmt::hde0a62ded68798e9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x570be5086d22 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h93773fc827e3113d
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x570be5096d8a - core::fmt::rt::Argument::fmt::h01eff69902dad97f
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x570be5096d8a - core::fmt::write::hed7b5c73d82ecb7c
[INFO] [stdout]    6:     0x570be5055a66 - std::io::default_write_fmt::h2f696ff5b8bbaa4b
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x570be5055a66 - std::io::Write::write_fmt::h5e66814db8a9cfce
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x570be5066209 - std::sys::backtrace::BacktraceLock::print::h8b1d6fcc5a56d1a3
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x570be5066209 - std::panicking::default_hook::{{closure}}::h2be84df4f189ae36
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x570be50660a1 - std::panicking::default_hook::hf0ea8939246f43a9
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x570be502a74e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h02d35e3888986252
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x570be502a74e - test::test_main_with_exit_callback::{{closure}}::h939640a27d647173
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x570be5066482 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hc9df09ff391af3e7
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x570be5066482 - std::panicking::panic_with_hook::hb4bd9ac1123582a0
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x570be50662fa - std::panicking::panic_handler::{{closure}}::hde00dd15f5637fe2
[INFO] [stdout]                                at /rustc/4a4ef493e3a1488c6e321570238084b38948f6db/library/std/src/panicking.rs:691:13
[WARN] too many lines in the log, truncating it
