[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#8b6b15b877fbceb1ee5d9a5a4746e7515901574a for pr-147294
[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] 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] validating manifest of git repo https://github.com/0xJonas/rehearse on toolchain 8b6b15b877fbceb1ee5d9a5a4746e7515901574a
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+8b6b15b877fbceb1ee5d9a5a4746e7515901574a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+8b6b15b877fbceb1ee5d9a5a4746e7515901574a" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 112 packages to latest compatible versions
[INFO] [stderr]       Adding crossterm v0.22.1 (available: v0.29.0)
[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" "+8b6b15b877fbceb1ee5d9a5a4746e7515901574a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded simplelog v0.11.2
[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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+8b6b15b877fbceb1ee5d9a5a4746e7515901574a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7fb7813b42749c458813f87a8a19b27008d7c16804937778e85849afcc26a6dd
[INFO] running `Command { std: "docker" "start" "-a" "7fb7813b42749c458813f87a8a19b27008d7c16804937778e85849afcc26a6dd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7fb7813b42749c458813f87a8a19b27008d7c16804937778e85849afcc26a6dd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7fb7813b42749c458813f87a8a19b27008d7c16804937778e85849afcc26a6dd", kill_on_drop: false }`
[INFO] [stdout] 7fb7813b42749c458813f87a8a19b27008d7c16804937778e85849afcc26a6dd
[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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+8b6b15b877fbceb1ee5d9a5a4746e7515901574a" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 9fa73e8ca3dddc1c423961defdcfd86fdab89e2cc635255cff7bad649f3882c8
[INFO] running `Command { std: "docker" "start" "-a" "9fa73e8ca3dddc1c423961defdcfd86fdab89e2cc635255cff7bad649f3882c8", kill_on_drop: false }`
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]     Checking parking_lot_core v0.8.6
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]     Checking mio v0.7.14
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking termcolor v1.1.3
[INFO] [stderr]     Checking atty v0.2.14
[INFO] [stderr]     Checking env_logger v0.8.4
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking parking_lot v0.11.2
[INFO] [stderr]     Checking simplelog v0.11.2
[INFO] [stderr]    Compiling quickcheck_macros v1.1.0
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking tokio v1.47.1
[INFO] [stderr]     Checking signal-hook-mio v0.2.4
[INFO] [stderr]     Checking crossterm v0.22.1
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking quickcheck v1.0.3
[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)]` (part of `#[warn(unused)]`) 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)]` (part of `#[warn(unused)]`) 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)]` (part of `#[warn(unused)]`) 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: struct `PQueueSlot` is never constructed
[INFO] [stdout]  --> src/diff/priority_queue.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | struct PQueueSlot<T> {
[INFO] [stdout]   |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PQueueIter` is never constructed
[INFO] [stdout]   --> src/diff/priority_queue.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct PQueueIter<'a, T> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PriorityQueue` is never constructed
[INFO] [stdout]   --> src/diff/priority_queue.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct PriorityQueue<T: PartialEq> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `InsertOrDecreaseResult` is never used
[INFO] [stdout]   --> src/diff/priority_queue.rs:33:10
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub enum InsertOrDecreaseResult {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^
[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: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/diff/priority_queue.rs:177:17
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub fn iter(&self) -> PQueueIter<T> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 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)]` (part of `#[warn(unused)]`) 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)]` (part of `#[warn(unused)]`) 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)]` (part of `#[warn(unused)]`) 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: struct `PQueueIter` is never constructed
[INFO] [stdout]   --> src/diff/priority_queue.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct PQueueIter<'a, T> {
[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: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/diff/priority_queue.rs:177:17
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub fn iter(&self) -> PQueueIter<T> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 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)]` (part of `#[warn(unused)]`) 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: variants `Pending` and `Diff` are never constructed
[INFO] [stdout]   --> src/test_cases/reporter.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub enum State {
[INFO] [stdout]    |          ----- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 14 |     Pending,
[INFO] [stdout]    |     ^^^^^^^
[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: struct `StringTerminal` is never constructed
[INFO] [stdout]    --> src/cli.rs:199:12
[INFO] [stdout]     |
[INFO] [stdout] 199 | pub struct StringTerminal {
[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: struct `InputCheckpoint` is never constructed
[INFO] [stdout]   --> src/match_script.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct InputCheckpoint {
[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: struct `ProtoExpression` is never constructed
[INFO] [stdout]   --> src/match_script/proto_grapheme_source.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct ProtoExpression {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ProtoGrapheme` is never used
[INFO] [stdout]   --> src/match_script/proto_grapheme_source.rs:22:10
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub enum ProtoGrapheme {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[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] 
[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: type alias `Symbol` is never used
[INFO] [stdout]   --> src/match_script/expression_parser.rs:11:10
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub type Symbol = String;
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ArgumentExpression` is never used
[INFO] [stdout]   --> src/match_script/expression_parser.rs:15:10
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub enum ArgumentExpression {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FunctionCall` is never constructed
[INFO] [stdout]   --> src/match_script/expression_parser.rs:37:12
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub struct FunctionCall {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TextExpressionSegment` is never used
[INFO] [stdout]   --> src/match_script/expression_parser.rs:68:10
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub enum TextExpressionSegment {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `escape_text` is never used
[INFO] [stdout]   --> src/match_script/expression_parser.rs:78:4
[INFO] [stdout]    |
[INFO] [stdout] 78 | fn escape_text(str: &str) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TextExpression` is never constructed
[INFO] [stdout]    --> src/match_script/expression_parser.rs:135:12
[INFO] [stdout]     |
[INFO] [stdout] 135 | pub struct TextExpression {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[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: struct `CursorPosition` is never constructed
[INFO] [stdout]  --> src/match_script/error.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct CursorPosition {
[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: enum `ParseErrorVariant` is never used
[INFO] [stdout]   --> src/match_script/error.rs:61:10
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub enum ParseErrorVariant {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_char_list` is never used
[INFO] [stdout]    --> src/match_script/error.rs:108:4
[INFO] [stdout]     |
[INFO] [stdout] 108 | fn build_char_list(chars: &[char]) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[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] 
[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: struct `PQueueSlot` is never constructed
[INFO] [stdout]  --> src/diff/priority_queue.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | struct PQueueSlot<T> {
[INFO] [stdout]   |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PQueueIter` is never constructed
[INFO] [stdout]   --> src/diff/priority_queue.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct PQueueIter<'a, T> {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PriorityQueue` is never constructed
[INFO] [stdout]   --> src/diff/priority_queue.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub struct PriorityQueue<T: PartialEq> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `InsertOrDecreaseResult` is never used
[INFO] [stdout]   --> src/diff/priority_queue.rs:33:10
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub enum InsertOrDecreaseResult {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^^^^^^
[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: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/diff/priority_queue.rs:177:17
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub fn iter(&self) -> PQueueIter<T> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub fn iter(&self) -> PQueueIter<'_, T> {
[INFO] [stdout]     |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Pending` and `Diff` are never constructed
[INFO] [stdout]   --> src/test_cases/reporter.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub enum State {
[INFO] [stdout]    |          ----- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 14 |     Pending,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 20 |     Diff,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) 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: struct `PQueueIter` is never constructed
[INFO] [stdout]   --> src/diff/priority_queue.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct PQueueIter<'a, T> {
[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: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/diff/priority_queue.rs:177:17
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub fn iter(&self) -> PQueueIter<T> {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 177 |     pub fn iter(&self) -> PQueueIter<'_, T> {
[INFO] [stdout]     |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 13.70s
[INFO] running `Command { std: "docker" "inspect" "9fa73e8ca3dddc1c423961defdcfd86fdab89e2cc635255cff7bad649f3882c8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9fa73e8ca3dddc1c423961defdcfd86fdab89e2cc635255cff7bad649f3882c8", kill_on_drop: false }`
[INFO] [stdout] 9fa73e8ca3dddc1c423961defdcfd86fdab89e2cc635255cff7bad649f3882c8
