[INFO] cloning repository https://github.com/0xJonas/rehearse
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/0xJonas/rehearse" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F0xJonas%2Frehearse", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F0xJonas%2Frehearse'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 5843d6bb2e369f8507b4b370f3d7ce13c9ddbdf1
[INFO] checking 0xJonas/rehearse against master#46424fb5054f211ec836c5c03159f92e46bb35ac for pr-139042
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F0xJonas%2Frehearse" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/0xJonas/rehearse on toolchain 46424fb5054f211ec836c5c03159f92e46bb35ac
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+46424fb5054f211ec836c5c03159f92e46bb35ac" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/0xJonas/rehearse
[INFO] finished tweaking git repo https://github.com/0xJonas/rehearse
[INFO] tweaked toml for git repo https://github.com/0xJonas/rehearse written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+46424fb5054f211ec836c5c03159f92e46bb35ac" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 106 packages to latest compatible versions
[INFO] [stderr]       Adding crossterm v0.22.1 (available: v0.28.1)
[INFO] [stderr]       Adding simplelog v0.11.2 (available: v0.12.2)
[INFO] [stderr]       Adding termcolor v1.1.3 (available: v1.4.1)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+46424fb5054f211ec836c5c03159f92e46bb35ac" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded quickcheck v1.0.3
[INFO] [stderr]   Downloaded parking_lot_core v0.8.6
[INFO] [stderr]   Downloaded quickcheck_macros v1.0.0
[INFO] [stderr]   Downloaded simplelog v0.11.2
[INFO] [stderr]   Downloaded ntapi v0.3.7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:4b26683ee3c49f365255c425c23003cbf4366de097804722c29c5bbbee3624d2" "/opt/rustwide/cargo-home/bin/cargo" "+46424fb5054f211ec836c5c03159f92e46bb35ac" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] b246aa499facac323d815806d39084f888b2d8e9873de7770a4fb39ed13b7888
[INFO] running `Command { std: "docker" "start" "-a" "b246aa499facac323d815806d39084f888b2d8e9873de7770a4fb39ed13b7888", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "b246aa499facac323d815806d39084f888b2d8e9873de7770a4fb39ed13b7888", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b246aa499facac323d815806d39084f888b2d8e9873de7770a4fb39ed13b7888", kill_on_drop: false }`
[INFO] [stdout] b246aa499facac323d815806d39084f888b2d8e9873de7770a4fb39ed13b7888
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:4b26683ee3c49f365255c425c23003cbf4366de097804722c29c5bbbee3624d2" "/opt/rustwide/cargo-home/bin/cargo" "+46424fb5054f211ec836c5c03159f92e46bb35ac" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] ccabff1cd440cd583c6da055495478b9ef76929921b4ea9ed975d47d18ff7c16
[INFO] running `Command { std: "docker" "start" "-a" "ccabff1cd440cd583c6da055495478b9ef76929921b4ea9ed975d47d18ff7c16", kill_on_drop: false }`
[INFO] [stderr]     Checking log v0.4.27
[INFO] [stderr]     Checking futures-sink v0.3.31
[INFO] [stderr]     Checking futures-core v0.3.31
[INFO] [stderr]    Compiling parking_lot_core v0.8.6
[INFO] [stderr]    Compiling syn v2.0.100
[INFO] [stderr]     Checking instant v0.1.13
[INFO] [stderr]     Checking smallvec v1.14.0
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]     Checking signal-hook v0.3.17
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]     Checking mio v0.7.14
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking termcolor v1.1.3
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking atty v0.2.14
[INFO] [stderr]     Checking glob v0.3.2
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking parking_lot v0.11.2
[INFO] [stderr]     Checking simplelog v0.11.2
[INFO] [stderr]     Checking env_logger v0.8.4
[INFO] [stderr]     Checking signal-hook-mio v0.2.4
[INFO] [stderr]     Checking crossterm v0.22.1
[INFO] [stderr]     Checking quickcheck v1.0.3
[INFO] [stderr]     Checking serde_json v1.0.140
[INFO] [stderr]    Compiling quickcheck_macros v1.0.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]     Checking tokio v1.44.1
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking rehearse v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `super::priority_queue::PriorityQueue`
[INFO] [stdout]   --> src/diff/differ.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use super::priority_queue::PriorityQueue;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::priority_queue::PriorityQueue`
[INFO] [stdout]   --> src/diff/differ.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use super::priority_queue::PriorityQueue;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `content` is never read
[INFO] [stdout]    --> src/match_script/expression_parser.rs:155:5
[INFO] [stdout]     |
[INFO] [stdout] 154 | struct Cursor<'a> {
[INFO] [stdout]     |        ------ field in this struct
[INFO] [stdout] 155 |     content: &'a str,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_next_newline` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:160:4
[INFO] [stdout]     |
[INFO] [stdout] 160 | fn find_next_newline(text: &str) -> usize {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/match_script/functions.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 |     Symbol(Symbol),
[INFO] [stdout]    |     ------ ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 25 -     Symbol(Symbol),
[INFO] [stdout] 25 +     Symbol(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/match_script/functions.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 26 |     Number(i64),
[INFO] [stdout]    |     ------ ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 26 -     Number(i64),
[INFO] [stdout] 26 +     Number(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/match_script/functions.rs:27:18
[INFO] [stdout]    |
[INFO] [stdout] 27 |     FunctionCall(Box<dyn Matcher>)
[INFO] [stdout]    |     ------------ ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 27 -     FunctionCall(Box<dyn Matcher>)
[INFO] [stdout] 27 +     FunctionCall(())
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `READ_BUFFER_SIZE` is never used
[INFO] [stdout]   --> src/diff/differ.rs:17:7
[INFO] [stdout]    |
[INFO] [stdout] 17 | const READ_BUFFER_SIZE: usize = 1024;
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DifferParams` is never constructed
[INFO] [stdout]   --> src/diff/differ.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct DifferParams<'ref_name, 'test_name, 'delimiter_tag, R: AsyncReadExt + Unpin> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DiffInput` is never constructed
[INFO] [stdout]   --> src/diff/differ.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | struct DiffInput<R: AsyncReadExt + AsyncSeekExt + Unpin> {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `mark_as_processed`, `discard_processed_data`, `top_up_ref_buffer`, `decode_strip`, and `push_test_data` are never used
[INFO] [stdout]    --> src/diff/differ.rs:82:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<R: AsyncReadExt + AsyncSeekExt + Unpin> DiffInput<R> {
[INFO] [stdout]     | --------------------------------------------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 82  |     fn new<'a, 'b, 'c, X>(params: DifferParams<'a, 'b, 'c, X>) -> DiffInput<X>
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 110 |     fn mark_as_processed(&mut self, ref_chars: usize, test_chars: usize) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     fn discard_processed_data(&mut self) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 131 |     async fn top_up_ref_buffer(&mut self, new_len: usize) -> Result<(), ParseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     fn decode_strip(&mut self, data: &[u8]) -> Result<usize, ParseError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 216 |     fn push_test_data(&mut self, data: &[u8]) -> Result<(), ParseError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Inserted`, `Decreased`, and `Ignored` are never constructed
[INFO] [stdout]   --> src/diff/priority_queue.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub enum InsertOrDecreaseResult {
[INFO] [stdout]    |          ---------------------- variants in this enum
[INFO] [stdout] 34 |     Inserted,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 35 |     Decreased,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 36 |     Ignored
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `InsertOrDecreaseResult` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/diff/priority_queue.rs:49:12
[INFO] [stdout]     |
[INFO] [stdout] 46  | impl<T: PartialEq> PriorityQueue<T> {
[INFO] [stdout]     | ----------------------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 49  |     pub fn new() -> PriorityQueue<T> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 56  |     pub fn len(&self) -> usize {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 62  |     fn move_up(&mut self, index: usize) -> () {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 80  |     fn move_down(&mut self, index: usize) -> () {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     fn insert(&mut self, data: T, priority: isize) -> () {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     pub fn peek_min(&self) -> Option<(&T, isize)> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 128 |     pub fn extract_min(&mut self) -> Option<(T, isize)> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     fn decrease_key(&mut self, index: usize, new_priority: isize) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn insert_or_decrease(&mut self, elem: T, priority: isize) -> InsertOrDecreaseResult {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn iter(&self) -> PQueueIter<T> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reporter::*`
[INFO] [stdout]  --> src/test_cases.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use reporter::*;
[INFO] [stdout]   |         ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout] help: if this is a test module, consider adding a `#[cfg(test)]` to the containing module
[INFO] [stdout]  --> src/main.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | mod test_cases;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::priority_queue::PriorityQueue`
[INFO] [stdout]   --> src/diff/differ.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use super::priority_queue::PriorityQueue;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `reporter::*`
[INFO] [stdout]  --> src/test_cases.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use reporter::*;
[INFO] [stdout]   |         ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::priority_queue::PriorityQueue`
[INFO] [stdout]   --> src/diff/differ.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use super::priority_queue::PriorityQueue;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `content` is never read
[INFO] [stdout]    --> src/match_script/expression_parser.rs:155:5
[INFO] [stdout]     |
[INFO] [stdout] 154 | struct Cursor<'a> {
[INFO] [stdout]     |        ------ field in this struct
[INFO] [stdout] 155 |     content: &'a str,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_next_newline` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:160:4
[INFO] [stdout]     |
[INFO] [stdout] 160 | fn find_next_newline(text: &str) -> usize {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/match_script/functions.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 |     Symbol(Symbol),
[INFO] [stdout]    |     ------ ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 25 -     Symbol(Symbol),
[INFO] [stdout] 25 +     Symbol(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/match_script/functions.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 26 |     Number(i64),
[INFO] [stdout]    |     ------ ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 26 -     Number(i64),
[INFO] [stdout] 26 +     Number(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/match_script/functions.rs:27:18
[INFO] [stdout]    |
[INFO] [stdout] 27 |     FunctionCall(Box<dyn Matcher>)
[INFO] [stdout]    |     ------------ ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 27 -     FunctionCall(Box<dyn Matcher>)
[INFO] [stdout] 27 +     FunctionCall(())
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `test_input` is never read
[INFO] [stdout]   --> src/diff/differ.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct DifferParams<'ref_name, 'test_name, 'delimiter_tag, R: AsyncReadExt + Unpin> {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 25 |     pub test_input: R,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `iter` is never used
[INFO] [stdout]    --> src/diff/priority_queue.rs:177:12
[INFO] [stdout]     |
[INFO] [stdout] 46  | impl<T: PartialEq> PriorityQueue<T> {
[INFO] [stdout]     | ----------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn iter(&self) -> PQueueIter<T> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `name`, `reference`, `encoding`, and `is_binary_file` are never read
[INFO] [stdout]   --> src/test_cases.rs:38:9
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub struct ArtifactConfig {
[INFO] [stdout]    |            -------------- fields in this struct
[INFO] [stdout] 38 |     pub name: PathBuf,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 39 |     pub reference: PathBuf,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 40 |     pub encoding: String,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] 41 |     pub is_binary_file: bool
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ArtifactConfig` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `version`, `reference_stdout`, `reference_stderr`, and `artifacts` are never read
[INFO] [stdout]   --> src/test_cases.rs:47:9
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub struct TestCase {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 47 |     pub version: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub reference_stdout: Option<PathBuf>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 54 |     pub reference_stderr: Option<PathBuf>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 55 |     pub artifacts: Vec<ArtifactConfig>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TestCase` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Diff` is never constructed
[INFO] [stdout]   --> src/test_cases/reporter.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 9  | pub enum State {
[INFO] [stdout]    |          ----- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 20 |     Diff,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `register_test_case` is never used
[INFO] [stdout]   --> src/test_cases/reporter.rs:31:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub trait ProgressReporter {
[INFO] [stdout]    |           ---------------- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 31 |     fn register_test_case(&mut self, test_case: &TestCase) -> ();
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `DiffAdded`, `DiffAddedBg`, `DiffDeleted`, and `DiffDeletedBg` are never constructed
[INFO] [stdout]   --> src/cli.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum TermColor {
[INFO] [stdout]    |          --------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 23 |     DiffAdded,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     DiffAddedBg,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |     DiffDeleted,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |     DiffDeletedBg
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TermColor` 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: method `set_color_bg` is never used
[INFO] [stdout]   --> src/cli.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub trait Terminal {
[INFO] [stdout]    |           -------- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 81 |     fn set_color_bg(&mut self, color: &TermColor) -> std::io::Result<()>;
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `get_buffer` are never used
[INFO] [stdout]    --> src/cli.rs:207:12
[INFO] [stdout]     |
[INFO] [stdout] 204 | impl StringTerminal {
[INFO] [stdout]     | ------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 207 |     pub fn new(size: (usize, usize)) -> StringTerminal {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 214 |     pub fn get_buffer(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_to_buffer` is never used
[INFO] [stdout]   --> src/match_script/char_source.rs:12:10
[INFO] [stdout]    |
[INFO] [stdout] 12 | async fn read_to_buffer<R: AsyncReadExt + Unpin>(buffer: &mut [u8], input: &mut R) -> std::io::Result<usize> {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CharSource` is never constructed
[INFO] [stdout]   --> src/match_script/char_source.rs:29:12
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub struct CharSource<R: AsyncReadExt + AsyncSeekExt + Unpin> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/match_script/char_source.rs:46:12
[INFO] [stdout]     |
[INFO] [stdout] 42  | impl<R: AsyncReadExt + AsyncSeekExt + Unpin> CharSource<R> {
[INFO] [stdout]     | ---------------------------------------------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46  |     pub fn new(encoding: &'static Encoding, input: R, input_name: &str, buffer_size: usize) -> CharSource<R> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 64  |     pub fn get_input_name(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 69  |     pub fn get_input_checkpoint(&self) -> InputCheckpoint {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 78  |     pub fn is_end_of_input(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 82  |     async fn top_up_buffer(&mut self) -> std::io::Result<()> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 93  |     pub async fn read_chars(&mut self, out_buffer: &mut [char]) -> Result<usize, ParseError> {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 148 |     pub async fn seek(&mut self, checkpoint: &InputCheckpoint) -> std::io::Result<()> {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LEXEME_LIMIT` is never used
[INFO] [stdout]   --> src/match_script/proto_grapheme_source.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const LEXEME_LIMIT: usize = 4096;            // 4 KiB, must be smaller than BUFFER_REFILL_AMOUNT in char_source.rs
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Char` and `ProtoExpression` are never constructed
[INFO] [stdout]   --> src/match_script/proto_grapheme_source.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub enum ProtoGrapheme {
[INFO] [stdout]    |          ------------- variants in this enum
[INFO] [stdout] 23 |     Char(char),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 24 |     ProtoExpression(Box<ProtoExpression>)
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ProtoGrapheme` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ProtoGraphemeSource` is never constructed
[INFO] [stdout]   --> src/match_script/proto_grapheme_source.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct ProtoGraphemeSource<R: AsyncReadExt + AsyncSeekExt + Unpin> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/match_script/proto_grapheme_source.rs:41:12
[INFO] [stdout]     |
[INFO] [stdout] 37  | impl<R: AsyncReadExt + AsyncSeekExt + Unpin> ProtoGraphemeSource<R> {
[INFO] [stdout]     | ------------------------------------------------------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 41  |     pub fn new(source: CharSource<R>, delimiter_tag: &str, char_buffer_size: usize) -> ProtoGraphemeSource<R> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 55  |     pub fn get_input_name(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60  |     pub fn is_end_of_input(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66  |     pub fn get_input_checkpoint(&self) -> InputCheckpoint {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74  |     async fn top_up_buffer(&mut self) -> Result<(), ParseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88  |     fn match_char(&self, offset: usize, c: char) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 98  |     fn read_proto_expression(&mut self) -> Option<ProtoExpression> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 169 |     pub async fn read_proto_graphemes(&mut self, out_buffer: &mut [ProtoGrapheme]) -> Result<usize, ParseError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 209 |     pub async fn seek(&mut self, checkpoint: &InputCheckpoint) -> std::io::Result<()> {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Grapheme` is never used
[INFO] [stdout]   --> src/match_script/grapheme_source.rs:14:10
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub enum Grapheme {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Grapheme` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GraphemeSource` is never constructed
[INFO] [stdout]   --> src/match_script/grapheme_source.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct GraphemeSource<R: AsyncReadExt + AsyncSeekExt + Unpin> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `is_end_of_input`, `get_input_checkpoint`, `read_graphemes`, and `seek` are never used
[INFO] [stdout]    --> src/match_script/grapheme_source.rs:32:12
[INFO] [stdout]     |
[INFO] [stdout] 28  | impl<R: AsyncReadExt + AsyncSeekExt + Unpin> GraphemeSource<R> {
[INFO] [stdout]     | -------------------------------------------------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 32  |     pub fn new(proto_grapheme_source: ProtoGraphemeSource<R>, buffer_size: usize) -> GraphemeSource<R> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 45  |     pub fn is_end_of_input(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51  |     pub fn get_input_checkpoint(&self) -> InputCheckpoint {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 56  |     pub async fn read_graphemes(&mut self, out_buffer: &mut [Grapheme]) -> Result<usize, ParseError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 116 |     pub async fn seek(&mut self, checkpoint: &InputCheckpoint) -> std::io::Result<()> {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Symbol`, `Number`, and `FunctionCall` are never constructed
[INFO] [stdout]   --> src/match_script/expression_parser.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub enum ArgumentExpression {
[INFO] [stdout]    |          ------------------ variants in this enum
[INFO] [stdout] 16 |     Symbol(Symbol),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 17 |     Number(i64),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 18 |     FunctionCall(FunctionCall)
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ArgumentExpression` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `String` and `FunctionCall` are never constructed
[INFO] [stdout]   --> src/match_script/expression_parser.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub enum TextExpressionSegment {
[INFO] [stdout]    |          --------------------- variants in this enum
[INFO] [stdout] 69 |     String(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 70 |     FunctionCall(FunctionCall)
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TextExpressionSegment` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Cursor` is never constructed
[INFO] [stdout]    --> src/match_script/expression_parser.rs:154:8
[INFO] [stdout]     |
[INFO] [stdout] 154 | struct Cursor<'a> {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_next_newline` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:160:4
[INFO] [stdout]     |
[INFO] [stdout] 160 | fn find_next_newline(text: &str) -> usize {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `peek`, `advance`, `expect`, and `get_position` are never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:169:8
[INFO] [stdout]     |
[INFO] [stdout] 167 | impl<'a> Cursor<'a> {
[INFO] [stdout]     | ------------------- associated items in this implementation
[INFO] [stdout] 168 |
[INFO] [stdout] 169 |     fn new<'b>(content: &'b str) -> Cursor<'b> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     fn peek(&mut self) -> Option<char> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 184 |     fn advance(&mut self) -> () {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 192 |     fn expect(&mut self, chars: &[char]) -> Result<(), ParseError> {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     fn get_position(&self) -> CursorPosition {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `skip_whitespace` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:218:4
[INFO] [stdout]     |
[INFO] [stdout] 218 | fn skip_whitespace(cursor: &mut Cursor) -> () {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_symbol` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:232:4
[INFO] [stdout]     |
[INFO] [stdout] 232 | fn parse_symbol(cursor: &mut Cursor) -> Result<Symbol, ParseError> {
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_number` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:253:4
[INFO] [stdout]     |
[INFO] [stdout] 253 | fn parse_number(cursor: &mut Cursor) -> Result<i64, ParseError> {
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_argument` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:291:4
[INFO] [stdout]     |
[INFO] [stdout] 291 | fn parse_argument<'i>(cursor: &mut Cursor<'i>) -> Result<(Symbol, ArgumentExpression), ParseError> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_function_call` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:321:4
[INFO] [stdout]     |
[INFO] [stdout] 321 | fn parse_function_call<'i>(cursor: &mut Cursor<'i>) -> Result<FunctionCall, ParseError> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_text_expression` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:370:4
[INFO] [stdout]     |
[INFO] [stdout] 370 | fn parse_text_expression<'i>(cursor: &mut Cursor<'i>) -> Result<TextExpression, ParseError> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_expression` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:450:8
[INFO] [stdout]     |
[INFO] [stdout] 450 | pub fn parse_expression(text: &str) -> Result<TextExpression, ParseError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CompiledArgument` is never used
[INFO] [stdout]   --> src/match_script/functions.rs:24:6
[INFO] [stdout]    |
[INFO] [stdout] 24 | enum CompiledArgument {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `MatcherFunction` is never used
[INFO] [stdout]   --> src/match_script/functions.rs:31:6
[INFO] [stdout]    |
[INFO] [stdout] 31 | type MatcherFunction = dyn Fn(&CursorPosition, &Vec<(Symbol, CompiledArgument)>, &Vec<Box<dyn Matcher>>) -> Result<Box<dyn Matcher>, Pars...
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MSContext` is never constructed
[INFO] [stdout]   --> src/match_script/functions.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct MSContext {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/match_script/functions.rs:40:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | impl MSContext {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 39 |
[INFO] [stdout] 40 |     pub fn new() -> MSContext {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Matcher` is never used
[INFO] [stdout]   --> src/match_script/functions.rs:49:11
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub trait Matcher: std::fmt::Debug {
[INFO] [stdout]    |           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FUN_ID_REGEX` is never used
[INFO] [stdout]   --> src/match_script/functions.rs:59:7
[INFO] [stdout]    |
[INFO] [stdout] 59 | const FUN_ID_REGEX: &'static str = "regex";
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FunctionSignature` is never constructed
[INFO] [stdout]   --> src/match_script/functions.rs:62:8
[INFO] [stdout]    |
[INFO] [stdout] 62 | struct FunctionSignature<'a> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `verify_function_signature` is never used
[INFO] [stdout]   --> src/match_script/functions.rs:70:4
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn verify_function_signature(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `StringMatcher` is never constructed
[INFO] [stdout]    --> src/match_script/functions.rs:102:8
[INFO] [stdout]     |
[INFO] [stdout] 102 | struct StringMatcher {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RegexMatcher` is never constructed
[INFO] [stdout]    --> src/match_script/functions.rs:130:8
[INFO] [stdout]     |
[INFO] [stdout] 130 | struct RegexMatcher {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_regex_matcher` is never used
[INFO] [stdout]    --> src/match_script/functions.rs:135:4
[INFO] [stdout]     |
[INFO] [stdout] 135 | fn build_regex_matcher(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TextExpressionMatcher` is never constructed
[INFO] [stdout]    --> src/match_script/functions.rs:173:8
[INFO] [stdout]     |
[INFO] [stdout] 173 | struct TextExpressionMatcher {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compile_function_call` is never used
[INFO] [stdout]    --> src/match_script/functions.rs:199:4
[INFO] [stdout]     |
[INFO] [stdout] 199 | fn compile_function_call(context: &MSContext, funcall: &FunctionCall) -> Result<Box<dyn Matcher>, ParseError> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compile_text_expression` is never used
[INFO] [stdout]    --> src/match_script/functions.rs:230:4
[INFO] [stdout]     |
[INFO] [stdout] 230 | fn compile_text_expression(context: &MSContext, expr: &TextExpression) -> Result<TextExpressionMatcher, ParseError> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_standard_functions` is never used
[INFO] [stdout]    --> src/match_script/functions.rs:257:8
[INFO] [stdout]     |
[INFO] [stdout] 257 | pub fn add_standard_functions(context: &mut MSContext) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compile_expression` is never used
[INFO] [stdout]    --> src/match_script/functions.rs:261:8
[INFO] [stdout]     |
[INFO] [stdout] 261 | pub fn compile_expression(context: &MSContext, expr: &TextExpression) -> Result<Box<dyn Matcher>, ParseError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `add_char`, `add_string`, and `add_position` are never used
[INFO] [stdout]   --> src/match_script/error.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl CursorPosition {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 17 |     pub fn new() -> CursorPosition {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     pub fn add_char(&mut self, c: char) -> &mut Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn add_string(&mut self, str: &str) -> &mut Self {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn add_position(&mut self, other: &CursorPosition) -> &mut Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]    --> src/match_script/error.rs:65:5
[INFO] [stdout]     |
[INFO] [stdout] 61  | pub enum ParseErrorVariant {
[INFO] [stdout]     |          ----------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 65  |     CharsExpected(Vec<char>),
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 68  |     TokenExpected(String),
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 71  |     DanglingBacktick,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74  |     UnmatchedBrace,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 79  |     FunctionNotFound(String),
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 82  |     BadParameter(String, String),
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 85  |     BadArgument(String, String),
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88  |     BadTextCount(String, usize, usize),
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 92  |     StaticMatchRequired,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 97  |     Encoding(Vec<u8>, &'static Encoding),
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 100 |     IO(std::io::Error),
[INFO] [stdout]     |     ^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     External(String, Box<dyn Error>)
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ParseErrorVariant` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_usable_context` is never used
[INFO] [stdout]    --> src/match_script/error.rs:135:4
[INFO] [stdout]     |
[INFO] [stdout] 135 | fn get_usable_context<'a>(context: &'a str, position: &CursorPosition, max_length: usize) -> Option<(&'a str, usize)> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ParseError` is never constructed
[INFO] [stdout]    --> src/match_script/error.rs:193:12
[INFO] [stdout]     |
[INFO] [stdout] 193 | pub struct ParseError {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ParseError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/match_script/error.rs:204:12
[INFO] [stdout]     |
[INFO] [stdout] 201 | impl ParseError {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub fn new(position: CursorPosition, variant: ParseErrorVariant) -> ParseError {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 219 |     pub fn get_position(&self) -> &CursorPosition {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 224 |     pub fn get_variant(&self) -> &ParseErrorVariant {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 233 |     pub fn set_context(&mut self, context_position: CursorPosition, context: &str) -> () {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     pub fn get_context(&self) -> Option<(&CursorPosition, &str)> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 249 |     pub fn set_input_name(&mut self, input_name: &str) -> () {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 255 |     pub fn get_input_name(&self) -> Option<&str> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 264 |     pub fn write<T: Terminal>(&self, terminal: &mut T) -> std::io::Result<()> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `READ_BUFFER_SIZE` is never used
[INFO] [stdout]   --> src/diff/differ.rs:17:7
[INFO] [stdout]    |
[INFO] [stdout] 17 | const READ_BUFFER_SIZE: usize = 1024;
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DifferParams` is never constructed
[INFO] [stdout]   --> src/diff/differ.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct DifferParams<'ref_name, 'test_name, 'delimiter_tag, R: AsyncReadExt + Unpin> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DiffInput` is never constructed
[INFO] [stdout]   --> src/diff/differ.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | struct DiffInput<R: AsyncReadExt + AsyncSeekExt + Unpin> {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `mark_as_processed`, `discard_processed_data`, `top_up_ref_buffer`, `decode_strip`, and `push_test_data` are never used
[INFO] [stdout]    --> src/diff/differ.rs:82:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<R: AsyncReadExt + AsyncSeekExt + Unpin> DiffInput<R> {
[INFO] [stdout]     | --------------------------------------------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 82  |     fn new<'a, 'b, 'c, X>(params: DifferParams<'a, 'b, 'c, X>) -> DiffInput<X>
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 110 |     fn mark_as_processed(&mut self, ref_chars: usize, test_chars: usize) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     fn discard_processed_data(&mut self) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 131 |     async fn top_up_ref_buffer(&mut self, new_len: usize) -> Result<(), ParseError> {
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     fn decode_strip(&mut self, data: &[u8]) -> Result<usize, ParseError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 216 |     fn push_test_data(&mut self, data: &[u8]) -> Result<(), ParseError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Inserted`, `Decreased`, and `Ignored` are never constructed
[INFO] [stdout]   --> src/diff/priority_queue.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub enum InsertOrDecreaseResult {
[INFO] [stdout]    |          ---------------------- variants in this enum
[INFO] [stdout] 34 |     Inserted,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 35 |     Decreased,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 36 |     Ignored
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `InsertOrDecreaseResult` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/diff/priority_queue.rs:49:12
[INFO] [stdout]     |
[INFO] [stdout] 46  | impl<T: PartialEq> PriorityQueue<T> {
[INFO] [stdout]     | ----------------------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 49  |     pub fn new() -> PriorityQueue<T> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 56  |     pub fn len(&self) -> usize {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 62  |     fn move_up(&mut self, index: usize) -> () {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 80  |     fn move_down(&mut self, index: usize) -> () {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     fn insert(&mut self, data: T, priority: isize) -> () {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     pub fn peek_min(&self) -> Option<(&T, isize)> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 128 |     pub fn extract_min(&mut self) -> Option<(T, isize)> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 149 |     fn decrease_key(&mut self, index: usize, new_priority: isize) -> () {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn insert_or_decrease(&mut self, elem: T, priority: isize) -> InsertOrDecreaseResult {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn iter(&self) -> PQueueIter<T> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Diff` is never constructed
[INFO] [stdout]   --> src/test_cases/reporter.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 9  | pub enum State {
[INFO] [stdout]    |          ----- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 20 |     Diff,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `register_test_case` is never used
[INFO] [stdout]   --> src/test_cases/reporter.rs:31:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub trait ProgressReporter {
[INFO] [stdout]    |           ---------------- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 31 |     fn register_test_case(&mut self, test_case: &TestCase) -> ();
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `DiffAdded`, `DiffAddedBg`, `DiffDeleted`, and `DiffDeletedBg` are never constructed
[INFO] [stdout]   --> src/cli.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum TermColor {
[INFO] [stdout]    |          --------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 23 |     DiffAdded,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     DiffAddedBg,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |     DiffDeleted,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |     DiffDeletedBg
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TermColor` 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: method `set_color_bg` is never used
[INFO] [stdout]   --> src/cli.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub trait Terminal {
[INFO] [stdout]    |           -------- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 81 |     fn set_color_bg(&mut self, color: &TermColor) -> std::io::Result<()>;
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `seek` is never used
[INFO] [stdout]    --> src/match_script/grapheme_source.rs:116:18
[INFO] [stdout]     |
[INFO] [stdout] 28  | impl<R: AsyncReadExt + AsyncSeekExt + Unpin> GraphemeSource<R> {
[INFO] [stdout]     | -------------------------------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 116 |     pub async fn seek(&mut self, checkpoint: &InputCheckpoint) -> std::io::Result<()> {
[INFO] [stdout]     |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `content` is never read
[INFO] [stdout]    --> src/match_script/expression_parser.rs:155:5
[INFO] [stdout]     |
[INFO] [stdout] 154 | struct Cursor<'a> {
[INFO] [stdout]     |        ------ field in this struct
[INFO] [stdout] 155 |     content: &'a str,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_next_newline` is never used
[INFO] [stdout]    --> src/match_script/expression_parser.rs:160:4
[INFO] [stdout]     |
[INFO] [stdout] 160 | fn find_next_newline(text: &str) -> usize {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/match_script/functions.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 |     Symbol(Symbol),
[INFO] [stdout]    |     ------ ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 25 -     Symbol(Symbol),
[INFO] [stdout] 25 +     Symbol(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/match_script/functions.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 26 |     Number(i64),
[INFO] [stdout]    |     ------ ^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 26 -     Number(i64),
[INFO] [stdout] 26 +     Number(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/match_script/functions.rs:27:18
[INFO] [stdout]    |
[INFO] [stdout] 27 |     FunctionCall(Box<dyn Matcher>)
[INFO] [stdout]    |     ------------ ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 27 -     FunctionCall(Box<dyn Matcher>)
[INFO] [stdout] 27 +     FunctionCall(())
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `BadArgument` is never constructed
[INFO] [stdout]   --> src/match_script/error.rs:85:5
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub enum ParseErrorVariant {
[INFO] [stdout]    |          ----------------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 85 |     BadArgument(String, String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseErrorVariant` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `test_input` is never read
[INFO] [stdout]   --> src/diff/differ.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct DifferParams<'ref_name, 'test_name, 'delimiter_tag, R: AsyncReadExt + Unpin> {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 25 |     pub test_input: R,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `iter` is never used
[INFO] [stdout]    --> src/diff/priority_queue.rs:177:12
[INFO] [stdout]     |
[INFO] [stdout] 46  | impl<T: PartialEq> PriorityQueue<T> {
[INFO] [stdout]     | ----------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn iter(&self) -> PQueueIter<T> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 5.08s
[INFO] running `Command { std: "docker" "inspect" "ccabff1cd440cd583c6da055495478b9ef76929921b4ea9ed975d47d18ff7c16", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ccabff1cd440cd583c6da055495478b9ef76929921b4ea9ed975d47d18ff7c16", kill_on_drop: false }`
[INFO] [stdout] ccabff1cd440cd583c6da055495478b9ef76929921b4ea9ed975d47d18ff7c16
