[INFO] fetching crate fantasy-cpu-emulator 0.1.1...
[INFO] checking fantasy-cpu-emulator-0.1.1 against master#642c19bfc3a5c1de985bf5d0cc8207ac9d22708a for pr-148577
[INFO] extracting crate fantasy-cpu-emulator 0.1.1 into /workspace/builds/worker-7-tc1/source
[INFO] started tweaking crates.io crate fantasy-cpu-emulator 0.1.1
[INFO] finished tweaking crates.io crate fantasy-cpu-emulator 0.1.1
[INFO] tweaked toml for crates.io crate fantasy-cpu-emulator 0.1.1 written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate fantasy-cpu-emulator 0.1.1 on toolchain 642c19bfc3a5c1de985bf5d0cc8207ac9d22708a
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+642c19bfc3a5c1de985bf5d0cc8207ac9d22708a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate fantasy-cpu-emulator 0.1.1 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" "+642c19bfc3a5c1de985bf5d0cc8207ac9d22708a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: only one of `license` or `license-file` is necessary
[INFO] [stderr] `license` should be used if the package license can be expressed with a standard SPDX expression.
[INFO] [stderr] `license-file` should be used if the package uses a non-standard license.
[INFO] [stderr] See https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields for more information.
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded syn v1.0.39
[INFO] [stderr]   Downloaded fantasy-cpu-emulator-macros v0.1.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+642c19bfc3a5c1de985bf5d0cc8207ac9d22708a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 4d2bb18ffc41ecf33fe13ea75d623f46c6938c661e4337daf24fa3d22c7b919f
[INFO] running `Command { std: "docker" "start" "-a" "4d2bb18ffc41ecf33fe13ea75d623f46c6938c661e4337daf24fa3d22c7b919f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4d2bb18ffc41ecf33fe13ea75d623f46c6938c661e4337daf24fa3d22c7b919f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4d2bb18ffc41ecf33fe13ea75d623f46c6938c661e4337daf24fa3d22c7b919f", kill_on_drop: false }`
[INFO] [stdout] 4d2bb18ffc41ecf33fe13ea75d623f46c6938c661e4337daf24fa3d22c7b919f
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+642c19bfc3a5c1de985bf5d0cc8207ac9d22708a" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] be3ca473e9ec530aa3132c5b28cd025c9362250243f2dd3ad31b7ab025250708
[INFO] running `Command { std: "docker" "start" "-a" "be3ca473e9ec530aa3132c5b28cd025c9362250243f2dd3ad31b7ab025250708", kill_on_drop: false }`
[INFO] [stderr] warning: only one of `license` or `license-file` is necessary
[INFO] [stderr] `license` should be used if the package license can be expressed with a standard SPDX expression.
[INFO] [stderr] `license-file` should be used if the package uses a non-standard license.
[INFO] [stderr] See https://doc.rust-lang.org/cargo/reference/manifest.html#the-license-and-license-file-fields for more information.
[INFO] [stderr]    Compiling proc-macro2 v1.0.19
[INFO] [stderr]    Compiling syn v1.0.39
[INFO] [stderr]     Checking unicode-xid v0.2.1
[INFO] [stderr]     Checking getopts v0.2.21
[INFO] [stderr]     Checking quote v1.0.7
[INFO] [stderr]    Compiling fantasy-cpu-emulator-macros v0.1.0
[INFO] [stderr]     Checking fantasy-cpu-emulator v0.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused `#[macro_use]` import
[INFO] [stdout]  --> src/lib.rs:3:1
[INFO] [stdout]   |
[INFO] [stdout] 3 | #[macro_use] extern crate quote;
[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: `fetch in Fetch = super`
[INFO] [stdout]   --> src/potato.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 51 |   - fetch in Fetch = super::super::fetch
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `write_out_state in WriteOutState = super`
[INFO] [stdout]   --> src/potato.rs:55:5
[INFO] [stdout]    |
[INFO] [stdout] 55 |   - write_out_state in WriteOutState = super::super::write_out_state
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `potato::potato_chip`
[INFO] [stdout]  --> src/lib.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use potato::potato_chip;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/unpipelined_potato.rs:33:8
[INFO] [stdout]    |
[INFO] [stdout] 33 |     if (forward_by > 0) {
[INFO] [stdout]    |        ^              ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 33 -     if (forward_by > 0) {
[INFO] [stdout] 33 +     if forward_by > 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/unpipelined_potato.rs:37:14
[INFO] [stdout]    |
[INFO] [stdout] 37 |           if (progress != 0) {
[INFO] [stdout]    |              ^             ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 37 -           if (progress != 0) {
[INFO] [stdout] 37 +           if progress != 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]   --> src/unpipelined_potato.rs:73:5
[INFO] [stdout]    |
[INFO] [stdout] 73 |     (from & ((1 << 36) - 1))
[INFO] [stdout]    |     ^                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 73 -     (from & ((1 << 36) - 1))
[INFO] [stdout] 73 +     from & ((1 << 36) - 1) 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/unpipelined_potato.rs:77:20
[INFO] [stdout]    |
[INFO] [stdout] 77 |     let test_bit = (1 << 35);
[INFO] [stdout]    |                    ^       ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 77 -     let test_bit = (1 << 35);
[INFO] [stdout] 77 +     let test_bit = 1 << 35 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]   --> src/unpipelined_potato.rs:88:5
[INFO] [stdout]    |
[INFO] [stdout] 88 |     (u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1))
[INFO] [stdout]    |     ^                                                            ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 88 -     (u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1))
[INFO] [stdout] 88 +     u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1) 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fetch in Fetch = super`
[INFO] [stdout]    --> src/unpipelined_potato.rs:120:5
[INFO] [stdout]     |
[INFO] [stdout] 120 |   - fetch in Fetch = super::super::fetch
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `decode in Decode = super`
[INFO] [stdout]    --> src/unpipelined_potato.rs:121:5
[INFO] [stdout]     |
[INFO] [stdout] 121 |   - decode in Decode = super::super::Instructions::decode
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `unpipelined_potato::unpipelined_potato_chip`
[INFO] [stdout]   --> src/lib.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use unpipelined_potato::unpipelined_potato_chip;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/jackfruit.rs:51:8
[INFO] [stdout]    |
[INFO] [stdout] 51 |     if (forward_by > 0) {
[INFO] [stdout]    |        ^              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 51 -     if (forward_by > 0) {
[INFO] [stdout] 51 +     if forward_by > 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/jackfruit.rs:62:14
[INFO] [stdout]    |
[INFO] [stdout] 62 |           if (progress != 0) {
[INFO] [stdout]    |              ^             ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 62 -           if (progress != 0) {
[INFO] [stdout] 62 +           if progress != 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/jackfruit.rs:139:5
[INFO] [stdout]     |
[INFO] [stdout] 139 |     (from & ((1 << 36) - 1))
[INFO] [stdout]     |     ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 139 -     (from & ((1 << 36) - 1))
[INFO] [stdout] 139 +     from & ((1 << 36) - 1) 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/jackfruit.rs:143:20
[INFO] [stdout]     |
[INFO] [stdout] 143 |     let test_bit = (1 << 35);
[INFO] [stdout]     |                    ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 143 -     let test_bit = (1 << 35);
[INFO] [stdout] 143 +     let test_bit = 1 << 35 ;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/jackfruit.rs:154:5
[INFO] [stdout]     |
[INFO] [stdout] 154 |     (u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1))
[INFO] [stdout]     |     ^                                                            ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -     (u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1))
[INFO] [stdout] 154 +     u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1) 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/jackfruit.rs:784:7
[INFO] [stdout]     |
[INFO] [stdout] 784 |       (1 << 35)
[INFO] [stdout]     |       ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 784 -       (1 << 35)
[INFO] [stdout] 784 +       1 << 35 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/jackfruit.rs:817:7
[INFO] [stdout]     |
[INFO] [stdout] 817 |       (1 << 35)
[INFO] [stdout]     |       ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 817 -       (1 << 35)
[INFO] [stdout] 817 +       1 << 35 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/jackfruit.rs:954:4
[INFO] [stdout]     |
[INFO] [stdout] 954 |   };
[INFO] [stdout]     |    ^ help: remove this semicolon
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(redundant_semicolons)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/jackfruit.rs:959:4
[INFO] [stdout]     |
[INFO] [stdout] 959 |   };
[INFO] [stdout]     |    ^ help: remove this semicolon
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/jackfruit.rs:964:4
[INFO] [stdout]     |
[INFO] [stdout] 964 |   };
[INFO] [stdout]     |    ^ help: remove this semicolon
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around match arm expression
[INFO] [stdout]     --> src/jackfruit.rs:1035:36
[INFO] [stdout]      |
[INFO] [stdout] 1035 |           Arg::Lit(num)         => (num.to_string()),
[INFO] [stdout]      |                                    ^               ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1035 -           Arg::Lit(num)         => (num.to_string()),
[INFO] [stdout] 1035 +           Arg::Lit(num)         => num.to_string() ,
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around match arm expression
[INFO] [stdout]     --> src/jackfruit.rs:1036:36
[INFO] [stdout]      |
[INFO] [stdout] 1036 |           Arg::Pos(pos)         => (locations.get(pos).unwrap().to_string()),
[INFO] [stdout]      |                                    ^                                       ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1036 -           Arg::Pos(pos)         => (locations.get(pos).unwrap().to_string()),
[INFO] [stdout] 1036 +           Arg::Pos(pos)         => locations.get(pos).unwrap().to_string() ,
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around match arm expression
[INFO] [stdout]     --> src/jackfruit.rs:1037:36
[INFO] [stdout]      |
[INFO] [stdout] 1037 |           Arg::Offset(pos, off) => (((*locations.get(pos).unwrap() as i64) + off).to_string()),
[INFO] [stdout]      |                                    ^                                                         ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1037 -           Arg::Offset(pos, off) => (((*locations.get(pos).unwrap() as i64) + off).to_string()),
[INFO] [stdout] 1037 +           Arg::Offset(pos, off) => ((*locations.get(pos).unwrap() as i64) + off).to_string() ,
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `jackfruit::jackfruit_chip`
[INFO] [stdout]   --> src/lib.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use jackfruit::jackfruit_chip;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `#[macro_use]` import
[INFO] [stdout]  --> src/lib.rs:3:1
[INFO] [stdout]   |
[INFO] [stdout] 3 | #[macro_use] extern crate quote;
[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: `fetch in Fetch = super`
[INFO] [stdout]   --> src/potato.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 51 |   - fetch in Fetch = super::super::fetch
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `write_out_state in WriteOutState = super`
[INFO] [stdout]   --> src/potato.rs:55:5
[INFO] [stdout]    |
[INFO] [stdout] 55 |   - write_out_state in WriteOutState = super::super::write_out_state
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `potato::potato_chip`
[INFO] [stdout]  --> src/lib.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use potato::potato_chip;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/unpipelined_potato.rs:33:8
[INFO] [stdout]    |
[INFO] [stdout] 33 |     if (forward_by > 0) {
[INFO] [stdout]    |        ^              ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 33 -     if (forward_by > 0) {
[INFO] [stdout] 33 +     if forward_by > 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/unpipelined_potato.rs:37:14
[INFO] [stdout]    |
[INFO] [stdout] 37 |           if (progress != 0) {
[INFO] [stdout]    |              ^             ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 37 -           if (progress != 0) {
[INFO] [stdout] 37 +           if progress != 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]   --> src/unpipelined_potato.rs:73:5
[INFO] [stdout]    |
[INFO] [stdout] 73 |     (from & ((1 << 36) - 1))
[INFO] [stdout]    |     ^                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 73 -     (from & ((1 << 36) - 1))
[INFO] [stdout] 73 +     from & ((1 << 36) - 1) 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]   --> src/unpipelined_potato.rs:77:20
[INFO] [stdout]    |
[INFO] [stdout] 77 |     let test_bit = (1 << 35);
[INFO] [stdout]    |                    ^       ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 77 -     let test_bit = (1 << 35);
[INFO] [stdout] 77 +     let test_bit = 1 << 35 ;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]   --> src/unpipelined_potato.rs:88:5
[INFO] [stdout]    |
[INFO] [stdout] 88 |     (u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1))
[INFO] [stdout]    |     ^                                                            ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 88 -     (u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1))
[INFO] [stdout] 88 +     u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1) 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fetch in Fetch = super`
[INFO] [stdout]    --> src/unpipelined_potato.rs:120:5
[INFO] [stdout]     |
[INFO] [stdout] 120 |   - fetch in Fetch = super::super::fetch
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `decode in Decode = super`
[INFO] [stdout]    --> src/unpipelined_potato.rs:121:5
[INFO] [stdout]     |
[INFO] [stdout] 121 |   - decode in Decode = super::super::Instructions::decode
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `unpipelined_potato::unpipelined_potato_chip`
[INFO] [stdout]   --> src/lib.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use unpipelined_potato::unpipelined_potato_chip;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/jackfruit.rs:51:8
[INFO] [stdout]    |
[INFO] [stdout] 51 |     if (forward_by > 0) {
[INFO] [stdout]    |        ^              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 51 -     if (forward_by > 0) {
[INFO] [stdout] 51 +     if forward_by > 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/jackfruit.rs:62:14
[INFO] [stdout]    |
[INFO] [stdout] 62 |           if (progress != 0) {
[INFO] [stdout]    |              ^             ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 62 -           if (progress != 0) {
[INFO] [stdout] 62 +           if progress != 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/jackfruit.rs:139:5
[INFO] [stdout]     |
[INFO] [stdout] 139 |     (from & ((1 << 36) - 1))
[INFO] [stdout]     |     ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 139 -     (from & ((1 << 36) - 1))
[INFO] [stdout] 139 +     from & ((1 << 36) - 1) 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/jackfruit.rs:143:20
[INFO] [stdout]     |
[INFO] [stdout] 143 |     let test_bit = (1 << 35);
[INFO] [stdout]     |                    ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 143 -     let test_bit = (1 << 35);
[INFO] [stdout] 143 +     let test_bit = 1 << 35 ;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/jackfruit.rs:154:5
[INFO] [stdout]     |
[INFO] [stdout] 154 |     (u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1))
[INFO] [stdout]     |     ^                                                            ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 154 -     (u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1))
[INFO] [stdout] 154 +     u64::from_ne_bytes(i64::to_ne_bytes(from)) & ((1 << 36) - 1) 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/jackfruit.rs:784:7
[INFO] [stdout]     |
[INFO] [stdout] 784 |       (1 << 35)
[INFO] [stdout]     |       ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 784 -       (1 << 35)
[INFO] [stdout] 784 +       1 << 35 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/jackfruit.rs:817:7
[INFO] [stdout]     |
[INFO] [stdout] 817 |       (1 << 35)
[INFO] [stdout]     |       ^       ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 817 -       (1 << 35)
[INFO] [stdout] 817 +       1 << 35 
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/jackfruit.rs:954:4
[INFO] [stdout]     |
[INFO] [stdout] 954 |   };
[INFO] [stdout]     |    ^ help: remove this semicolon
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(redundant_semicolons)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/jackfruit.rs:959:4
[INFO] [stdout]     |
[INFO] [stdout] 959 |   };
[INFO] [stdout]     |    ^ help: remove this semicolon
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/jackfruit.rs:964:4
[INFO] [stdout]     |
[INFO] [stdout] 964 |   };
[INFO] [stdout]     |    ^ help: remove this semicolon
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around match arm expression
[INFO] [stdout]     --> src/jackfruit.rs:1035:36
[INFO] [stdout]      |
[INFO] [stdout] 1035 |           Arg::Lit(num)         => (num.to_string()),
[INFO] [stdout]      |                                    ^               ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1035 -           Arg::Lit(num)         => (num.to_string()),
[INFO] [stdout] 1035 +           Arg::Lit(num)         => num.to_string() ,
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around match arm expression
[INFO] [stdout]     --> src/jackfruit.rs:1036:36
[INFO] [stdout]      |
[INFO] [stdout] 1036 |           Arg::Pos(pos)         => (locations.get(pos).unwrap().to_string()),
[INFO] [stdout]      |                                    ^                                       ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1036 -           Arg::Pos(pos)         => (locations.get(pos).unwrap().to_string()),
[INFO] [stdout] 1036 +           Arg::Pos(pos)         => locations.get(pos).unwrap().to_string() ,
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around match arm expression
[INFO] [stdout]     --> src/jackfruit.rs:1037:36
[INFO] [stdout]      |
[INFO] [stdout] 1037 |           Arg::Offset(pos, off) => (((*locations.get(pos).unwrap() as i64) + off).to_string()),
[INFO] [stdout]      |                                    ^                                                         ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1037 -           Arg::Offset(pos, off) => (((*locations.get(pos).unwrap() as i64) + off).to_string()),
[INFO] [stdout] 1037 +           Arg::Offset(pos, off) => ((*locations.get(pos).unwrap() as i64) + off).to_string() ,
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `jackfruit::jackfruit_chip`
[INFO] [stdout]   --> src/lib.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use jackfruit::jackfruit_chip;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `input`
[INFO] [stdout]   --> src/potato.rs:23:26
[INFO] [stdout]    |
[INFO] [stdout] 23 |   pub fn write_out_state(input: StateBundle) -> () {
[INFO] [stdout]    |                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_input`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/potato.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |     let mut fetched = fetch(&mem, mem.registers.ip);
[INFO] [stdout]    |         ----^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/potato.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut decoded = match pipeline_outputs.0 {
[INFO] [stdout]    |         ----^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/potato.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let mut assign_architectural_registers = match pipeline_outputs.1 {
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `forward_by`
[INFO] [stdout]   --> src/potato.rs:25:15
[INFO] [stdout]    |
[INFO] [stdout] 25 |   pub fn tick(forward_by: u64, mem: Memories::t, pipeline_outputs: (Option<U36>, Option<Instruction>, Option<Pipeline::MemoryToArchitectu...
[INFO] [stdout]    |               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_forward_by`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fetched`
[INFO] [stdout]   --> src/potato.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |     let mut fetched = fetch(&mem, mem.registers.ip);
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fetched`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `decoded`
[INFO] [stdout]   --> src/potato.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut decoded = match pipeline_outputs.0 {
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_decoded`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `assign_architectural_registers`
[INFO] [stdout]   --> src/potato.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let mut assign_architectural_registers = match pipeline_outputs.1 {
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_assign_architectural_registers`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `forward_by_2`
[INFO] [stdout]   --> src/jackfruit.rs:97:50
[INFO] [stdout]    |
[INFO] [stdout] 97 |             Work::StalledComputing { forward_by: forward_by_2, progress, instruction, mem, waiting_on } => {
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_forward_by_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `forward_by_2`
[INFO] [stdout]    --> src/jackfruit.rs:102:46
[INFO] [stdout]     |
[INFO] [stdout] 102 |         Work::StalledComputing { forward_by: forward_by_2, progress, instruction, mem, waiting_on } => {
[INFO] [stdout]     |                                              ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_forward_by_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]    --> src/jackfruit.rs:225:86
[INFO] [stdout]     |
[INFO] [stdout] 225 |   } -> F *, BackEnd <- 1 (super::super::Instruction::F(super::super::Instructions::F{a, b, c}), mems) => { let mut new_mems = mems; new_m...
[INFO] [stdout]     |                                                                                      ^ help: try ignoring the field: `a: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]    --> src/jackfruit.rs:225:89
[INFO] [stdout]     |
[INFO] [stdout] 225 |   } -> F *, BackEnd <- 1 (super::super::Instruction::F(super::super::Instructions::F{a, b, c}), mems) => { let mut new_mems = mems; new_m...
[INFO] [stdout]     |                                                                                         ^ help: try ignoring the field: `b: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]    --> src/jackfruit.rs:303:13
[INFO] [stdout]     |
[INFO] [stdout] 303 |     let (m, n) = (u36_to_u64(fetch(&mems, a)), u36_to_u64(fetch(&mems, b)));
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/jackfruit.rs:357:10
[INFO] [stdout]     |
[INFO] [stdout] 357 |     let (m, n) = (u36_to_u64(fetch(&mems, a)), u36_to_u64(fetch(&mems, b)));
[INFO] [stdout]     |          ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/jackfruit.rs:492:10
[INFO] [stdout]     |
[INFO] [stdout] 492 |     let (m, n) = (u36_to_u64(fetch(&mems, a)), u36_to_u64(fetch(&mems, b)));
[INFO] [stdout]     |          ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]    --> src/jackfruit.rs:546:13
[INFO] [stdout]     |
[INFO] [stdout] 546 |     let (m, n) = (u36_to_u64(fetch(&mems, a)), u36_to_u64(fetch(&mems, b)));
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]    --> src/jackfruit.rs:623:86
[INFO] [stdout]     |
[INFO] [stdout] 623 |   } -> T *, BackEnd <- 1 (super::super::Instruction::T(super::super::Instructions::T{a, b, c}), mems) => { let mut new_mems = mems; new_m...
[INFO] [stdout]     |                                                                                      ^ help: try ignoring the field: `a: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]    --> src/jackfruit.rs:623:89
[INFO] [stdout]     |
[INFO] [stdout] 623 |   } -> T *, BackEnd <- 1 (super::super::Instruction::T(super::super::Instructions::T{a, b, c}), mems) => { let mut new_mems = mems; new_m...
[INFO] [stdout]     |                                                                                         ^ help: try ignoring the field: `b: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `U10` is never used
[INFO] [stdout]   --> src/potato.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 |   type U10 = u16;
[INFO] [stdout]    |        ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `StateBundle` is never constructed
[INFO] [stdout]   --> src/potato.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 |   pub struct StateBundle {
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MemoryWrite` is never constructed
[INFO] [stdout]   --> src/potato.rs:14:14
[INFO] [stdout]    |
[INFO] [stdout] 14 |   pub struct MemoryWrite {
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fetch` is never used
[INFO] [stdout]   --> src/potato.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 |   pub fn fetch(mem: &Memories::t, input: U10) -> U36 {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_out_state` is never used
[INFO] [stdout]   --> src/potato.rs:23:10
[INFO] [stdout]    |
[INFO] [stdout] 23 |   pub fn write_out_state(input: StateBundle) -> () {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tick` is never used
[INFO] [stdout]   --> src/potato.rs:25:10
[INFO] [stdout]    |
[INFO] [stdout] 25 |   pub fn tick(forward_by: u64, mem: Memories::t, pipeline_outputs: (Option<U36>, Option<Instruction>, Option<Pipeline::MemoryToArchitectu...
[INFO] [stdout]    |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Nop` is never constructed
[INFO] [stdout]   --> src/potato.rs:60:238
[INFO] [stdout]    |
[INFO] [stdout] 60 | ...ions::Nop{}) => { Instruction::Nop(Nop{}) } -> Nop -> pub struct Nop {}, Compute <- 2 super::MemoryToArchitecturalRegisters::Instructi...
[INFO] [stdout]    |                                                                     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]   --> src/potato.rs:19:14
[INFO] [stdout]    |
[INFO] [stdout] 19 |       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]    = note: the `panic!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout]    = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]    |
[INFO] [stdout] 19 -       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout] 19 +       panic!("fetch from outside of bounds: {}", input);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Fetch` should have a snake case name
[INFO] [stdout]   --> src/potato.rs:51:14
[INFO] [stdout]    |
[INFO] [stdout] 51 |   - fetch in Fetch = super::super::fetch
[INFO] [stdout]    |              ^^^^^ help: convert the identifier to snake case (notice the capitalization): `fetch`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Decode` should have a snake case name
[INFO] [stdout]   --> src/potato.rs:52:15
[INFO] [stdout]    |
[INFO] [stdout] 52 |   - decode in Decode = super::super::Instructions::decode
[INFO] [stdout]    |               ^^^^^^ help: convert the identifier to snake case: `decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `MemoryToArchitecturalRegisters` should have a snake case name
[INFO] [stdout]   --> src/potato.rs:53:41
[INFO] [stdout]    |
[INFO] [stdout] 53 |   - memory_to_architecture_registers in MemoryToArchitecturalRegisters: super::super::Instruction -> Instruction
[INFO] [stdout]    |                                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `memory_to_architectural_registers`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Compute` should have a snake case name
[INFO] [stdout]   --> src/potato.rs:54:16
[INFO] [stdout]    |
[INFO] [stdout] 54 |   - compute in Compute: super::MemoryToArchitecturalRegisters::Instruction -> super::super::StateBundle
[INFO] [stdout]    |                ^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `compute`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `WriteOutState` should have a snake case name
[INFO] [stdout]   --> src/potato.rs:55:24
[INFO] [stdout]    |
[INFO] [stdout] 55 |   - write_out_state in WriteOutState = super::super::write_out_state
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: convert the identifier to snake case: `write_out_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]   --> src/unpipelined_potato.rs:19:14
[INFO] [stdout]    |
[INFO] [stdout] 19 |       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]    = note: the `panic!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]    |
[INFO] [stdout] 19 -       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout] 19 +       panic!("fetch from outside of bounds: {}", input);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clampU` should have a snake case name
[INFO] [stdout]   --> src/unpipelined_potato.rs:90:10
[INFO] [stdout]    |
[INFO] [stdout] 90 |   pub fn clampU(from: u64, max: u64) -> u64 {
[INFO] [stdout]    |          ^^^^^^ help: convert the identifier to snake case: `clamp_u`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clampS` should have a snake case name
[INFO] [stdout]   --> src/unpipelined_potato.rs:97:10
[INFO] [stdout]    |
[INFO] [stdout] 97 |   pub fn clampS(from: i64, max: i64, min: i64) -> i64 {
[INFO] [stdout]    |          ^^^^^^ help: convert the identifier to snake case: `clamp_s`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Fetch` should have a snake case name
[INFO] [stdout]    --> src/unpipelined_potato.rs:120:14
[INFO] [stdout]     |
[INFO] [stdout] 120 |   - fetch in Fetch = super::super::fetch
[INFO] [stdout]     |              ^^^^^ help: convert the identifier to snake case (notice the capitalization): `fetch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Decode` should have a snake case name
[INFO] [stdout]    --> src/unpipelined_potato.rs:121:15
[INFO] [stdout]     |
[INFO] [stdout] 121 |   - decode in Decode = super::super::Instructions::decode
[INFO] [stdout]     |               ^^^^^^ help: convert the identifier to snake case: `decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `BackEnd` should have a snake case name
[INFO] [stdout]    --> src/unpipelined_potato.rs:122:17
[INFO] [stdout]     |
[INFO] [stdout] 122 |   - back_end in BackEnd: super::super::MachineState -> super::super::Memories::t
[INFO] [stdout]     |                 ^^^^^^^ help: convert the identifier to snake case: `back_end`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]   --> src/jackfruit.rs:21:14
[INFO] [stdout]    |
[INFO] [stdout] 21 |       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]    = note: the `panic!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]    |
[INFO] [stdout] 21 -       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout] 21 +       panic!("fetch from outside of bounds: {}", input);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clampU` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:163:10
[INFO] [stdout]     |
[INFO] [stdout] 163 |   pub fn clampU(from: u64, max: u64) -> u64 {
[INFO] [stdout]     |          ^^^^^^ help: convert the identifier to snake case: `clamp_u`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clampS` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:170:10
[INFO] [stdout]     |
[INFO] [stdout] 170 |   pub fn clampS(from: i64, max: i64, min: i64) -> i64 {
[INFO] [stdout]     |          ^^^^^^ help: convert the identifier to snake case: `clamp_s`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Fetch` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:197:14
[INFO] [stdout]     |
[INFO] [stdout] 197 |   - fetch in Fetch = super::super::fetch
[INFO] [stdout]     |              ^^^^^ help: convert the identifier to snake case (notice the capitalization): `fetch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Decode` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:198:15
[INFO] [stdout]     |
[INFO] [stdout] 198 |   - decode in Decode = super::super::Instructions::decode
[INFO] [stdout]     |               ^^^^^^ help: convert the identifier to snake case: `decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `CheckStall` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:199:20
[INFO] [stdout]     |
[INFO] [stdout] 199 |   - check_stall in CheckStall: super::super::MachineState -> super::super::Work
[INFO] [stdout]     |                    ^^^^^^^^^^ help: convert the identifier to snake case: `check_stall`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `BackEnd` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:200:17
[INFO] [stdout]     |
[INFO] [stdout] 200 |   - back_end in BackEnd: super::super::MachineState -> super::super::Memories::t
[INFO] [stdout]     |                 ^^^^^^^ help: convert the identifier to snake case: `back_end`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `input`
[INFO] [stdout]   --> src/potato.rs:23:26
[INFO] [stdout]    |
[INFO] [stdout] 23 |   pub fn write_out_state(input: StateBundle) -> () {
[INFO] [stdout]    |                          ^^^^^ help: if this is intentional, prefix it with an underscore: `_input`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/potato.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |     let mut fetched = fetch(&mem, mem.registers.ip);
[INFO] [stdout]    |         ----^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/potato.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut decoded = match pipeline_outputs.0 {
[INFO] [stdout]    |         ----^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/potato.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let mut assign_architectural_registers = match pipeline_outputs.1 {
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `forward_by`
[INFO] [stdout]   --> src/potato.rs:25:15
[INFO] [stdout]    |
[INFO] [stdout] 25 |   pub fn tick(forward_by: u64, mem: Memories::t, pipeline_outputs: (Option<U36>, Option<Instruction>, Option<Pipeline::MemoryToArchitectu...
[INFO] [stdout]    |               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_forward_by`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fetched`
[INFO] [stdout]   --> src/potato.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |     let mut fetched = fetch(&mem, mem.registers.ip);
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_fetched`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `decoded`
[INFO] [stdout]   --> src/potato.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut decoded = match pipeline_outputs.0 {
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_decoded`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `assign_architectural_registers`
[INFO] [stdout]   --> src/potato.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let mut assign_architectural_registers = match pipeline_outputs.1 {
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_assign_architectural_registers`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `forward_by_2`
[INFO] [stdout]   --> src/jackfruit.rs:97:50
[INFO] [stdout]    |
[INFO] [stdout] 97 |             Work::StalledComputing { forward_by: forward_by_2, progress, instruction, mem, waiting_on } => {
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_forward_by_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `forward_by_2`
[INFO] [stdout]    --> src/jackfruit.rs:102:46
[INFO] [stdout]     |
[INFO] [stdout] 102 |         Work::StalledComputing { forward_by: forward_by_2, progress, instruction, mem, waiting_on } => {
[INFO] [stdout]     |                                              ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_forward_by_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]    --> src/jackfruit.rs:225:86
[INFO] [stdout]     |
[INFO] [stdout] 225 |   } -> F *, BackEnd <- 1 (super::super::Instruction::F(super::super::Instructions::F{a, b, c}), mems) => { let mut new_mems = mems; new_m...
[INFO] [stdout]     |                                                                                      ^ help: try ignoring the field: `a: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]    --> src/jackfruit.rs:225:89
[INFO] [stdout]     |
[INFO] [stdout] 225 |   } -> F *, BackEnd <- 1 (super::super::Instruction::F(super::super::Instructions::F{a, b, c}), mems) => { let mut new_mems = mems; new_m...
[INFO] [stdout]     |                                                                                         ^ help: try ignoring the field: `b: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]    --> src/jackfruit.rs:303:13
[INFO] [stdout]     |
[INFO] [stdout] 303 |     let (m, n) = (u36_to_u64(fetch(&mems, a)), u36_to_u64(fetch(&mems, b)));
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/jackfruit.rs:357:10
[INFO] [stdout]     |
[INFO] [stdout] 357 |     let (m, n) = (u36_to_u64(fetch(&mems, a)), u36_to_u64(fetch(&mems, b)));
[INFO] [stdout]     |          ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/jackfruit.rs:492:10
[INFO] [stdout]     |
[INFO] [stdout] 492 |     let (m, n) = (u36_to_u64(fetch(&mems, a)), u36_to_u64(fetch(&mems, b)));
[INFO] [stdout]     |          ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]    --> src/jackfruit.rs:546:13
[INFO] [stdout]     |
[INFO] [stdout] 546 |     let (m, n) = (u36_to_u64(fetch(&mems, a)), u36_to_u64(fetch(&mems, b)));
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]    --> src/jackfruit.rs:623:86
[INFO] [stdout]     |
[INFO] [stdout] 623 |   } -> T *, BackEnd <- 1 (super::super::Instruction::T(super::super::Instructions::T{a, b, c}), mems) => { let mut new_mems = mems; new_m...
[INFO] [stdout]     |                                                                                      ^ help: try ignoring the field: `a: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]    --> src/jackfruit.rs:623:89
[INFO] [stdout]     |
[INFO] [stdout] 623 |   } -> T *, BackEnd <- 1 (super::super::Instruction::T(super::super::Instructions::T{a, b, c}), mems) => { let mut new_mems = mems; new_m...
[INFO] [stdout]     |                                                                                         ^ help: try ignoring the field: `b: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `U10` is never used
[INFO] [stdout]   --> src/potato.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 |   type U10 = u16;
[INFO] [stdout]    |        ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `StateBundle` is never constructed
[INFO] [stdout]   --> src/potato.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 |   pub struct StateBundle {
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MemoryWrite` is never constructed
[INFO] [stdout]   --> src/potato.rs:14:14
[INFO] [stdout]    |
[INFO] [stdout] 14 |   pub struct MemoryWrite {
[INFO] [stdout]    |              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fetch` is never used
[INFO] [stdout]   --> src/potato.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 |   pub fn fetch(mem: &Memories::t, input: U10) -> U36 {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_out_state` is never used
[INFO] [stdout]   --> src/potato.rs:23:10
[INFO] [stdout]    |
[INFO] [stdout] 23 |   pub fn write_out_state(input: StateBundle) -> () {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tick` is never used
[INFO] [stdout]   --> src/potato.rs:25:10
[INFO] [stdout]    |
[INFO] [stdout] 25 |   pub fn tick(forward_by: u64, mem: Memories::t, pipeline_outputs: (Option<U36>, Option<Instruction>, Option<Pipeline::MemoryToArchitectu...
[INFO] [stdout]    |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Nop` is never constructed
[INFO] [stdout]   --> src/potato.rs:60:238
[INFO] [stdout]    |
[INFO] [stdout] 60 | ...ions::Nop{}) => { Instruction::Nop(Nop{}) } -> Nop -> pub struct Nop {}, Compute <- 2 super::MemoryToArchitecturalRegisters::Instructi...
[INFO] [stdout]    |                                                                     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `MachineState` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 |   type MachineState = (Instruction, Memories::t);
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Work` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 |   pub enum Work {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fetch` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 |   pub fn fetch(mem: &Memories::t, input: U10) -> U36 {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_mem` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:23:10
[INFO] [stdout]    |
[INFO] [stdout] 23 |   pub fn get_mem(work: Work) -> Memories::t {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `begin_tick` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:29:10
[INFO] [stdout]    |
[INFO] [stdout] 29 |   pub fn begin_tick(forward_by: u32, mem: Memories::t) -> Work {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tick` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:32:10
[INFO] [stdout]    |
[INFO] [stdout] 32 |   pub fn tick(forward_by: u32, working: Work) -> Work {
[INFO] [stdout]    |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `u36_to_u64` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:69:10
[INFO] [stdout]    |
[INFO] [stdout] 69 |   pub fn u36_to_u64(from: U36) -> u64 {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `u64_to_u36` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:72:10
[INFO] [stdout]    |
[INFO] [stdout] 72 |   pub fn u64_to_u36(from: u64) -> U36 {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `u36_to_i64` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:75:10
[INFO] [stdout]    |
[INFO] [stdout] 75 |   pub fn u36_to_i64(from: U36) -> i64 {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `i64_to_u36` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:85:10
[INFO] [stdout]    |
[INFO] [stdout] 85 |   pub fn i64_to_u36(from: i64) -> U36 {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clampU` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:90:10
[INFO] [stdout]    |
[INFO] [stdout] 90 |   pub fn clampU(from: u64, max: u64) -> u64 {
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clampS` is never used
[INFO] [stdout]   --> src/unpipelined_potato.rs:97:10
[INFO] [stdout]    |
[INFO] [stdout] 97 |   pub fn clampS(from: i64, max: i64, min: i64) -> i64 {
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]   --> src/potato.rs:19:14
[INFO] [stdout]    |
[INFO] [stdout] 19 |       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]    = note: the `panic!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout]    = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]    |
[INFO] [stdout] 19 -       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout] 19 +       panic!("fetch from outside of bounds: {}", input);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Fetch` should have a snake case name
[INFO] [stdout]   --> src/potato.rs:51:14
[INFO] [stdout]    |
[INFO] [stdout] 51 |   - fetch in Fetch = super::super::fetch
[INFO] [stdout]    |              ^^^^^ help: convert the identifier to snake case (notice the capitalization): `fetch`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Decode` should have a snake case name
[INFO] [stdout]   --> src/potato.rs:52:15
[INFO] [stdout]    |
[INFO] [stdout] 52 |   - decode in Decode = super::super::Instructions::decode
[INFO] [stdout]    |               ^^^^^^ help: convert the identifier to snake case: `decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `MemoryToArchitecturalRegisters` should have a snake case name
[INFO] [stdout]   --> src/potato.rs:53:41
[INFO] [stdout]    |
[INFO] [stdout] 53 |   - memory_to_architecture_registers in MemoryToArchitecturalRegisters: super::super::Instruction -> Instruction
[INFO] [stdout]    |                                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `memory_to_architectural_registers`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Compute` should have a snake case name
[INFO] [stdout]   --> src/potato.rs:54:16
[INFO] [stdout]    |
[INFO] [stdout] 54 |   - compute in Compute: super::MemoryToArchitecturalRegisters::Instruction -> super::super::StateBundle
[INFO] [stdout]    |                ^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `compute`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `WriteOutState` should have a snake case name
[INFO] [stdout]   --> src/potato.rs:55:24
[INFO] [stdout]    |
[INFO] [stdout] 55 |   - write_out_state in WriteOutState = super::super::write_out_state
[INFO] [stdout]    |                        ^^^^^^^^^^^^^ help: convert the identifier to snake case: `write_out_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]   --> src/unpipelined_potato.rs:19:14
[INFO] [stdout]    |
[INFO] [stdout] 19 |       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]    = note: the `panic!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]    |
[INFO] [stdout] 19 -       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout] 19 +       panic!("fetch from outside of bounds: {}", input);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clampU` should have a snake case name
[INFO] [stdout]   --> src/unpipelined_potato.rs:90:10
[INFO] [stdout]    |
[INFO] [stdout] 90 |   pub fn clampU(from: u64, max: u64) -> u64 {
[INFO] [stdout]    |          ^^^^^^ help: convert the identifier to snake case: `clamp_u`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clampS` should have a snake case name
[INFO] [stdout]   --> src/unpipelined_potato.rs:97:10
[INFO] [stdout]    |
[INFO] [stdout] 97 |   pub fn clampS(from: i64, max: i64, min: i64) -> i64 {
[INFO] [stdout]    |          ^^^^^^ help: convert the identifier to snake case: `clamp_s`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Fetch` should have a snake case name
[INFO] [stdout]    --> src/unpipelined_potato.rs:120:14
[INFO] [stdout]     |
[INFO] [stdout] 120 |   - fetch in Fetch = super::super::fetch
[INFO] [stdout]     |              ^^^^^ help: convert the identifier to snake case (notice the capitalization): `fetch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Decode` should have a snake case name
[INFO] [stdout]    --> src/unpipelined_potato.rs:121:15
[INFO] [stdout]     |
[INFO] [stdout] 121 |   - decode in Decode = super::super::Instructions::decode
[INFO] [stdout]     |               ^^^^^^ help: convert the identifier to snake case: `decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `BackEnd` should have a snake case name
[INFO] [stdout]    --> src/unpipelined_potato.rs:122:17
[INFO] [stdout]     |
[INFO] [stdout] 122 |   - back_end in BackEnd: super::super::MachineState -> super::super::Memories::t
[INFO] [stdout]     |                 ^^^^^^^ help: convert the identifier to snake case: `back_end`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]   --> src/jackfruit.rs:21:14
[INFO] [stdout]    |
[INFO] [stdout] 21 |       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]    = note: the `panic!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]    |
[INFO] [stdout] 21 -       panic!(format!("fetch from outside of bounds: {}", input));
[INFO] [stdout] 21 +       panic!("fetch from outside of bounds: {}", input);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clampU` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:163:10
[INFO] [stdout]     |
[INFO] [stdout] 163 |   pub fn clampU(from: u64, max: u64) -> u64 {
[INFO] [stdout]     |          ^^^^^^ help: convert the identifier to snake case: `clamp_u`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clampS` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:170:10
[INFO] [stdout]     |
[INFO] [stdout] 170 |   pub fn clampS(from: i64, max: i64, min: i64) -> i64 {
[INFO] [stdout]     |          ^^^^^^ help: convert the identifier to snake case: `clamp_s`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Fetch` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:197:14
[INFO] [stdout]     |
[INFO] [stdout] 197 |   - fetch in Fetch = super::super::fetch
[INFO] [stdout]     |              ^^^^^ help: convert the identifier to snake case (notice the capitalization): `fetch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `Decode` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:198:15
[INFO] [stdout]     |
[INFO] [stdout] 198 |   - decode in Decode = super::super::Instructions::decode
[INFO] [stdout]     |               ^^^^^^ help: convert the identifier to snake case: `decode`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `CheckStall` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:199:20
[INFO] [stdout]     |
[INFO] [stdout] 199 |   - check_stall in CheckStall: super::super::MachineState -> super::super::Work
[INFO] [stdout]     |                    ^^^^^^^^^^ help: convert the identifier to snake case: `check_stall`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `BackEnd` should have a snake case name
[INFO] [stdout]    --> src/jackfruit.rs:200:17
[INFO] [stdout]     |
[INFO] [stdout] 200 |   - back_end in BackEnd: super::super::MachineState -> super::super::Memories::t
[INFO] [stdout]     |                 ^^^^^^^ help: convert the identifier to snake case: `back_end`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Matches`
[INFO] [stdout]  --> src/bin/fantasy_assembler.rs:3:23
[INFO] [stdout]   |
[INFO] [stdout] 3 | use getopts::{Options,Matches};
[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: `fantasy_cpu_emulator::jackfruit`
[INFO] [stdout]  --> src/bin/fantasy_emulator.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use fantasy_cpu_emulator::jackfruit;
[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: `Matches`
[INFO] [stdout]  --> src/bin/fantasy_assembler.rs:3:23
[INFO] [stdout]   |
[INFO] [stdout] 3 | use getopts::{Options,Matches};
[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: `fantasy_cpu_emulator::jackfruit`
[INFO] [stdout]  --> src/bin/fantasy_emulator.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use fantasy_cpu_emulator::jackfruit;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 9.92s
[INFO] running `Command { std: "docker" "inspect" "be3ca473e9ec530aa3132c5b28cd025c9362250243f2dd3ad31b7ab025250708", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "be3ca473e9ec530aa3132c5b28cd025c9362250243f2dd3ad31b7ab025250708", kill_on_drop: false }`
[INFO] [stdout] be3ca473e9ec530aa3132c5b28cd025c9362250243f2dd3ad31b7ab025250708
