[INFO] cloning repository https://github.com/mdsherry/randomizer
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/mdsherry/randomizer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmdsherry%2Frandomizer", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmdsherry%2Frandomizer'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 8d09c665d25b81c7d527f7635ef181378d49b73f
[INFO] checking mdsherry/randomizer against master#642c19bfc3a5c1de985bf5d0cc8207ac9d22708a for pr-148577
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmdsherry%2Frandomizer" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/mdsherry/randomizer
[INFO] finished tweaking git repo https://github.com/mdsherry/randomizer
[INFO] tweaked toml for git repo https://github.com/mdsherry/randomizer written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/mdsherry/randomizer 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 git repo https://github.com/mdsherry/randomizer 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]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded proc-macro2 v1.0.32
[INFO] [stderr]   Downloaded openssl-probe v0.1.4
[INFO] [stderr]   Downloaded git-version-macro v0.3.5
[INFO] [stderr]   Downloaded pkg-config v0.3.22
[INFO] [stderr]   Downloaded unicode_reader v1.0.1
[INFO] [stderr]   Downloaded ref_thread_local v0.0.0
[INFO] [stderr]   Downloaded divrem v0.1.0
[INFO] [stderr]   Downloaded git-version v0.3.5
[INFO] [stderr]   Downloaded dirs-next v1.0.2
[INFO] [stderr]   Downloaded ordered-float v0.5.2
[INFO] [stderr]   Downloaded ed25519 v1.2.0
[INFO] [stderr]   Downloaded string_cache v0.7.5
[INFO] [stderr]   Downloaded joinery v2.1.0
[INFO] [stderr]   Downloaded cpu-time v1.0.0
[INFO] [stderr]   Downloaded once_cell v1.8.0
[INFO] [stderr]   Downloaded anyhow v1.0.53
[INFO] [stderr]   Downloaded security-framework v2.4.2
[INFO] [stderr]   Downloaded openssl-sys v0.9.70
[INFO] [stderr]   Downloaded crossterm v0.16.0
[INFO] [stderr]   Downloaded serde_json v1.0.70
[INFO] [stderr]   Downloaded lexical v2.2.4
[INFO] [stderr]   Downloaded openssl v0.10.38
[INFO] [stderr]   Downloaded syn v1.0.81
[INFO] [stderr]   Downloaded nix v0.18.0
[INFO] [stderr]   Downloaded rustyline v6.3.0
[INFO] [stderr]   Downloaded rug v1.13.0
[INFO] [stderr]   Downloaded unicode-segmentation v1.8.0
[INFO] [stderr]   Downloaded roxmltree v0.11.0
[INFO] [stderr]   Downloaded native-tls v0.2.8
[INFO] [stderr]   Downloaded az v1.1.2
[INFO] [stderr]   Downloaded lexical-core v0.4.8
[INFO] [stderr]   Downloaded typenum v1.14.0
[INFO] [stderr]   Downloaded quote v1.0.10
[INFO] [stderr]   Downloaded dirs-sys v0.3.6
[INFO] [stderr]   Downloaded tempfile v3.2.0
[INFO] [stderr]   Downloaded security-framework-sys v2.4.2
[INFO] [stderr]   Downloaded redox_users v0.4.0
[INFO] [stderr]   Downloaded signature v1.4.0
[INFO] [stderr]   Downloaded sodiumoxide v0.2.7
[INFO] [stderr]   Downloaded libsodium-sys v0.2.7
[INFO] [stderr]   Downloaded gmp-mpfr-sys v1.4.7
[INFO] [stderr]   Downloaded prolog_parser v0.8.68
[INFO] [stderr]   Downloaded openssl-src v300.0.2+3.0.0
[INFO] [stderr]   Downloaded select v0.4.3
[INFO] [stderr]   Downloaded scryer-prolog v0.8.127
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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] 27d47642a52618776822096f06057f147a4e5c83a5c2297073945cce5f16d57e
[INFO] running `Command { std: "docker" "start" "-a" "27d47642a52618776822096f06057f147a4e5c83a5c2297073945cce5f16d57e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "27d47642a52618776822096f06057f147a4e5c83a5c2297073945cce5f16d57e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "27d47642a52618776822096f06057f147a4e5c83a5c2297073945cce5f16d57e", kill_on_drop: false }`
[INFO] [stdout] 27d47642a52618776822096f06057f147a4e5c83a5c2297073945cce5f16d57e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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] 8bf38fad5b62fd3b9ad75722fe4c62204153bc73d5ac57d8429eacf62dcd393b
[INFO] running `Command { std: "docker" "start" "-a" "8bf38fad5b62fd3b9ad75722fe4c62204153bc73d5ac57d8429eacf62dcd393b", kill_on_drop: false }`
[INFO] [stderr] warning: minish-random v0.1.0 (/opt/rustwide/workdir) ignoring invalid dependency `scryer-prolog` which is missing a lib target
[INFO] [stderr]    Compiling proc-macro2 v1.0.32
[INFO] [stderr]    Compiling syn v1.0.81
[INFO] [stderr]    Compiling libc v0.2.107
[INFO] [stderr]    Compiling indexmap v1.7.0
[INFO] [stderr]     Checking unicode-width v0.1.9
[INFO] [stderr]    Compiling unicode-segmentation v1.8.0
[INFO] [stderr]    Compiling anyhow v1.0.53
[INFO] [stderr]     Checking ppv-lite86 v0.2.15
[INFO] [stderr]     Checking textwrap v0.11.0
[INFO] [stderr]     Checking yaml-rust v0.4.5
[INFO] [stderr]     Checking regex v1.5.4
[INFO] [stderr]    Compiling heck v0.3.3
[INFO] [stderr]     Checking joinery v2.1.0
[INFO] [stderr]     Checking heck v0.4.0
[INFO] [stderr]    Compiling quote v1.0.10
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]     Checking getrandom v0.2.3
[INFO] [stderr]     Checking atty v0.2.14
[INFO] [stderr]     Checking clap v2.34.0
[INFO] [stderr]     Checking rand_core v0.6.3
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand v0.8.4
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling serde_derive v1.0.136
[INFO] [stderr]    Compiling thiserror-impl v1.0.30
[INFO] [stderr]    Compiling structopt-derive v0.4.18
[INFO] [stderr]     Checking structopt v0.3.26
[INFO] [stderr]     Checking thiserror v1.0.30
[INFO] [stderr]     Checking serde v1.0.136
[INFO] [stderr]     Checking serde_yaml v0.8.23
[INFO] [stderr]     Checking minish-random v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `HashMap`, `HashSet`, `hash::Hash`, and `io::Error`
[INFO] [stdout]  --> src/main.rs:1:11
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{io::Error, path::Path, collections::{HashMap, HashSet}, hash::Hash};
[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: `HashSet`
[INFO] [stdout]  --> src/logic/condition.rs:1:34
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{collections::{HashMap, HashSet}, rc::Rc, vec};
[INFO] [stdout]   |                                  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HashMap`, `HashSet`, `hash::Hash`, and `io::Error`
[INFO] [stdout]  --> src/main.rs:1:11
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{io::Error, path::Path, collections::{HashMap, HashSet}, hash::Hash};
[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: `HashSet`
[INFO] [stdout]  --> src/logic/condition.rs:1:34
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{collections::{HashMap, HashSet}, rc::Rc, vec};
[INFO] [stdout]   |                                  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused macro definition: `cond_or`
[INFO] [stdout]  --> src/main.rs:6:14
[INFO] [stdout]   |
[INFO] [stdout] 6 | macro_rules! cond_or {
[INFO] [stdout]   |              ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_macros)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused macro definition: `cond_and`
[INFO] [stdout]   --> src/main.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 | macro_rules! cond_and {
[INFO] [stdout]    |              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Item` and `PreLogic`
[INFO] [stdout]   --> src/main.rs:68:13
[INFO] [stdout]    |
[INFO] [stdout] 68 | use logic::{PreLogic, Allocator, Item, LogicLoader, AssignmentChecker};
[INFO] [stdout]    |             ^^^^^^^^             ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `logic_parse::parse_logic`
[INFO] [stdout]   --> src/main.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 | use logic_parse::parse_logic;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused macro definition: `cond_or`
[INFO] [stdout]  --> src/main.rs:6:14
[INFO] [stdout]   |
[INFO] [stdout] 6 | macro_rules! cond_or {
[INFO] [stdout]   |              ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_macros)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused macro definition: `cond_and`
[INFO] [stdout]   --> src/main.rs:11:14
[INFO] [stdout]    |
[INFO] [stdout] 11 | macro_rules! cond_and {
[INFO] [stdout]    |              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Item` and `PreLogic`
[INFO] [stdout]   --> src/main.rs:68:13
[INFO] [stdout]    |
[INFO] [stdout] 68 | use logic::{PreLogic, Allocator, Item, LogicLoader, AssignmentChecker};
[INFO] [stdout]    |             ^^^^^^^^             ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `logic_parse::parse_logic`
[INFO] [stdout]   --> src/main.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 | use logic_parse::parse_logic;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `req_str`
[INFO] [stdout]   --> src/logic_parse.rs:29:17
[INFO] [stdout]    |
[INFO] [stdout] 29 |             let req_str = gen_reqs(&reqs);
[INFO] [stdout]    |                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_req_str`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `var_name`
[INFO] [stdout]   --> src/logic_parse.rs:30:17
[INFO] [stdout]    |
[INFO] [stdout] 30 |             let var_name = bits[0].split(':').next().expect("Always at least one piece");
[INFO] [stdout]    |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_var_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `req_str`
[INFO] [stdout]   --> src/logic_parse.rs:38:17
[INFO] [stdout]    |
[INFO] [stdout] 38 |             let req_str = gen_reqs(&reqs);
[INFO] [stdout]    |                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_req_str`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `var_name`
[INFO] [stdout]   --> src/logic_parse.rs:39:17
[INFO] [stdout]    |
[INFO] [stdout] 39 |             let var_name = location[0].to_snake_case();
[INFO] [stdout]    |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_var_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `category`
[INFO] [stdout]   --> src/logic_parse.rs:40:17
[INFO] [stdout]    |
[INFO] [stdout] 40 |             let category = if location.len() > 1 {
[INFO] [stdout]    |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_category`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `item`
[INFO] [stdout]   --> src/logic_parse.rs:56:9
[INFO] [stdout]    |
[INFO] [stdout] 56 |     for item in items {
[INFO] [stdout]    |         ^^^^ help: if this is intentional, prefix it with an underscore: `_item`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `req_str`
[INFO] [stdout]   --> src/logic_parse.rs:29:17
[INFO] [stdout]    |
[INFO] [stdout] 29 |             let req_str = gen_reqs(&reqs);
[INFO] [stdout]    |                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_req_str`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `var_name`
[INFO] [stdout]   --> src/logic_parse.rs:30:17
[INFO] [stdout]    |
[INFO] [stdout] 30 |             let var_name = bits[0].split(':').next().expect("Always at least one piece");
[INFO] [stdout]    |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_var_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `req_str`
[INFO] [stdout]   --> src/logic_parse.rs:38:17
[INFO] [stdout]    |
[INFO] [stdout] 38 |             let req_str = gen_reqs(&reqs);
[INFO] [stdout]    |                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_req_str`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `var_name`
[INFO] [stdout]   --> src/logic_parse.rs:39:17
[INFO] [stdout]    |
[INFO] [stdout] 39 |             let var_name = location[0].to_snake_case();
[INFO] [stdout]    |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_var_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `category`
[INFO] [stdout]   --> src/logic_parse.rs:40:17
[INFO] [stdout]    |
[INFO] [stdout] 40 |             let category = if location.len() > 1 {
[INFO] [stdout]    |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_category`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `item`
[INFO] [stdout]   --> src/logic_parse.rs:56:9
[INFO] [stdout]    |
[INFO] [stdout] 56 |     for item in items {
[INFO] [stdout]    |         ^^^^ help: if this is intentional, prefix it with an underscore: `_item`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Rom` is never constructed
[INFO] [stdout]   --> src/main.rs:33:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | struct Rom {
[INFO] [stdout]    |        ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `read_at` are never used
[INFO] [stdout]   --> src/main.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 38 | impl Rom {
[INFO] [stdout]    | -------- associated items in this implementation
[INFO] [stdout] 39 |     fn new(fname: &Path) -> Result<Self, std::io::Error> {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     fn read_at<const N: usize>(&self, pos: usize) -> [u8; N] {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_logic` is never used
[INFO] [stdout]  --> src/logic_parse.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub fn parse_logic(s: &str) {
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_items` is never used
[INFO] [stdout]   --> src/logic_parse.rs:69:4
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn get_items(terms: &[Term], collected: &mut HashSet<String>) {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gen_reqs` is never used
[INFO] [stdout]   --> src/logic_parse.rs:85:4
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn gen_reqs(terms: &[Term<'_>]) -> String {
[INFO] [stdout]    |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gen_req` is never used
[INFO] [stdout]   --> src/logic_parse.rs:93:4
[INFO] [stdout]    |
[INFO] [stdout] 93 | fn gen_req(term: &Term) -> String {
[INFO] [stdout]    |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HeaderData` is never constructed
[INFO] [stdout]  --> src/header.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub struct HeaderData {
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EU_HEADER_DATA` is never used
[INFO] [stdout]   --> src/header.rs:21:11
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub const EU_HEADER_DATA: HeaderData = HeaderData {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_header` is never used
[INFO] [stdout]   --> src/header.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub fn get_header(region: RomVersion) -> &'static HeaderData {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `items` is never read
[INFO] [stdout]   --> src/logic.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct Logic {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] 21 |     pub items: Vec<(Rc<ItemDef>, ItemCondition)>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_item` is never used
[INFO] [stdout]    --> src/logic.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl PreLogic {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn get_item(&self, id: ItemId) -> Option<&PreItemDef> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Item` is never constructed
[INFO] [stdout]    --> src/logic.rs:239:12
[INFO] [stdout]     |
[INFO] [stdout] 239 | pub struct Item {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/logic.rs:253:12
[INFO] [stdout]     |
[INFO] [stdout] 252 | impl Item {
[INFO] [stdout]     | --------- associated function in this implementation
[INFO] [stdout] 253 |     pub fn new(def: Rc<ItemDef>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `complexity` is never used
[INFO] [stdout]   --> src/logic/condition.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout] 64 | impl ItemCondition {
[INFO] [stdout]    | ------------------ method in this implementation
[INFO] [stdout] 65 |     pub fn complexity(&self) -> u32 {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `preflight_check` is never used
[INFO] [stdout]   --> src/logic/allocator.rs:46:8
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl Allocator {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     fn preflight_check(&self) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `typ` is never read
[INFO] [stdout]   --> src/logic/logic_loader.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | struct ParameterData {
[INFO] [stdout]    |        ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 23 |     typ: ParameterType,
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParameterData` 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: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/logic_parse.rs:171:26
[INFO] [stdout]     |
[INFO] [stdout] 171 | pub fn parse_reqs(mut s: &str) -> (Vec<Term>, &str) {
[INFO] [stdout]     |                          ^^^^          ^^^^   ^^^^ the same lifetime is elided here
[INFO] [stdout]     |                          |             |
[INFO] [stdout]     |                          |             the same lifetime is hidden here
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 171 | pub fn parse_reqs(mut s: &str) -> (Vec<Term<'_>>, &str) {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Rom` is never constructed
[INFO] [stdout]   --> src/main.rs:33:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | struct Rom {
[INFO] [stdout]    |        ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `read_at` are never used
[INFO] [stdout]   --> src/main.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 38 | impl Rom {
[INFO] [stdout]    | -------- associated items in this implementation
[INFO] [stdout] 39 |     fn new(fname: &Path) -> Result<Self, std::io::Error> {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     fn read_at<const N: usize>(&self, pos: usize) -> [u8; N] {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_logic` is never used
[INFO] [stdout]  --> src/logic_parse.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub fn parse_logic(s: &str) {
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_items` is never used
[INFO] [stdout]   --> src/logic_parse.rs:69:4
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn get_items(terms: &[Term], collected: &mut HashSet<String>) {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gen_reqs` is never used
[INFO] [stdout]   --> src/logic_parse.rs:85:4
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn gen_reqs(terms: &[Term<'_>]) -> String {
[INFO] [stdout]    |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gen_req` is never used
[INFO] [stdout]   --> src/logic_parse.rs:93:4
[INFO] [stdout]    |
[INFO] [stdout] 93 | fn gen_req(term: &Term) -> String {
[INFO] [stdout]    |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HeaderData` is never constructed
[INFO] [stdout]  --> src/header.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub struct HeaderData {
[INFO] [stdout]   |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EU_HEADER_DATA` is never used
[INFO] [stdout]   --> src/header.rs:21:11
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub const EU_HEADER_DATA: HeaderData = HeaderData {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_header` is never used
[INFO] [stdout]   --> src/header.rs:39:8
[INFO] [stdout]    |
[INFO] [stdout] 39 | pub fn get_header(region: RomVersion) -> &'static HeaderData {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `items` is never read
[INFO] [stdout]   --> src/logic.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct Logic {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] 21 |     pub items: Vec<(Rc<ItemDef>, ItemCondition)>,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_item` is never used
[INFO] [stdout]    --> src/logic.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl PreLogic {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn get_item(&self, id: ItemId) -> Option<&PreItemDef> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Item` is never constructed
[INFO] [stdout]    --> src/logic.rs:239:12
[INFO] [stdout]     |
[INFO] [stdout] 239 | pub struct Item {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/logic.rs:253:12
[INFO] [stdout]     |
[INFO] [stdout] 252 | impl Item {
[INFO] [stdout]     | --------- associated function in this implementation
[INFO] [stdout] 253 |     pub fn new(def: Rc<ItemDef>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `complexity` is never used
[INFO] [stdout]   --> src/logic/condition.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout] 64 | impl ItemCondition {
[INFO] [stdout]    | ------------------ method in this implementation
[INFO] [stdout] 65 |     pub fn complexity(&self) -> u32 {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `preflight_check` is never used
[INFO] [stdout]   --> src/logic/allocator.rs:46:8
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl Allocator {
[INFO] [stdout]    | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     fn preflight_check(&self) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `typ` is never read
[INFO] [stdout]   --> src/logic/logic_loader.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | struct ParameterData {
[INFO] [stdout]    |        ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 23 |     typ: ParameterType,
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParameterData` 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: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/logic_parse.rs:171:26
[INFO] [stdout]     |
[INFO] [stdout] 171 | pub fn parse_reqs(mut s: &str) -> (Vec<Term>, &str) {
[INFO] [stdout]     |                          ^^^^          ^^^^   ^^^^ the same lifetime is elided here
[INFO] [stdout]     |                          |             |
[INFO] [stdout]     |                          |             the same lifetime is hidden here
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 171 | pub fn parse_reqs(mut s: &str) -> (Vec<Term<'_>>, &str) {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/logic/allocation_checker.rs:138:9
[INFO] [stdout]     |
[INFO] [stdout] 138 |         std::fs::write("graph.dot", graph.as_bytes());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 138 |         let _ = std::fs::write("graph.dot", graph.as_bytes());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/logic/allocation_checker.rs:138:9
[INFO] [stdout]     |
[INFO] [stdout] 138 |         std::fs::write("graph.dot", graph.as_bytes());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 138 |         let _ = std::fs::write("graph.dot", graph.as_bytes());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 23.13s
[INFO] running `Command { std: "docker" "inspect" "8bf38fad5b62fd3b9ad75722fe4c62204153bc73d5ac57d8429eacf62dcd393b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8bf38fad5b62fd3b9ad75722fe4c62204153bc73d5ac57d8429eacf62dcd393b", kill_on_drop: false }`
[INFO] [stdout] 8bf38fad5b62fd3b9ad75722fe4c62204153bc73d5ac57d8429eacf62dcd393b
