[INFO] cloning repository https://github.com/RichoDemus/advent-of-code-2019
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/RichoDemus/advent-of-code-2019" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FRichoDemus%2Fadvent-of-code-2019", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FRichoDemus%2Fadvent-of-code-2019'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 4dc90f4628a049aa6e8bfb9029f242e8bdc5c71b
[INFO] testing RichoDemus/advent-of-code-2019 against master#1ef7943ee607160a564655b6596f83670ef95df5 for pr-146098-6
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FRichoDemus%2Fadvent-of-code-2019" "/workspace/builds/worker-5-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc1/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-5-tc1/source/rust-toolchain
[INFO] started tweaking git repo https://github.com/RichoDemus/advent-of-code-2019
[INFO] finished tweaking git repo https://github.com/RichoDemus/advent-of-code-2019
[INFO] tweaked toml for git repo https://github.com/RichoDemus/advent-of-code-2019 written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/RichoDemus/advent-of-code-2019 on toolchain 1ef7943ee607160a564655b6596f83670ef95df5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/RichoDemus/advent-of-code-2019 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" "+1ef7943ee607160a564655b6596f83670ef95df5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded num-rational v0.2.3
[INFO] [stderr]   Downloaded num-bigint v0.2.5
[INFO] [stderr]   Downloaded float-cmp v0.6.0
[INFO] [stderr]   Downloaded itertools v0.8.2
[INFO] [stderr]   Downloaded array_tool v0.4.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 525ddf907e5e3c6565a31526560de86212886458c16f066e6fee00423ecf8167
[INFO] running `Command { std: "docker" "start" "-a" "525ddf907e5e3c6565a31526560de86212886458c16f066e6fee00423ecf8167", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "525ddf907e5e3c6565a31526560de86212886458c16f066e6fee00423ecf8167", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "525ddf907e5e3c6565a31526560de86212886458c16f066e6fee00423ecf8167", kill_on_drop: false }`
[INFO] [stdout] 525ddf907e5e3c6565a31526560de86212886458c16f066e6fee00423ecf8167
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5bf422d9076352211e190dcd2fe38eb0dedce59fc79a279be6b66b1b3bef08d0
[INFO] running `Command { std: "docker" "start" "-a" "5bf422d9076352211e190dcd2fe38eb0dedce59fc79a279be6b66b1b3bef08d0", kill_on_drop: false }`
[INFO] [stderr]    Compiling autocfg v1.0.0
[INFO] [stderr]    Compiling either v1.5.3
[INFO] [stderr]    Compiling array_tool v0.4.1
[INFO] [stderr]    Compiling itertools v0.8.2
[INFO] [stderr]    Compiling num-traits v0.2.11
[INFO] [stderr]    Compiling num-integer v0.1.42
[INFO] [stderr]    Compiling num-bigint v0.2.5
[INFO] [stderr]    Compiling num-iter v0.1.40
[INFO] [stderr]    Compiling num-rational v0.2.3
[INFO] [stderr]    Compiling num-complex v0.2.4
[INFO] [stderr]    Compiling float-cmp v0.6.0
[INFO] [stderr]    Compiling num v0.2.1
[INFO] [stderr]    Compiling advent-of-code-2019 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `split`
[INFO] [stdout]   --> src/twelve.rs:61:17
[INFO] [stdout]    |
[INFO] [stdout] 61 |             let split: Vec<&str> = s.split_ascii_whitespace().collect();
[INFO] [stdout]    |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_split`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `outputs` is never read
[INFO] [stdout]   --> src/intputer.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub(crate) struct Intputer {
[INFO] [stdout]    |                   -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 20 |     outputs: Vec<i64>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Intputer` 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 `x_max` and `y_max` are never read
[INFO] [stdout]    --> src/ten.rs:161:5
[INFO] [stdout]     |
[INFO] [stdout] 160 | struct AsteroidField {
[INFO] [stdout]     |        ------------- fields in this struct
[INFO] [stdout] 161 |     x_max: i32,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 162 |     y_max: i32,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_max_laser_length` is never used
[INFO] [stdout]    --> src/ten.rs:270:4
[INFO] [stdout]     |
[INFO] [stdout] 270 | fn calculate_max_laser_length(field: &AsteroidField, station: &Point) -> i32 {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from` is never used
[INFO] [stdout]    --> src/eleven.rs:184:8
[INFO] [stdout]     |
[INFO] [stdout] 183 | impl Robot {
[INFO] [stdout]     | ---------- associated function in this implementation
[INFO] [stdout] 184 |     fn from(y: i32, x: i32, direction: Direction) -> Robot {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Body` is never constructed
[INFO] [stdout]  --> src/twelve.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | struct Body {
[INFO] [stdout]   |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from` is never used
[INFO] [stdout]   --> src/twelve.rs:16:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | impl Body {
[INFO] [stdout]    | --------- associated function in this implementation
[INFO] [stdout] 16 |     fn from(s: &str) -> Body {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Space` is never constructed
[INFO] [stdout]   --> src/twelve.rs:90:8
[INFO] [stdout]    |
[INFO] [stdout] 90 | struct Space {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `parse`, `parse_str`, and `tick` are never used
[INFO] [stdout]    --> src/twelve.rs:96:8
[INFO] [stdout]     |
[INFO] [stdout]  95 | impl Space {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout]  96 |     fn parse(input: Vec<String>) -> Space {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     fn parse_str(input: Vec<&str>) -> Space {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 116 |     fn tick(&mut self)  {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_input` is never used
[INFO] [stdout]    --> src/twelve.rs:123:4
[INFO] [stdout]     |
[INFO] [stdout] 123 | fn read_input() -> Vec<Body> {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: using `.clone()` on a double reference, which returns `&six::Body` instead of cloning the inner type
[INFO] [stdout]   --> src/six.rs:51:25
[INFO] [stdout]    |
[INFO] [stdout] 51 |         current = parent.clone();
[INFO] [stdout]    |                         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(suspicious_double_ref_op)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/intputer.rs:237:25
[INFO] [stdout]     |
[INFO] [stdout] 237 |             _ => panic!(format!("Unknown mode {}", mode)),
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `panic!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 237 -             _ => panic!(format!("Unknown mode {}", mode)),
[INFO] [stdout] 237 +             _ => panic!("Unknown mode {}", mode),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::mem::replace` that must be used
[INFO] [stdout]    --> src/eight.rs:130:17
[INFO] [stdout]     |
[INFO] [stdout] 130 |                 std::mem::replace(&mut row[index], cell);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the old value, you can just assign the new value directly
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 130 |                 let _ = std::mem::replace(&mut row[index], cell);
[INFO] [stdout]     |                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 5.62s
[INFO] running `Command { std: "docker" "inspect" "5bf422d9076352211e190dcd2fe38eb0dedce59fc79a279be6b66b1b3bef08d0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5bf422d9076352211e190dcd2fe38eb0dedce59fc79a279be6b66b1b3bef08d0", kill_on_drop: false }`
[INFO] [stdout] 5bf422d9076352211e190dcd2fe38eb0dedce59fc79a279be6b66b1b3bef08d0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 923f963ceba784628ca41aa9f874d5484e45e74bf457a23cd0d8465927fa7717
[INFO] running `Command { std: "docker" "start" "-a" "923f963ceba784628ca41aa9f874d5484e45e74bf457a23cd0d8465927fa7717", kill_on_drop: false }`
[INFO] [stderr]    Compiling advent-of-code-2019 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `split`
[INFO] [stdout]   --> src/twelve.rs:61:17
[INFO] [stdout]    |
[INFO] [stdout] 61 |             let split: Vec<&str> = s.split_ascii_whitespace().collect();
[INFO] [stdout]    |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_split`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `outputs` is never read
[INFO] [stdout]   --> src/intputer.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub(crate) struct Intputer {
[INFO] [stdout]    |                   -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 20 |     outputs: Vec<i64>,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Intputer` 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: using `.clone()` on a double reference, which returns `&six::Body` instead of cloning the inner type
[INFO] [stdout]   --> src/six.rs:51:25
[INFO] [stdout]    |
[INFO] [stdout] 51 |         current = parent.clone();
[INFO] [stdout]    |                         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(suspicious_double_ref_op)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/intputer.rs:237:25
[INFO] [stdout]     |
[INFO] [stdout] 237 |             _ => panic!(format!("Unknown mode {}", mode)),
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: the `panic!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: remove the `format!(..)` macro call
[INFO] [stdout]     |
[INFO] [stdout] 237 -             _ => panic!(format!("Unknown mode {}", mode)),
[INFO] [stdout] 237 +             _ => panic!("Unknown mode {}", mode),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `std::mem::replace` that must be used
[INFO] [stdout]    --> src/eight.rs:130:17
[INFO] [stdout]     |
[INFO] [stdout] 130 |                 std::mem::replace(&mut row[index], cell);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: if you don't need the old value, you can just assign the new value directly
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 130 |                 let _ = std::mem::replace(&mut row[index], cell);
[INFO] [stdout]     |                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 2.01s
[INFO] running `Command { std: "docker" "inspect" "923f963ceba784628ca41aa9f874d5484e45e74bf457a23cd0d8465927fa7717", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "923f963ceba784628ca41aa9f874d5484e45e74bf457a23cd0d8465927fa7717", kill_on_drop: false }`
[INFO] [stdout] 923f963ceba784628ca41aa9f874d5484e45e74bf457a23cd0d8465927fa7717
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1ef7943ee607160a564655b6596f83670ef95df5" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 1f42b862bcf3204517caaa5f3ab90dd5a0309ee57a57c104875b4f259ab548d3
[INFO] running `Command { std: "docker" "start" "-a" "1f42b862bcf3204517caaa5f3ab90dd5a0309ee57a57c104875b4f259ab548d3", kill_on_drop: false }`
[INFO] [stderr] warning: unused variable: `split`
[INFO] [stderr]   --> src/twelve.rs:61:17
[INFO] [stderr]    |
[INFO] [stderr] 61 |             let split: Vec<&str> = s.split_ascii_whitespace().collect();
[INFO] [stderr]    |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_split`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `outputs` is never read
[INFO] [stderr]   --> src/intputer.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub(crate) struct Intputer {
[INFO] [stderr]    |                   -------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 20 |     outputs: Vec<i64>,
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Intputer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: using `.clone()` on a double reference, which returns `&six::Body` instead of cloning the inner type
[INFO] [stderr]   --> src/six.rs:51:25
[INFO] [stderr]    |
[INFO] [stderr] 51 |         current = parent.clone();
[INFO] [stderr]    |                         ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(suspicious_double_ref_op)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: panic message is not a string literal
[INFO] [stderr]    --> src/intputer.rs:237:25
[INFO] [stderr]     |
[INFO] [stderr] 237 |             _ => panic!(format!("Unknown mode {}", mode)),
[INFO] [stderr]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stderr]     = note: the `panic!()` macro supports formatting, so there's no need for the `format!()` macro here
[INFO] [stderr]     = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stderr] help: remove the `format!(..)` macro call
[INFO] [stderr]     |
[INFO] [stderr] 237 -             _ => panic!(format!("Unknown mode {}", mode)),
[INFO] [stderr] 237 +             _ => panic!("Unknown mode {}", mode),
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused return value of `std::mem::replace` that must be used
[INFO] [stderr]    --> src/eight.rs:130:17
[INFO] [stderr]     |
[INFO] [stderr] 130 |                 std::mem::replace(&mut row[index], cell);
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: if you don't need the old value, you can just assign the new value directly
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 130 |                 let _ = std::mem::replace(&mut row[index], cell);
[INFO] [stderr]     |                 +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `advent-of-code-2019` (bin "advent-of-code-2019" test) generated 5 warnings (run `cargo fix --bin "advent-of-code-2019" -p advent-of-code-2019 --tests` to apply 2 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.07s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/advent_of_code_2019-00afbf849a3a49e9)
[INFO] [stdout] 
[INFO] [stdout] running 63 tests
[INFO] [stdout] test eight::tests::test ... ok
[INFO] [stdout] test eight::tests::test_first ... ok
[INFO] [stdout] test eleven::tests::robot_drive_around ... ok
[INFO] [stdout] test eight::tests::testing_while_impl_part2 ... ok
[INFO] [stdout] test five::tests::i_try_to_write_a_program ... ok
[INFO] [stdout] test eleven::tests::test_calc_min_and_max ... ok
[INFO] [stdout] test four::tests::test_cases ... ok
[INFO] [stdout] test five_part_two::tests::test_equal_eight ... ok
[INFO] [stdout] test four::tests::test_digits ... ok
[INFO] [stdout] test eight::tests::solve_first ... ok
[INFO] [stdout] test four::tests::test_is_valid ... ok
[INFO] [stdout] test five_part_two::tests::test_below_eight ... ok
[INFO] [stdout] test four::tests::test_pairs ... ok
[INFO] [stdout] test intputer::tests::i_try_to_write_a_program ... ok
[INFO] [stdout] test intputer::tests::test_parse_parameter_and_modes ... ok
[INFO] [stdout] test intputer::tests::test_simple_input_output ... ok
[INFO] [stdout] test intputer::tests::test_simpler_run ... ok
[INFO] [stdout] test five::tests::test_simple_input_output ... ok
[INFO] [stdout] test nine::tests::sample_data ... ok
[INFO] [stdout] test five::tests::test_parse_parameter_and_modes ... ok
[INFO] [stdout] test nine::tests::solve_nine ... ok
[INFO] [stdout] test nine::tests::test_relative_base ... ok
[INFO] [stdout] test intputer::tests::new_input_output ... ok
[INFO] [stdout] test six::tests::test_cases ... ok
[INFO] [stdout] test six::tests::test_distance ... ok
[INFO] [stdout] test five_part_two::tests::test_greater_than_eight ... ok
[INFO] [stdout] test one::tests::test ... ok
[INFO] [stdout] test seven::tests::test_feedback_loop ... ok
[INFO] [stdout] test seven::tests::test_permutations ... ok
[INFO] [stdout] test ten::tests::my_test_case ... ok
[INFO] [stdout] test eleven::tests::test_paint_under_robot ... ok
[INFO] [stdout] test six::tests::test_orbital_transfers ... ok
[INFO] [stdout] test ten::tests::my_test_case2 ... ok
[INFO] [stdout] test ten::tests::first_test_case ... ok
[INFO] [stdout] test seven::tests::test_specific ... ok
[INFO] [stdout] test ten::tests::small_example_part2 ... ok
[INFO] [stdout] test ten::tests::test_direction_asteroid_above ... ok
[INFO] [stdout] test ten::tests::test_direction_asteroid_to_left_and_above ... ok
[INFO] [stdout] test ten::tests::test_direction_asteroid_to_left ... ok
[INFO] [stdout] test ten::tests::test_has_asteroid_at ... ok
[INFO] [stdout] test ten::tests::test_atan_version ... ok
[INFO] [stdout] test ten::tests::test_reverse_direction_block ... ok
[INFO] [stdout] test ten::tests::test_calc_max_laser_length ... ok
[INFO] [stdout] test three::tests::test_calculate_path ... ok
[INFO] [stdout] test three::tests::test_distance ... ok
[INFO] [stdout] test three::tests::test_split_input ... ok
[INFO] [stdout] test two::tests::test ... ok
[INFO] [stdout] test two::tests::test_add_params ... ok
[INFO] [stdout] test twelve::tests::parse_input ... ok
[INFO] [stdout] test eleven::tests::actually_solve_eleven_part2 ... ok
[INFO] [stdout] test three::tests::test_fewest_steps ... ok
[INFO] [stdout] test seven::tests::test ... ok
[INFO] [stdout] test eleven::tests::should_be_able_to_move_oob_down - should panic ... ok
[INFO] [stdout] test eleven::tests::should_be_able_to_move_oob_left - should panic ... ok
[INFO] [stdout] test twelve::tests::test_provided_example ... FAILED
[INFO] [stdout] test three::tests::test ... ok
[INFO] [stdout] test eight::tests::test_part2 ... ok
[INFO] [stdout] test eight::tests::test_vec_concat ... ok
[INFO] [stdout] test eleven::tests::actually_solve_eleven_part1 ... ok
[INFO] [stdout] test ten::tests::part2_test_case ... ok
[INFO] [stdout] test nine::tests::solve_nine_part2 ... ok
[INFO] [stdout] test ten::tests::assert_part2_solution ... ok
[INFO] [stdout] test ten::tests::solve_first ... ok
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- twelve::tests::test_provided_example stdout ----
[INFO] [stdout] s: "pos=<x=-1, y=  0, z= 2>, vel=<x= 0, y= 0, z= 0>"
[INFO] [stdout] s: "pos=<x= 2, y=-10, z=-7>, vel=<x= 0, y= 0, z= 0>"
[INFO] [stdout] s: "pos=<x= 4, y= -8, z= 8>, vel=<x= 0, y= 0, z= 0>"
[INFO] [stdout] s: "pos=<x= 3, y=  5, z=-1>, vel=<x= 0, y= 0, z= 0>"
[INFO] [stdout] s: "pos=<x= 2, y=-1, z= 1>, vel=<x= 3, y=-1, z=-1>"
[INFO] [stdout] s: "pos=<x= 3, y=-7, z=-4>, vel=<x= 1, y= 3, z= 3>"
[INFO] [stdout] s: "pos=<x= 1, y=-7, z= 5>, vel=<x=-3, y= 1, z=-3>"
[INFO] [stdout] s: "pos=<x= 2, y= 2, z= 0>, vel=<x=-1, y=-3, z= 1>"
[INFO] [stdout] 
[INFO] [stdout] thread 'twelve::tests::test_provided_example' (84) panicked at src/twelve.rs:168:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: Space { bodies: [Body { y: 0, x: -1, z: 2, dy: 0, dx: 0, dz: 0 }, Body { y: -10, x: 2, z: -7, dy: 0, dx: 0, dz: 0 }, Body { y: -8, x: 4, z: 8, dy: 0, dx: 0, dz: 0 }, Body { y: 5, x: 3, z: -1, dy: 0, dx: 0, dz: 0 }], tick: 1 }
[INFO] [stdout]  right: Space { bodies: [Body { y: -1, x: 2, z: 1, dy: -1, dx: 3, dz: -1 }, Body { y: -7, x: 3, z: -4, dy: 3, dx: 1, dz: 3 }, Body { y: -7, x: 1, z: 5, dy: 1, dx: -3, dz: -3 }, Body { y: 2, x: 2, z: 0, dy: -3, dx: -1, dz: 1 }], tick: 0 }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5f569ba0e692 - std::backtrace_rs::backtrace::libunwind::trace::h786de35fecf3582f
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5f569ba0e692 - std::backtrace_rs::backtrace::trace_unsynchronized::h4a7da1a2a64387f1
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5f569ba0e692 - std::sys::backtrace::_print_fmt::h6bd7d500070c788c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5f569ba0e692 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::h6d82c1afff976903
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5f569ba1e88f - core::fmt::rt::Argument::fmt::hc4ce6d643d397690
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5f569ba1e88f - core::fmt::write::hb1e7ca88b6a3936e
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/fmt/mod.rs:1469:25
[INFO] [stdout]    6:     0x5f569b9dbf23 - std::io::default_write_fmt::haffd49d96f1984a8
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5f569b9dbf23 - std::io::Write::write_fmt::h027871c57cf57c01
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5f569b9e7df2 - std::sys::backtrace::BacktraceLock::print::ha2430613ee79d059
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5f569b9ec92f - std::panicking::default_hook::{{closure}}::hdbd2db9e5c303cf6
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:301:27
[INFO] [stdout]   10:     0x5f569b9ec7c1 - std::panicking::default_hook::hed93c70cba5fdcf0
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:325:9
[INFO] [stdout]   11:     0x5f569b9a6dde - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hd0ee8b569efc6a07
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   12:     0x5f569b9a6dde - test::test_main_with_exit_callback::{{closure}}::hf10864b576ecd15d
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5f569b9ecf3f - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h3a55ca34534c0d00
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2099:9
[INFO] [stdout]   14:     0x5f569b9ecf3f - std::panicking::panic_with_hook::h3862d766c2cec19b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:842:13
[INFO] [stdout]   15:     0x5f569b9ecd9a - std::panicking::panic_handler::{{closure}}::hb95eb402b5e28ee1
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:707:13
[INFO] [stdout]   16:     0x5f569b9e7f39 - std::sys::backtrace::__rust_end_short_backtrace::hf73a26dc1835d85a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x5f569b9d081d - __rustc[6ed5915ee467787]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:698:5
[INFO] [stdout]   18:     0x5f569ba265c0 - core::panicking::panic_fmt::h3454303eb8e6f7cd
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5f569ba263c3 - core::panicking::assert_failed_inner::hdcc703ae7c807131
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:444:17
[INFO] [stdout]   20:     0x5f569b93491f - core::panicking::assert_failed::hc7a61fc7c250d7a8
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panicking.rs:399:5
[INFO] [stdout]   21:     0x5f569b95caf1 - advent_of_code_2019::twelve::tests::test_provided_example::h738ce97fec1442d7
[INFO] [stdout]                                at /opt/rustwide/workdir/src/twelve.rs:168:9
[INFO] [stdout]   22:     0x5f569b95cb47 - advent_of_code_2019::twelve::tests::test_provided_example::{{closure}}::h29aae56dbf163efe
[INFO] [stdout]                                at /opt/rustwide/workdir/src/twelve.rs:147:31
[INFO] [stdout]   23:     0x5f569b95d406 - core::ops::function::FnOnce::call_once::h1350c71fb49fdce6
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5f569b9a6bbb - core::ops::function::FnOnce::call_once::ha729ee35d2fab541
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x5f569b9a6bbb - test::__rust_begin_short_backtrace::ha40f4db8207e1111
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x5f569b9bac3d - test::run_test_in_process::{{closure}}::hc1b77cda5d44f0f3
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x5f569b9bac3d - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h1dbea1de64785521
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x5f569b9bac3d - std::panicking::catch_unwind::do_call::hd5febe9affd5a1b3
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:590:40
[INFO] [stdout]   29:     0x5f569b9bac3d - std::panicking::catch_unwind::h51ea89627559b6f4
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:553:19
[INFO] [stdout]   30:     0x5f569b9bac3d - std::panic::catch_unwind::hb8b8c2367cae3d66
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x5f569b9bac3d - test::run_test_in_process::ha5b55801407ea100
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x5f569b9bac3d - test::run_test::{{closure}}::h0b9d4072b527abf5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x5f569b994154 - test::run_test::{{closure}}::hb1056b5731205822
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x5f569b994154 - std::sys::backtrace::__rust_begin_short_backtrace::hb61ff5a34023c7ef
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   35:     0x5f569b997a8a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hb0a83c0e8b353cff
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/mod.rs:562:17
[INFO] [stdout]   36:     0x5f569b997a8a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hb4f32cb008535298
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x5f569b997a8a - std::panicking::catch_unwind::do_call::h16d110e4fc35789a
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:590:40
[INFO] [stdout]   38:     0x5f569b997a8a - std::panicking::catch_unwind::hea9118f355699c4b
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panicking.rs:553:19
[INFO] [stdout]   39:     0x5f569b997a8a - std::panic::catch_unwind::hf4b3c2a06d3f42f5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x5f569b997a8a - std::thread::Builder::spawn_unchecked_::{{closure}}::h3f4cb733a52d53d5
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/thread/mod.rs:560:30
[INFO] [stdout]   41:     0x5f569b997a8a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h4052f0967b37caeb
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x5f569b9e332f - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h7ec433abd3f148b4
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/alloc/src/boxed.rs:2085:9
[INFO] [stdout]   43:     0x5f569b9e332f - std::sys::thread::unix::Thread::new::thread_start::he514622d3d7ba65c
[INFO] [stdout]                                at /rustc/1ef7943ee607160a564655b6596f83670ef95df5/library/std/src/sys/thread/unix.rs:124:17
[INFO] [stdout]   44:     0x7bf3e9e9faa4 - <unknown>
[INFO] [stdout]   45:     0x7bf3e9f2ca64 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     twelve::tests::test_provided_example
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 62 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.59s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin advent-of-code-2019`
[INFO] running `Command { std: "docker" "inspect" "1f42b862bcf3204517caaa5f3ab90dd5a0309ee57a57c104875b4f259ab548d3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1f42b862bcf3204517caaa5f3ab90dd5a0309ee57a57c104875b4f259ab548d3", kill_on_drop: false }`
[INFO] [stdout] 1f42b862bcf3204517caaa5f3ab90dd5a0309ee57a57c104875b4f259ab548d3
