[INFO] cloning repository https://github.com/brannegan/aoc-2023
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/brannegan/aoc-2023" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbrannegan%2Faoc-2023", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbrannegan%2Faoc-2023'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 29e5a240bec119d15c14f2865d263b559677f494
[INFO] testing brannegan/aoc-2023 against master#0d162b25edd5bf0dba9a22e83b614f1113e90474 for pr-150681
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbrannegan%2Faoc-2023" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/brannegan/aoc-2023
[INFO] finished tweaking git repo https://github.com/brannegan/aoc-2023
[INFO] tweaked toml for git repo https://github.com/brannegan/aoc-2023 written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/brannegan/aoc-2023 on toolchain 0d162b25edd5bf0dba9a22e83b614f1113e90474
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/brannegan/aoc-2023 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded ahash v0.8.7
[INFO] [stderr]   Downloaded rustworkx-core v0.13.2
[INFO] [stderr]   Downloaded indicatif v0.17.7
[INFO] [stderr]   Downloaded indextree v4.6.0
[INFO] [stderr]   Downloaded console v0.15.7
[INFO] [stderr]   Downloaded proc-macro2 v1.0.76
[INFO] [stderr]   Downloaded priority-queue v1.3.2
[INFO] [stderr]   Downloaded rayon-cond v0.2.0
[INFO] [stderr]   Downloaded wide v0.7.13
[INFO] [stderr]   Downloaded nalgebra v0.32.3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 3b58645c07b29b9508dcc20d2b11df9067c3783167497a82754846eddf0002ee
[INFO] running `Command { std: "docker" "start" "-a" "3b58645c07b29b9508dcc20d2b11df9067c3783167497a82754846eddf0002ee", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "3b58645c07b29b9508dcc20d2b11df9067c3783167497a82754846eddf0002ee", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3b58645c07b29b9508dcc20d2b11df9067c3783167497a82754846eddf0002ee", kill_on_drop: false }`
[INFO] [stdout] 3b58645c07b29b9508dcc20d2b11df9067c3783167497a82754846eddf0002ee
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cf1890f1f52bef78c1f37d8babeb199a464e54b5d60164822bcf989d6b96e500
[INFO] running `Command { std: "docker" "start" "-a" "cf1890f1f52bef78c1f37d8babeb199a464e54b5d60164822bcf989d6b96e500", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.151
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]    Compiling either v1.9.0
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]    Compiling ahash v0.8.7
[INFO] [stderr]    Compiling proc-macro2 v1.0.76
[INFO] [stderr]    Compiling num-bigint v0.4.4
[INFO] [stderr]    Compiling once_cell v1.19.0
[INFO] [stderr]    Compiling rayon v1.8.0
[INFO] [stderr]    Compiling zerocopy v0.7.32
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]    Compiling bytemuck v1.14.0
[INFO] [stderr]    Compiling priority-queue v1.3.2
[INFO] [stderr]    Compiling quote v1.0.35
[INFO] [stderr]    Compiling matrixmultiply v0.3.8
[INFO] [stderr]    Compiling num-iter v0.1.43
[INFO] [stderr]    Compiling portable-atomic v1.6.0
[INFO] [stderr]    Compiling safe_arch v0.7.1
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling getrandom v0.2.12
[INFO] [stderr]    Compiling unicode-width v0.1.11
[INFO] [stderr]    Compiling rawpointer v0.2.1
[INFO] [stderr]    Compiling fixedbitset v0.4.2
[INFO] [stderr]    Compiling anyhow v1.0.75
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling num-complex v0.4.4
[INFO] [stderr]    Compiling wide v0.7.13
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling approx v0.5.1
[INFO] [stderr]    Compiling console v0.15.7
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling rand_pcg v0.3.1
[INFO] [stderr]    Compiling hashbrown v0.14.3
[INFO] [stderr]    Compiling rayon-cond v0.2.0
[INFO] [stderr]    Compiling glam v0.24.2
[INFO] [stderr]    Compiling memchr v2.6.4
[INFO] [stderr]    Compiling simba v0.8.1
[INFO] [stderr]    Compiling number_prefix v0.4.0
[INFO] [stderr]    Compiling indicatif v0.17.7
[INFO] [stderr]    Compiling indexmap v2.1.0
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling itertools v0.12.0
[INFO] [stderr]    Compiling petgraph v0.6.4
[INFO] [stderr]    Compiling num v0.4.1
[INFO] [stderr]    Compiling indextree v4.6.0
[INFO] [stderr]    Compiling nalgebra-macros v0.2.1
[INFO] [stderr]    Compiling rustworkx-core v0.13.2
[INFO] [stderr]    Compiling nalgebra v0.32.3
[INFO] [stderr]    Compiling aoc-2023 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day08-part1.rs:17:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map)> {
[INFO] [stdout]    |                 ^^^^ the lifetime is elided here   ^^^ the same lifetime is hidden 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] 17 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map<'_>)> {
[INFO] [stdout]    |                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]   --> src/bin/day18-part2.rs:81:23
[INFO] [stdout]    |
[INFO] [stdout] 81 |         .map(|(a, b)| (a.x * b.y - a.y * b.x))
[INFO] [stdout]    |                       ^                     ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 81 -         .map(|(a, b)| (a.x * b.y - a.y * b.x))
[INFO] [stdout] 81 +         .map(|(a, b)| a.x * b.y - a.y * b.x )
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]  --> src/main.rs:4:9
[INFO] [stdout]   |
[INFO] [stdout] 4 |     let mut lines = input.lines();
[INFO] [stdout]   |         ----^^^^^
[INFO] [stdout]   |         |
[INFO] [stdout]   |         help: remove this `mut`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `lines`
[INFO] [stdout]  --> src/main.rs:4:9
[INFO] [stdout]   |
[INFO] [stdout] 4 |     let mut lines = input.lines();
[INFO] [stdout]   |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_lines`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parsed`
[INFO] [stdout]  --> src/main.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | fn part1(parsed: &str) -> usize {
[INFO] [stdout]   |          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parsed`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]   --> src/bin/day24-part1.rs:42:21
[INFO] [stdout]    |
[INFO] [stdout] 42 |         .filter(|t| (t.x >= 0. && t.y >= 0.))
[INFO] [stdout]    |                     ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 42 -         .filter(|t| (t.x >= 0. && t.y >= 0.))
[INFO] [stdout] 42 +         .filter(|t| t.x >= 0. && t.y >= 0. )
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day25-part1.rs:33:17
[INFO] [stdout]    |
[INFO] [stdout] 33 | fn parse(input: &str) -> Components {
[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] 33 | fn parse(input: &str) -> Components<'_> {
[INFO] [stdout]    |                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day20-part2.rs:29:17
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn parse(input: &str) -> HashMap<&str, Module> {
[INFO] [stdout]    |                 ^^^^             ^^^^  ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |                |
[INFO] [stdout]    |                 |                the same lifetime is elided here
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn parse(input: &str) -> HashMap<&str, Module<'_>> {
[INFO] [stdout]    |                                              ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day08-part2.rs:18:17
[INFO] [stdout]    |
[INFO] [stdout] 18 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map)> {
[INFO] [stdout]    |                 ^^^^ the lifetime is elided here   ^^^ the same lifetime is hidden 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] 18 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map<'_>)> {
[INFO] [stdout]    |                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day19-part2.rs:60:17
[INFO] [stdout]    |
[INFO] [stdout] 60 | fn parse(input: &str) -> anyhow::Result<Workflows> {
[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] 60 | fn parse(input: &str) -> anyhow::Result<Workflows<'_>> {
[INFO] [stdout]    |                                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_pipes` is never used
[INFO] [stdout]    --> src/bin/day10-part1.rs:119:4
[INFO] [stdout]     |
[INFO] [stdout] 119 | fn print_pipes(pipes: &Vec<Vec<Tile>>) {
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day20-part1.rs:27:17
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn parse(input: &str) -> HashMap<&str, Module> {
[INFO] [stdout]    |                 ^^^^             ^^^^  ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |                |
[INFO] [stdout]    |                 |                the same lifetime is elided here
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn parse(input: &str) -> HashMap<&str, Module<'_>> {
[INFO] [stdout]    |                                              ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day19-part1.rs:80:17
[INFO] [stdout]    |
[INFO] [stdout] 80 | fn parse(input: &str) -> anyhow::Result<Aplenty> {
[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] 80 | fn parse(input: &str) -> anyhow::Result<Aplenty<'_>> {
[INFO] [stdout]    |                                                ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]   --> src/bin/day03-part2.rs:74:37
[INFO] [stdout]    |
[INFO] [stdout] 74 |         .filter(|(_, gear_numbers)| (gear_numbers.len() > 1))
[INFO] [stdout]    |                                     ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 74 -         .filter(|(_, gear_numbers)| (gear_numbers.len() > 1))
[INFO] [stdout] 74 +         .filter(|(_, gear_numbers)| gear_numbers.len() > 1 )
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Range`
[INFO] [stdout]  --> src/bin/day13-part1.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ops::Range;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 12s
[INFO] running `Command { std: "docker" "inspect" "cf1890f1f52bef78c1f37d8babeb199a464e54b5d60164822bcf989d6b96e500", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cf1890f1f52bef78c1f37d8babeb199a464e54b5d60164822bcf989d6b96e500", kill_on_drop: false }`
[INFO] [stdout] cf1890f1f52bef78c1f37d8babeb199a464e54b5d60164822bcf989d6b96e500
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2f1e447abb50218da23e8bf716bee3c8ce1922b3e17c200509a92105a6e82850
[INFO] running `Command { std: "docker" "start" "-a" "2f1e447abb50218da23e8bf716bee3c8ce1922b3e17c200509a92105a6e82850", kill_on_drop: false }`
[INFO] [stderr]    Compiling aoc-2023 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]   --> src/bin/day18-part2.rs:81:23
[INFO] [stdout]    |
[INFO] [stdout] 81 |         .map(|(a, b)| (a.x * b.y - a.y * b.x))
[INFO] [stdout]    |                       ^                     ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 81 -         .map(|(a, b)| (a.x * b.y - a.y * b.x))
[INFO] [stdout] 81 +         .map(|(a, b)| a.x * b.y - a.y * b.x )
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day08-part1.rs:17:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map)> {
[INFO] [stdout]    |                 ^^^^ the lifetime is elided here   ^^^ the same lifetime is hidden 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] 17 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map<'_>)> {
[INFO] [stdout]    |                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day08-part2.rs:18:17
[INFO] [stdout]    |
[INFO] [stdout] 18 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map)> {
[INFO] [stdout]    |                 ^^^^ the lifetime is elided here   ^^^ the same lifetime is hidden 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] 18 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map<'_>)> {
[INFO] [stdout]    |                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]  --> src/main.rs:4:9
[INFO] [stdout]   |
[INFO] [stdout] 4 |     let mut lines = input.lines();
[INFO] [stdout]   |         ----^^^^^
[INFO] [stdout]   |         |
[INFO] [stdout]   |         help: remove this `mut`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `lines`
[INFO] [stdout]  --> src/main.rs:4:9
[INFO] [stdout]   |
[INFO] [stdout] 4 |     let mut lines = input.lines();
[INFO] [stdout]   |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_lines`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `parsed`
[INFO] [stdout]  --> src/main.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | fn part1(parsed: &str) -> usize {
[INFO] [stdout]   |          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parsed`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day25-part1.rs:33:17
[INFO] [stdout]    |
[INFO] [stdout] 33 | fn parse(input: &str) -> Components {
[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] 33 | fn parse(input: &str) -> Components<'_> {
[INFO] [stdout]    |                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day19-part2.rs:60:17
[INFO] [stdout]    |
[INFO] [stdout] 60 | fn parse(input: &str) -> anyhow::Result<Workflows> {
[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] 60 | fn parse(input: &str) -> anyhow::Result<Workflows<'_>> {
[INFO] [stdout]    |                                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Range`
[INFO] [stdout]  --> src/bin/day13-part1.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ops::Range;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day20-part1.rs:27:17
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn parse(input: &str) -> HashMap<&str, Module> {
[INFO] [stdout]    |                 ^^^^             ^^^^  ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |                |
[INFO] [stdout]    |                 |                the same lifetime is elided here
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn parse(input: &str) -> HashMap<&str, Module<'_>> {
[INFO] [stdout]    |                                              ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]   --> src/bin/day24-part1.rs:42:21
[INFO] [stdout]    |
[INFO] [stdout] 42 |         .filter(|t| (t.x >= 0. && t.y >= 0.))
[INFO] [stdout]    |                     ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 42 -         .filter(|t| (t.x >= 0. && t.y >= 0.))
[INFO] [stdout] 42 +         .filter(|t| t.x >= 0. && t.y >= 0. )
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_pipes` is never used
[INFO] [stdout]    --> src/bin/day10-part1.rs:119:4
[INFO] [stdout]     |
[INFO] [stdout] 119 | fn print_pipes(pipes: &Vec<Vec<Tile>>) {
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day19-part1.rs:80:17
[INFO] [stdout]    |
[INFO] [stdout] 80 | fn parse(input: &str) -> anyhow::Result<Aplenty> {
[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] 80 | fn parse(input: &str) -> anyhow::Result<Aplenty<'_>> {
[INFO] [stdout]    |                                                ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]   --> src/bin/day03-part2.rs:74:37
[INFO] [stdout]    |
[INFO] [stdout] 74 |         .filter(|(_, gear_numbers)| (gear_numbers.len() > 1))
[INFO] [stdout]    |                                     ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 74 -         .filter(|(_, gear_numbers)| (gear_numbers.len() > 1))
[INFO] [stdout] 74 +         .filter(|(_, gear_numbers)| gear_numbers.len() > 1 )
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/bin/day20-part2.rs:29:17
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn parse(input: &str) -> HashMap<&str, Module> {
[INFO] [stdout]    |                 ^^^^             ^^^^  ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |                |
[INFO] [stdout]    |                 |                the same lifetime is elided here
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn parse(input: &str) -> HashMap<&str, Module<'_>> {
[INFO] [stdout]    |                                              ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 18.04s
[INFO] running `Command { std: "docker" "inspect" "2f1e447abb50218da23e8bf716bee3c8ce1922b3e17c200509a92105a6e82850", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2f1e447abb50218da23e8bf716bee3c8ce1922b3e17c200509a92105a6e82850", kill_on_drop: false }`
[INFO] [stdout] 2f1e447abb50218da23e8bf716bee3c8ce1922b3e17c200509a92105a6e82850
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+0d162b25edd5bf0dba9a22e83b614f1113e90474" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 3596f12ed057f30d7f97b0f39d5f4e9e13f4bb84aa404f16ea319405c25f118d
[INFO] running `Command { std: "docker" "start" "-a" "3596f12ed057f30d7f97b0f39d5f4e9e13f4bb84aa404f16ea319405c25f118d", kill_on_drop: false }`
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/bin/day19-part1.rs:80:17
[INFO] [stderr]    |
[INFO] [stderr] 80 | fn parse(input: &str) -> anyhow::Result<Aplenty> {
[INFO] [stderr]    |                 ^^^^                    ^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 80 | fn parse(input: &str) -> anyhow::Result<Aplenty<'_>> {
[INFO] [stderr]    |                                                ++++
[INFO] [stderr] 
[INFO] [stderr] warning: `aoc-2023` (bin "day19-part1" test) generated 1 warning (run `cargo fix --bin "day19-part1" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr] warning: unnecessary parentheses around closure body
[INFO] [stderr]   --> src/bin/day24-part1.rs:42:21
[INFO] [stderr]    |
[INFO] [stderr] 42 |         .filter(|t| (t.x >= 0. && t.y >= 0.))
[INFO] [stderr]    |                     ^                      ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 42 -         .filter(|t| (t.x >= 0. && t.y >= 0.))
[INFO] [stderr] 42 +         .filter(|t| t.x >= 0. && t.y >= 0. )
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/bin/day08-part2.rs:18:17
[INFO] [stderr]    |
[INFO] [stderr] 18 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map)> {
[INFO] [stderr]    |                 ^^^^ the lifetime is elided here   ^^^ the same lifetime is hidden here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 18 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map<'_>)> {
[INFO] [stderr]    |                                                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/bin/day20-part1.rs:27:17
[INFO] [stderr]    |
[INFO] [stderr] 27 | fn parse(input: &str) -> HashMap<&str, Module> {
[INFO] [stderr]    |                 ^^^^             ^^^^  ^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |                |
[INFO] [stderr]    |                 |                the same lifetime is elided here
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 27 | fn parse(input: &str) -> HashMap<&str, Module<'_>> {
[INFO] [stderr]    |                                              ++++
[INFO] [stderr] 
[INFO] [stderr] warning: `aoc-2023` (bin "day24-part1" test) generated 1 warning (run `cargo fix --bin "day24-part1" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr] warning: `aoc-2023` (bin "day08-part2" test) generated 1 warning (run `cargo fix --bin "day08-part2" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr] warning: `aoc-2023` (bin "day20-part1" test) generated 1 warning (run `cargo fix --bin "day20-part1" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr] warning: unused import: `std::ops::Range`
[INFO] [stderr]  --> src/bin/day13-part1.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::ops::Range;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `print_pipes` is never used
[INFO] [stderr]    --> src/bin/day10-part1.rs:119:4
[INFO] [stderr]     |
[INFO] [stderr] 119 | fn print_pipes(pipes: &Vec<Vec<Tile>>) {
[INFO] [stderr]     |    ^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/bin/day08-part1.rs:17:17
[INFO] [stderr]    |
[INFO] [stderr] 17 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map)> {
[INFO] [stderr]    |                 ^^^^ the lifetime is elided here   ^^^ the same lifetime is hidden here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 17 | fn parse(input: &str) -> anyhow::Result<(Vec<Dir>, Map<'_>)> {
[INFO] [stderr]    |                                                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/bin/day25-part1.rs:33:17
[INFO] [stderr]    |
[INFO] [stderr] 33 | fn parse(input: &str) -> Components {
[INFO] [stderr]    |                 ^^^^     ^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 33 | fn parse(input: &str) -> Components<'_> {
[INFO] [stderr]    |                                    ++++
[INFO] [stderr] 
[INFO] [stderr] warning: `aoc-2023` (bin "day13-part1" test) generated 1 warning (run `cargo fix --bin "day13-part1" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr] warning: `aoc-2023` (bin "day10-part1" test) generated 1 warning
[INFO] [stderr] warning: `aoc-2023` (bin "day08-part1" test) generated 1 warning (run `cargo fix --bin "day08-part1" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr] warning: `aoc-2023` (bin "day25-part1" test) generated 1 warning (run `cargo fix --bin "day25-part1" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/bin/day19-part2.rs:60:17
[INFO] [stderr]    |
[INFO] [stderr] 60 | fn parse(input: &str) -> anyhow::Result<Workflows> {
[INFO] [stderr]    |                 ^^^^                    ^^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 60 | fn parse(input: &str) -> anyhow::Result<Workflows<'_>> {
[INFO] [stderr]    |                                                  ++++
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around closure body
[INFO] [stderr]   --> src/bin/day18-part2.rs:81:23
[INFO] [stderr]    |
[INFO] [stderr] 81 |         .map(|(a, b)| (a.x * b.y - a.y * b.x))
[INFO] [stderr]    |                       ^                     ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 81 -         .map(|(a, b)| (a.x * b.y - a.y * b.x))
[INFO] [stderr] 81 +         .map(|(a, b)| a.x * b.y - a.y * b.x )
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: `aoc-2023` (bin "day19-part2" test) generated 1 warning (run `cargo fix --bin "day19-part2" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr] warning: `aoc-2023` (bin "day18-part2" test) generated 1 warning (run `cargo fix --bin "day18-part2" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]  --> src/main.rs:4:9
[INFO] [stderr]   |
[INFO] [stderr] 4 |     let mut lines = input.lines();
[INFO] [stderr]   |         ----^^^^^
[INFO] [stderr]   |         |
[INFO] [stderr]   |         help: remove this `mut`
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `lines`
[INFO] [stderr]  --> src/main.rs:4:9
[INFO] [stderr]   |
[INFO] [stderr] 4 |     let mut lines = input.lines();
[INFO] [stderr]   |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_lines`
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `parsed`
[INFO] [stderr]  --> src/main.rs:7:10
[INFO] [stderr]   |
[INFO] [stderr] 7 | fn part1(parsed: &str) -> usize {
[INFO] [stderr]   |          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_parsed`
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around closure body
[INFO] [stderr]   --> src/bin/day03-part2.rs:74:37
[INFO] [stderr]    |
[INFO] [stderr] 74 |         .filter(|(_, gear_numbers)| (gear_numbers.len() > 1))
[INFO] [stderr]    |                                     ^                      ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 74 -         .filter(|(_, gear_numbers)| (gear_numbers.len() > 1))
[INFO] [stderr] 74 +         .filter(|(_, gear_numbers)| gear_numbers.len() > 1 )
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: `aoc-2023` (bin "aoc-2023" test) generated 3 warnings (run `cargo fix --bin "aoc-2023" -p aoc-2023 --tests` to apply 3 suggestions)
[INFO] [stderr] warning: `aoc-2023` (bin "day03-part2" test) generated 1 warning (run `cargo fix --bin "day03-part2" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/bin/day20-part2.rs:29:17
[INFO] [stderr]    |
[INFO] [stderr] 29 | fn parse(input: &str) -> HashMap<&str, Module> {
[INFO] [stderr]    |                 ^^^^             ^^^^  ^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                 |                |
[INFO] [stderr]    |                 |                the same lifetime is elided here
[INFO] [stderr]    |                 the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 29 | fn parse(input: &str) -> HashMap<&str, Module<'_>> {
[INFO] [stderr]    |                                              ++++
[INFO] [stderr] 
[INFO] [stderr] warning: `aoc-2023` (bin "day20-part2" test) generated 1 warning (run `cargo fix --bin "day20-part2" -p aoc-2023 --tests` to apply 1 suggestion)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.19s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/aoc_2023-57456e52dca6284b)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day01-part1.rs (/opt/rustwide/target/debug/deps/day01_part1-7b2661a8bd3c96a3)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day01-part2.rs (/opt/rustwide/target/debug/deps/day01_part2-9c6c9a33a3c160e9)
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test tests::one_line ... ok
[INFO] [stdout] test tests::same_digits ... ok
[INFO] [stdout] test tests::part2 ... ok
[INFO] [stdout] test tests::same_words ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day02-part1.rs (/opt/rustwide/target/debug/deps/day02_part1-57f28d9f11760901)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day02-part2.rs (/opt/rustwide/target/debug/deps/day02_part2-c34ca66c4a7e5f49)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test tests::part2_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day03-part1.rs (/opt/rustwide/target/debug/deps/day03_part1-4406148e1e213fd0)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day03-part2.rs (/opt/rustwide/target/debug/deps/day03_part2-b60261916ea8e20e)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::part2_test ... ok
[INFO] [stderr]      Running unittests src/bin/day04-part1.rs (/opt/rustwide/target/debug/deps/day04_part1-51bf149838b60311)
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day04-part2.rs (/opt/rustwide/target/debug/deps/day04_part2-d0ea55220b0a5ff4)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::part2_test ... ok
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day05-part1.rs (/opt/rustwide/target/debug/deps/day05_part1-4906d9b049cab074)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test tests::location_test ... ok
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day05-part2.rs (/opt/rustwide/target/debug/deps/day05_part2-8737ca1c68fa2996)
[INFO] [stdout] 
[INFO] [stdout] running 8 tests
[INFO] [stdout] test tests::location_contains ... ok
[INFO] [stdout] test tests::location_inside ... ok
[INFO] [stdout] test tests::location_multimap ... ok
[INFO] [stdout] test tests::location_left ... ok
[INFO] [stdout] test tests::location_outside ... ok
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part2_test ... ok
[INFO] [stdout] test tests::location_right ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 8 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day06-part1.rs (/opt/rustwide/target/debug/deps/day06_part1-504404225a3bfc93)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day06-part2.rs (/opt/rustwide/target/debug/deps/day06_part2-5f2f4dd24c855c9b)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day07-part1.rs (/opt/rustwide/target/debug/deps/day07_part1-e5c01d4affa06a86)
[INFO] [stdout] 
[INFO] [stdout] running 6 tests
[INFO] [stdout] test tests::handtype_test ... ok
[INFO] [stdout] test tests::handrank ... ok
[INFO] [stdout] test tests::strength_card_test ... ok
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::strength_hand_test ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day07-part2.rs (/opt/rustwide/target/debug/deps/day07_part2-d003fab2253e7e4f)
[INFO] [stdout] 
[INFO] [stdout] running 6 tests
[INFO] [stdout] test tests::handrank ... ok
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::handtype_test ... ok
[INFO] [stdout] test tests::strength_card_test ... ok
[INFO] [stdout] test tests::strength_hand_test ... ok
[INFO] [stdout] test tests::part2_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day08-part1.rs (/opt/rustwide/target/debug/deps/day08_part1-e427264a544c9ff8)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day08-part2.rs (/opt/rustwide/target/debug/deps/day08_part2-c19f10b376257889)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stderr]      Running unittests src/bin/day09-part1.rs (/opt/rustwide/target/debug/deps/day09_part1-63aeca135fe498d9)
[INFO] [stdout] test tests::part2_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stderr]      Running unittests src/bin/day09-part2.rs (/opt/rustwide/target/debug/deps/day09_part2-5bcda0ffb51806d1)
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stderr]      Running unittests src/bin/day10-part1.rs (/opt/rustwide/target/debug/deps/day10_part1-5963d4723bd2e945)
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part2_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test tests::part1_test2 ... ok
[INFO] [stdout] test tests::part1_test1 ... ok
[INFO] [stdout] test tests::tile_display ... ok
[INFO] [stderr]      Running unittests src/bin/day10-part2.rs (/opt/rustwide/target/debug/deps/day10_part2-24fb3aa5afce7e6f)
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.21s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test tests::part2_test2 ... ok
[INFO] [stdout] test tests::tile_display ... ok
[INFO] [stdout] test tests::part2_test3 ... ok
[INFO] [stdout] test tests::part2_test1 ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day11-part1.rs (/opt/rustwide/target/debug/deps/day11_part1-12ebe5b6e3ccf109)
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test tests::length ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::expansion ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day11-part2.rs (/opt/rustwide/target/debug/deps/day11_part2-666322625a15d63e)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parsing ... ok
[INFO] [stdout] test tests::part2_test ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/bin/day12-part1.rs (/opt/rustwide/target/debug/deps/day12_part1-c1fef5228a830e82)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test tests::arrangements ... ok
[INFO] [stdout] test tests::part1_test ... ok
[INFO] [stdout] test tests::parsing ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- tests::parsing stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'tests::parsing' (107) panicked at src/bin/day12-part1.rs:138:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: "???.### : 1,1,3,"
[INFO] [stdout]  right: "???.###"
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x6469c490d032 - std[3b51380354919863]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x6469c490d032 - std[3b51380354919863]::backtrace_rs::backtrace::trace_unsynchronized::<std[3b51380354919863]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x6469c490d032 - std[3b51380354919863]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x6469c490d032 - <<std[3b51380354919863]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[27de1724e4349be2]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x6469c49218aa - <core[27de1724e4349be2]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x6469c49218aa - core[27de1724e4349be2]::fmt::write
[INFO] [stdout]    6:     0x6469c4911e36 - std[3b51380354919863]::io::default_write_fmt::<alloc[a57f19327c0ad893]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x6469c4911e36 - <alloc[a57f19327c0ad893]::vec::Vec<u8> as std[3b51380354919863]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x6469c48eb7cf - <std[3b51380354919863]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x6469c48eb7cf - std[3b51380354919863]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x6469c4905319 - std[3b51380354919863]::panicking::default_hook
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x6469c48a0d9e - <alloc[a57f19327c0ad893]::boxed::Box<dyn for<'a, 'b> core[27de1724e4349be2]::ops::function::Fn<(&'a std[3b51380354919863]::panic::PanicHookInfo<'b>,), Output = ()> + core[27de1724e4349be2]::marker::Sync + core[27de1724e4349be2]::marker::Send> as core[27de1724e4349be2]::ops::function::Fn<(&std[3b51380354919863]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x6469c48a0d9e - test[182b2e79ecd7bbd9]::test_main_with_exit_callback::<test[182b2e79ecd7bbd9]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x6469c49054d2 - <alloc[a57f19327c0ad893]::boxed::Box<dyn for<'a, 'b> core[27de1724e4349be2]::ops::function::Fn<(&'a std[3b51380354919863]::panic::PanicHookInfo<'b>,), Output = ()> + core[27de1724e4349be2]::marker::Sync + core[27de1724e4349be2]::marker::Send> as core[27de1724e4349be2]::ops::function::Fn<(&std[3b51380354919863]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x6469c49054d2 - std[3b51380354919863]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x6469c48eb888 - std[3b51380354919863]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x6469c48e0b09 - std[3b51380354919863]::sys::backtrace::__rust_end_short_backtrace::<std[3b51380354919863]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x6469c48ec6dd - __rustc[d79c0ace40940972]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x6469c4921f5c - core[27de1724e4349be2]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x6469c4921e73 - core[27de1724e4349be2]::panicking::assert_failed_inner
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/panicking.rs:439:17
[INFO] [stdout]   20:     0x6469c488b536 - core[27de1724e4349be2]::panicking::assert_failed::<alloc[a57f19327c0ad893]::string::String, &str>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x6469c48909bf - day12_part1[53858941f338d004]::tests::parsing
[INFO] [stdout]                                at /opt/rustwide/workdir/src/bin/day12-part1.rs:138:9
[INFO] [stdout]   22:     0x6469c48902d7 - day12_part1[53858941f338d004]::tests::parsing::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/bin/day12-part1.rs:136:17
[INFO] [stdout]   23:     0x6469c488ecc6 - <day12_part1[53858941f338d004]::tests::parsing::{closure#0} as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x6469c489514b - <fn() -> core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String> as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x6469c489514b - test[182b2e79ecd7bbd9]::__rust_begin_short_backtrace::<core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String>, fn() -> core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x6469c48a19aa - test[182b2e79ecd7bbd9]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x6469c48a19aa - <core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<test[182b2e79ecd7bbd9]::run_test_in_process::{closure#0}> as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x6469c48a19aa - std[3b51380354919863]::panicking::catch_unwind::do_call::<core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<test[182b2e79ecd7bbd9]::run_test_in_process::{closure#0}>, core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:581:40
[INFO] [stdout]   29:     0x6469c48a19aa - std[3b51380354919863]::panicking::catch_unwind::<core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String>, core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<test[182b2e79ecd7bbd9]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:544:19
[INFO] [stdout]   30:     0x6469c48a19aa - std[3b51380354919863]::panic::catch_unwind::<core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<test[182b2e79ecd7bbd9]::run_test_in_process::{closure#0}>, core[27de1724e4349be2]::result::Result<(), alloc[a57f19327c0ad893]::string::String>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x6469c48a19aa - test[182b2e79ecd7bbd9]::run_test_in_process
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x6469c48a19aa - test[182b2e79ecd7bbd9]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x6469c489cf54 - test[182b2e79ecd7bbd9]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x6469c489cf54 - std[3b51380354919863]::sys::backtrace::__rust_begin_short_backtrace::<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   35:     0x6469c48a44a2 - std[3b51380354919863]::thread::lifecycle::spawn_unchecked::<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   36:     0x6469c48a44a2 - <core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<std[3b51380354919863]::thread::lifecycle::spawn_unchecked<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x6469c48a44a2 - std[3b51380354919863]::panicking::catch_unwind::do_call::<core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<std[3b51380354919863]::thread::lifecycle::spawn_unchecked<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:581:40
[INFO] [stdout]   38:     0x6469c48a44a2 - std[3b51380354919863]::panicking::catch_unwind::<(), core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<std[3b51380354919863]::thread::lifecycle::spawn_unchecked<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panicking.rs:544:19
[INFO] [stdout]   39:     0x6469c48a44a2 - std[3b51380354919863]::panic::catch_unwind::<core[27de1724e4349be2]::panic::unwind_safe::AssertUnwindSafe<std[3b51380354919863]::thread::lifecycle::spawn_unchecked<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x6469c48a44a2 - std[3b51380354919863]::thread::lifecycle::spawn_unchecked::<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   41:     0x6469c48a44a2 - <std[3b51380354919863]::thread::lifecycle::spawn_unchecked<test[182b2e79ecd7bbd9]::run_test::{closure#1}, ()>::{closure#1} as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x6469c490c8df - <alloc[a57f19327c0ad893]::boxed::Box<dyn core[27de1724e4349be2]::ops::function::FnOnce<(), Output = ()> + core[27de1724e4349be2]::marker::Send> as core[27de1724e4349be2]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   43:     0x6469c490c8df - <std[3b51380354919863]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/0d162b25edd5bf0dba9a22e83b614f1113e90474/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   44:     0x79b0cb298aa4 - <unknown>
[INFO] [stdout]   45:     0x79b0cb325a64 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     tests::parsing
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 2 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin day12-part1`
[INFO] running `Command { std: "docker" "inspect" "3596f12ed057f30d7f97b0f39d5f4e9e13f4bb84aa404f16ea319405c25f118d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3596f12ed057f30d7f97b0f39d5f4e9e13f4bb84aa404f16ea319405c25f118d", kill_on_drop: false }`
[INFO] [stdout] 3596f12ed057f30d7f97b0f39d5f4e9e13f4bb84aa404f16ea319405c25f118d
