[INFO] cloning repository https://github.com/ArtShx/100-exercise-rust
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/ArtShx/100-exercise-rust" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArtShx%2F100-exercise-rust", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArtShx%2F100-exercise-rust'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] e5c00c7064daa22601d310a3c7d2de79098209c3
[INFO] checking ArtShx/100-exercise-rust against master#36b21637e93b038453924d3c66821089e71d8baa for pr-143164
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FArtShx%2F100-exercise-rust" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/ArtShx/100-exercise-rust
[INFO] finished tweaking git repo https://github.com/ArtShx/100-exercise-rust
[INFO] tweaked toml for git repo https://github.com/ArtShx/100-exercise-rust written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/ArtShx/100-exercise-rust on toolchain 36b21637e93b038453924d3c66821089e71d8baa
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/ArtShx/100-exercise-rust 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" "+36b21637e93b038453924d3c66821089e71d8baa" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: profiles for the non root package will be ignored, specify profiles at the workspace root:
[INFO] [stderr] package:   /workspace/builds/worker-1-tc1/source/exercises/02_basic_calculator/08_overflow/Cargo.toml
[INFO] [stderr] workspace: /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded anyhow v1.0.83
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cf8efcab8866f2cf4285301c7418e2f4f2a9b088c91ba69c40d5b659f81557f7" "/opt/rustwide/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] f233787ad45ed3898fc7641769a3437dc26befcfa91a9348cb0eebfb111075f3
[INFO] running `Command { std: "docker" "start" "-a" "f233787ad45ed3898fc7641769a3437dc26befcfa91a9348cb0eebfb111075f3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "f233787ad45ed3898fc7641769a3437dc26befcfa91a9348cb0eebfb111075f3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f233787ad45ed3898fc7641769a3437dc26befcfa91a9348cb0eebfb111075f3", kill_on_drop: false }`
[INFO] [stdout] f233787ad45ed3898fc7641769a3437dc26befcfa91a9348cb0eebfb111075f3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cf8efcab8866f2cf4285301c7418e2f4f2a9b088c91ba69c40d5b659f81557f7" "/opt/rustwide/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 67ce9a0a54e745bd19d54aa8c46e8d9a9d0a97f0a4918d2f6cbf4cd6faf31d44
[INFO] running `Command { std: "docker" "start" "-a" "67ce9a0a54e745bd19d54aa8c46e8d9a9d0a97f0a4918d2f6cbf4cd6faf31d44", kill_on_drop: false }`
[INFO] [stderr] warning: profiles for the non root package will be ignored, specify profiles at the workspace root:
[INFO] [stderr] package:   /opt/rustwide/workdir/exercises/02_basic_calculator/08_overflow/Cargo.toml
[INFO] [stderr] workspace: /opt/rustwide/workdir/Cargo.toml
[INFO] [stderr]    Compiling proc-macro2 v1.0.82
[INFO] [stderr]    Compiling unicode-ident v1.0.12
[INFO] [stderr]     Checking common v0.1.0 (/opt/rustwide/workdir/helpers/common)
[INFO] [stderr]    Compiling thiserror v1.0.60
[INFO] [stderr]    Compiling libc v0.2.154
[INFO] [stderr]    Compiling autocfg v1.3.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]     Checking cfg-if v1.0.0
[INFO] [stderr]     Checking smallvec v1.13.2
[INFO] [stderr]     Checking scopeguard v1.2.0
[INFO] [stderr]     Checking bytes v1.6.0
[INFO] [stderr]     Checking pin-project-lite v0.2.14
[INFO] [stderr]    Compiling anyhow v1.0.83
[INFO] [stderr]     Checking packages v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/10_packages)
[INFO] [stderr]     Checking outro_02 v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/12_outro)
[INFO] [stderr]     Checking static_assertions v1.1.0
[INFO] [stderr]     Checking outro_03 v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/13_outro)
[INFO] [stderr]     Checking validation v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/02_validation)
[INFO] [stderr]     Checking error_trait v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/09_error_trait)
[INFO] [stderr]     Checking fallibility v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/06_fallibility)
[INFO] [stderr]     Checking enum_ v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/01_enum)
[INFO] [stdout] warning: fields `title`, `description`, and `status` are never read
[INFO] [stdout]  --> exercises/03_ticket_v1/02_validation/src/lib.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | struct Ticket {
[INFO] [stdout]   |        ------ fields in this struct
[INFO] [stdout] 2 |     title: String,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 3 |     description: String,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 4 |     status: String,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking setters v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/07_setters)
[INFO] [stdout] warning: associated items `new`, `title`, `description`, and `status` are never used
[INFO] [stdout]   --> exercises/05_ticket_v2/01_enum/src/lib.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl Ticket {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 21 |     pub fn new(title: String, description: String, status: Status) -> Ticket {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn title(&self) -> &String {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn description(&self) -> &String {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn status(&self) -> &Status {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking error_enums v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/08_error_enums)
[INFO] [stdout] warning: variants `InProgress` and `Done` are never constructed
[INFO] [stdout]   --> exercises/05_ticket_v2/06_fallibility/src/lib.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | enum Status {
[INFO] [stdout]    |      ------ variants in this enum
[INFO] [stdout] 13 |     ToDo,
[INFO] [stdout] 14 |     InProgress { assigned_to: String },
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 15 |     Done,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Status` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking nullability v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/05_nullability)
[INFO] [stderr]     Checking unwrap v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/07_unwrap)
[INFO] [stderr]     Checking variants_with_data v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/03_variants_with_data)
[INFO] [stderr]     Checking str_slice v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/05_str_slice)
[INFO] [stderr]     Checking factorial v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/05_factorial)
[INFO] [stdout] warning: unused variable: `msg`
[INFO] [stdout]   --> exercises/05_ticket_v2/09_error_trait/src/lib.rs:44:46
[INFO] [stdout]    |
[INFO] [stdout] 44 |         Err(TicketNewError::DescriptionError(msg)) => {
[INFO] [stdout]    |                                              ^^^ help: if this is intentional, prefix it with an underscore: `_msg`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `InProgress` and `Done` are never constructed
[INFO] [stdout]   --> exercises/05_ticket_v2/09_error_trait/src/lib.rs:60:5
[INFO] [stdout]    |
[INFO] [stdout] 58 | enum Status {
[INFO] [stdout]    |      ------ variants in this enum
[INFO] [stdout] 59 |     ToDo,
[INFO] [stdout] 60 |     InProgress { assigned_to: String },
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 61 |     Done,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Status` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking if_else v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/03_if_else)
[INFO] [stderr]     Checking derives v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/04_derive)
[INFO] [stdout] warning: unused variable: `msg`
[INFO] [stdout]   --> exercises/05_ticket_v2/08_error_enums/src/lib.rs:19:50
[INFO] [stdout]    |
[INFO] [stdout] 19 |                 TicketNewError::DescriptionErr { msg } => {
[INFO] [stdout]    |                                                  ^^^ help: try ignoring the field: `msg: _`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `InProgress` and `Done` are never constructed
[INFO] [stdout]   --> exercises/05_ticket_v2/08_error_enums/src/lib.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 38 | enum Status {
[INFO] [stdout]    |      ------ variants in this enum
[INFO] [stdout] 39 |     ToDo,
[INFO] [stdout] 40 |     InProgress { assigned_to: String },
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 41 |     Done,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Status` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking slice v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/10_slices)
[INFO] [stdout] warning: function `factorial` is never used
[INFO] [stdout]   --> exercises/02_basic_calculator/05_factorial/src/lib.rs:12:4
[INFO] [stdout]    |
[INFO] [stdout] 12 | fn factorial(n: u32) -> u32 {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking destructor v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/11_destructor)
[INFO] [stderr]     Checking intro_07 v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/00_intro)
[INFO] [stdout] warning: variants `InProgress` and `Done` are never constructed
[INFO] [stdout]   --> exercises/05_ticket_v2/07_unwrap/src/lib.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | enum Status {
[INFO] [stdout]    |      ------ variants in this enum
[INFO] [stdout] 31 |     ToDo,
[INFO] [stdout] 32 |     InProgress { assigned_to: String },
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 33 |     Done,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Status` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking stack v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/08_stack)
[INFO] [stderr]     Checking arrays v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/01_arrays)
[INFO] [stdout] warning: function `is_even` is never used
[INFO] [stdout]  --> exercises/02_basic_calculator/03_if_else/src/lib.rs:2:4
[INFO] [stdout]   |
[INFO] [stdout] 2 | fn is_even(n: u32) -> bool {
[INFO] [stdout]   |    ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]  --> exercises/05_ticket_v2/06_fallibility/src/lib.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | struct Ticket {
[INFO] [stdout]   |        ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Status` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/06_fallibility/src/lib.rs:12:6
[INFO] [stdout]    |
[INFO] [stdout] 12 | enum Status {
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking ownership v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/06_ownership)
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/06_fallibility/src/lib.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl Ticket {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 19 |     pub fn new(title: String, description: String, status: Status) -> Result<Ticket, String> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking assoc_vs_generic v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/09_assoc_vs_generic)
[INFO] [stdout] warning: function `intro` is never used
[INFO] [stdout]  --> exercises/07_threads/00_intro/src/lib.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn intro() -> &'static str {
[INFO] [stdout]   |    ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking clone v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/10_clone)
[INFO] [stderr]     Checking scoped_threads v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/04_scoped_threads)
[INFO] [stderr]     Checking struct_ v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/01_struct)
[INFO] [stderr]     Checking syntax v0.1.0 (/opt/rustwide/workdir/exercises/01_intro/01_syntax)
[INFO] [stderr]     Checking interior_mutability v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/06_interior_mutability)
[INFO] [stderr]     Checking heap v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/09_heap)
[INFO] [stderr]     Checking vec v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/02_vec)
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]  --> exercises/05_ticket_v2/05_nullability/src/lib.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | struct Ticket {
[INFO] [stdout]   |        ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Status` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/05_nullability/src/lib.rs:11:6
[INFO] [stdout]    |
[INFO] [stdout] 11 | enum Status {
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `assigned_to` are never used
[INFO] [stdout]   --> exercises/05_ticket_v2/05_nullability/src/lib.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl Ticket {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 18 |     pub fn new(title: String, description: String, status: Status) -> Ticket {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn assigned_to(&self) -> Option<&String> {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking encapsulation v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/05_encapsulation)
[INFO] [stdout] warning: function `compute` is never used
[INFO] [stdout]  --> exercises/01_intro/01_syntax/src/lib.rs:6:4
[INFO] [stdout]   |
[INFO] [stdout] 6 | fn compute(a: u32, b: u32) -> u32 {
[INFO] [stdout]   |    ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Order` is never constructed
[INFO] [stdout]  --> exercises/03_ticket_v1/01_struct/src/lib.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | struct Order {
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `is_available` and `associated_func` are never used
[INFO] [stdout]   --> exercises/03_ticket_v1/01_struct/src/lib.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl Order {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 13 |     fn is_available(self) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 17 |     fn associated_func() -> () {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking integers v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/01_integers)
[INFO] [stdout] warning: struct `FibNumbers` is never constructed
[INFO] [stdout]   --> exercises/06_ticket_management/02_vec/src/lib.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | struct FibNumbers {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `title`, `description`, and `status` are never read
[INFO] [stdout]  --> exercises/03_ticket_v1/09_heap/src/lib.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct Ticket {
[INFO] [stdout]   |            ------ fields in this struct
[INFO] [stdout] 2 |     title: String,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 3 |     description: String,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 4 |     status: String,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking for_ v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/07_for)
[INFO] [stderr]     Checking if_let v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/04_if_let)
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> exercises/07_threads/06_interior_mutability/src/lib.rs:40:17
[INFO] [stdout]    |
[INFO] [stdout] 40 |             let a = DropTracker::new(5, Rc::clone(&counter));
[INFO] [stdout]    |                 ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]   --> exercises/07_threads/06_interior_mutability/src/lib.rs:41:17
[INFO] [stdout]    |
[INFO] [stdout] 41 |             let b = DropTracker::new(6, Rc::clone(&counter));
[INFO] [stdout]    |                 ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]  --> exercises/03_ticket_v1/02_validation/src/lib.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | struct Ticket {
[INFO] [stdout]   |        ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> exercises/03_ticket_v1/02_validation/src/lib.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 7  | impl Ticket {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 19 |     fn new(title: String, description: String, status: String) -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]  --> exercises/07_threads/06_interior_mutability/src/lib.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct DropTracker<T> {
[INFO] [stdout]   |            ----------- field in this struct
[INFO] [stdout] 8 |     value: T,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking intro_05 v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/00_intro)
[INFO] [stderr]     Checking overloading v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/03_operator_overloading)
[INFO] [stderr]     Checking modules v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/03_modules)
[INFO] [stdout] warning: function `compute` is never used
[INFO] [stdout]  --> exercises/02_basic_calculator/01_integers/src/lib.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn compute(a: u32, b: u32) -> u32 {
[INFO] [stdout]   |    ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]  --> exercises/05_ticket_v2/03_variants_with_data/src/lib.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | struct Ticket {
[INFO] [stdout]   |        ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Status` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/03_variants_with_data/src/lib.rs:13:6
[INFO] [stdout]    |
[INFO] [stdout] 13 | enum Status {
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `assigned_to` are never used
[INFO] [stdout]   --> exercises/05_ticket_v2/03_variants_with_data/src/lib.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl Ticket {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 20 |     pub fn new(title: String, description: String, status: Status) -> Ticket {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub fn assigned_to(&self) -> &str {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `title`, `description`, and `status` are never read
[INFO] [stdout]  --> exercises/03_ticket_v1/09_heap/src/lib.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct Ticket {
[INFO] [stdout]   |            ------ fields in this struct
[INFO] [stdout] 2 |     title: String,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 3 |     description: String,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 4 |     status: String,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking panics v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/04_panics)
[INFO] [stderr]     Checking intro_08 v0.1.0 (/opt/rustwide/workdir/exercises/08_futures/00_intro)
[INFO] [stdout] warning: function `easy_ticket` is never used
[INFO] [stdout]  --> exercises/05_ticket_v2/07_unwrap/src/lib.rs:5:4
[INFO] [stdout]   |
[INFO] [stdout] 5 | fn easy_ticket(title: String, description: String, status: Status) -> Ticket {
[INFO] [stdout]   |    ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]   --> exercises/05_ticket_v2/07_unwrap/src/lib.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | struct Ticket {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Status` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/07_unwrap/src/lib.rs:30:6
[INFO] [stdout]    |
[INFO] [stdout] 30 | enum Status {
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/07_unwrap/src/lib.rs:37:12
[INFO] [stdout]    |
[INFO] [stdout] 36 | impl Ticket {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 37 |     pub fn new(title: String, description: String, status: Status) -> Result<Ticket, String> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `border` is never read
[INFO] [stdout]  --> exercises/05_ticket_v2/04_if_let/src/lib.rs:3:14
[INFO] [stdout]   |
[INFO] [stdout] 3 |     Square { border: f64 },
[INFO] [stdout]   |     ------   ^^^^^^
[INFO] [stdout]   |     |
[INFO] [stdout]   |     field in this variant
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `width` and `height` are never read
[INFO] [stdout]  --> exercises/05_ticket_v2/04_if_let/src/lib.rs:4:17
[INFO] [stdout]   |
[INFO] [stdout] 4 |     Rectangle { width: f64, height: f64 },
[INFO] [stdout]   |     ---------   ^^^^^       ^^^^^^
[INFO] [stdout]   |     |
[INFO] [stdout]   |     fields in this variant
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking static v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/02_static)
[INFO] [stderr]     Checking match_ v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/02_match)
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]     Checking leaking v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/03_leak)
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]   --> exercises/03_ticket_v1/03_modules/src/lib.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | struct Ticket {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> exercises/03_ticket_v1/03_modules/src/lib.rs:18:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl Ticket {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 18 |     fn new(title: String, description: String, status: String) -> Ticket {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_todo_ticket` is never used
[INFO] [stdout]  --> exercises/03_ticket_v1/03_modules/src/lib.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 |     fn create_todo_ticket(title: String, description: String) -> Ticket {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking overflow v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/08_overflow)
[INFO] [stderr]     Checking mut_slice v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/11_mutable_slices)
[INFO] [stderr]     Checking deref v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/06_deref)
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]   --> exercises/04_traits/04_derive/src/lib.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | struct Ticket {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `lowercase` is never used
[INFO] [stdout]  --> exercises/06_ticket_management/11_mutable_slices/src/lib.rs:5:4
[INFO] [stdout]   |
[INFO] [stdout] 5 | fn lowercase(string: &mut str) {
[INFO] [stdout]   |    ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking intro_04 v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/00_intro)
[INFO] [stderr]     Checking visibility v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/04_visibility)
[INFO] [stderr]     Checking while_ v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/06_while)
[INFO] [stderr]     Checking saturating v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/09_saturating)
[INFO] [stderr]     Checking sized v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/07_sized)
[INFO] [stdout] warning: field `status` is never read
[INFO] [stdout]   --> exercises/04_traits/06_deref/src/lib.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 7  | pub struct Ticket {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 10 |     status: String,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]  --> exercises/07_threads/06_interior_mutability/src/lib.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct DropTracker<T> {
[INFO] [stdout]   |            ----------- field in this struct
[INFO] [stdout] 8 |     value: T,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking welcome_00 v0.1.0 (/opt/rustwide/workdir/exercises/01_intro/00_welcome)
[INFO] [stdout] warning: function `speed` is never used
[INFO] [stdout]  --> exercises/02_basic_calculator/04_panics/src/lib.rs:3:4
[INFO] [stdout]   |
[INFO] [stdout] 3 | fn speed(start: u32, end: u32, time_elapsed: u32) -> u32 {
[INFO] [stdout]   |    ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `intro` is never used
[INFO] [stdout]  --> exercises/05_ticket_v2/00_intro/src/lib.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn intro() -> &'static str {
[INFO] [stdout]   |    ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ticket`
[INFO] [stdout]   --> exercises/03_ticket_v1/04_visibility/src/lib.rs:47:13
[INFO] [stdout]    |
[INFO] [stdout] 47 |         let ticket = Ticket::new("A title".into(), "A description".into(), "To-Do".into());
[INFO] [stdout]    |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_ticket`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]  --> exercises/03_ticket_v1/04_visibility/src/lib.rs:2:16
[INFO] [stdout]   |
[INFO] [stdout] 2 |     pub struct Ticket {
[INFO] [stdout]   |                ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]  --> exercises/03_ticket_v1/04_visibility/src/lib.rs:9:16
[INFO] [stdout]   |
[INFO] [stdout] 8 |     impl Ticket {
[INFO] [stdout]   |     ----------- associated function in this implementation
[INFO] [stdout] 9 |         pub fn new(title: String, description: String, status: String) -> Ticket {
[INFO] [stdout]   |                ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `should_not_be_possible` is never used
[INFO] [stdout]   --> exercises/03_ticket_v1/04_visibility/src/lib.rs:46:8
[INFO] [stdout]    |
[INFO] [stdout] 46 |     fn should_not_be_possible() {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `encapsulation_cannot_be_violated` is never used
[INFO] [stdout]   --> exercises/03_ticket_v1/04_visibility/src/lib.rs:61:8
[INFO] [stdout]    |
[INFO] [stdout] 61 |     fn encapsulation_cannot_be_violated() {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking deps v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/11_dependencies)
[INFO] [stderr]     Checking orphan v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/02_orphan_rule)
[INFO] [stderr]     Checking copy v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/11_copy)
[INFO] [stdout] warning: field `status` is never read
[INFO] [stdout]   --> exercises/04_traits/06_deref/src/lib.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 7  | pub struct Ticket {
[INFO] [stdout]    |            ------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 10 |     status: String,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking resizing v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/03_resizing)
[INFO] [stderr]     Checking intro_02 v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/00_intro)
[INFO] [stdout] warning: function `greeting` is never used
[INFO] [stdout]   --> exercises/01_intro/00_welcome/src/lib.rs:18:4
[INFO] [stdout]    |
[INFO] [stdout] 18 | fn greeting() -> &'static str {
[INFO] [stdout]    |    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking intro_03 v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/00_intro)
[INFO] [stdout] warning: unused import: `anyhow::Error`
[INFO] [stdout]  --> exercises/05_ticket_v2/11_dependencies/src/lib.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use anyhow::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `anyhow::Error`
[INFO] [stdout]  --> exercises/05_ticket_v2/11_dependencies/src/lib.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use anyhow::Error;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking threads v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/01_threads)
[INFO] [stderr]     Checking from v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/08_from)
[INFO] [stdout] warning: function `intro` is never used
[INFO] [stdout]  --> exercises/08_futures/00_intro/src/lib.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn intro() -> &'static str {
[INFO] [stdout]   |    ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]  --> exercises/04_traits/03_operator_overloading/src/lib.rs:3:8
[INFO] [stdout]   |
[INFO] [stdout] 3 | struct Ticket {
[INFO] [stdout]   |        ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking sync v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/14_sync)
[INFO] [stdout] warning: function `intro` is never used
[INFO] [stdout]  --> exercises/03_ticket_v1/00_intro/src/lib.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn intro() -> &'static str {
[INFO] [stdout]   |    ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]   --> exercises/03_ticket_v1/03_modules/src/lib.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | struct Ticket {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> exercises/03_ticket_v1/03_modules/src/lib.rs:18:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl Ticket {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 18 |     fn new(title: String, description: String, status: String) -> Ticket {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_todo_ticket` is never used
[INFO] [stdout]  --> exercises/03_ticket_v1/03_modules/src/lib.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 |     fn create_todo_ticket(title: String, description: String) -> Ticket {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking trait_ v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/01_trait)
[INFO] [stdout] warning: unused variable: `msg`
[INFO] [stdout]   --> exercises/05_ticket_v2/08_error_enums/src/lib.rs:19:50
[INFO] [stdout]    |
[INFO] [stdout] 19 |                 TicketNewError::DescriptionErr { msg } => {
[INFO] [stdout]    |                                                  ^^^ help: try ignoring the field: `msg: _`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking variables v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/02_variables)
[INFO] [stdout] warning: enum `TicketNewError` is never used
[INFO] [stdout]  --> exercises/05_ticket_v2/08_error_enums/src/lib.rs:5:6
[INFO] [stdout]   |
[INFO] [stdout] 5 | enum TicketNewError {
[INFO] [stdout]   |      ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `easy_ticket` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/08_error_enums/src/lib.rs:14:4
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn easy_ticket(title: String, description: String, status: Status) -> Ticket {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]   --> exercises/05_ticket_v2/08_error_enums/src/lib.rs:31:8
[INFO] [stdout]    |
[INFO] [stdout] 31 | struct Ticket {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Status` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/08_error_enums/src/lib.rs:38:6
[INFO] [stdout]    |
[INFO] [stdout] 38 | enum Status {
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/08_error_enums/src/lib.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | impl Ticket {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 45 |     pub fn new(
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wrapping`
[INFO] [stdout]   --> exercises/04_traits/08_from/src/lib.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let wrapping: WrappingU32 = 42.into();
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_wrapping`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wrapping`
[INFO] [stdout]   --> exercises/04_traits/08_from/src/lib.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 |     let wrapping = WrappingU32::from(42);
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_wrapping`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]  --> exercises/04_traits/08_from/src/lib.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub struct WrappingU32 {
[INFO] [stdout]   |            ----------- field in this struct
[INFO] [stdout] 4 |     value: u32,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `example` is never used
[INFO] [stdout]   --> exercises/04_traits/08_from/src/lib.rs:15:4
[INFO] [stdout]    |
[INFO] [stdout] 15 | fn example() {
[INFO] [stdout]    |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `outro` is never used
[INFO] [stdout]  --> exercises/07_threads/14_sync/src/lib.rs:2:4
[INFO] [stdout]   |
[INFO] [stdout] 2 | fn outro() -> &'static str {
[INFO] [stdout]   |    ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking intro_01 v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/00_intro)
[INFO] [stdout] warning: enum `Shape` is never used
[INFO] [stdout]  --> exercises/05_ticket_v2/04_if_let/src/lib.rs:1:6
[INFO] [stdout]   |
[INFO] [stdout] 1 | enum Shape {
[INFO] [stdout]   |      ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `radius` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/04_if_let/src/lib.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 7  | impl Shape {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 10 |     pub fn radius(&self) -> f64 {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `price` is never read
[INFO] [stdout]  --> exercises/03_ticket_v1/01_struct/src/lib.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | struct Order {
[INFO] [stdout]   |        ----- field in this struct
[INFO] [stdout] 8 |     price: u16,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Shape` is never used
[INFO] [stdout]  --> exercises/05_ticket_v2/02_match/src/lib.rs:1:6
[INFO] [stdout]   |
[INFO] [stdout] 1 | enum Shape {
[INFO] [stdout]   |      ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `n_sides` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/02_match/src/lib.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 9  | impl Shape {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] 10 |     // TODO: Implement the `n_sides` method using a `match`.
[INFO] [stdout] 11 |     pub fn n_sides(&self) -> u8 {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking drop v0.1.0 (/opt/rustwide/workdir/exercises/04_traits/12_drop)
[INFO] [stdout] warning: function `intro` is never used
[INFO] [stdout]  --> exercises/06_ticket_management/00_intro/src/lib.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn intro() -> &'static str {
[INFO] [stdout]   |    ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `intro` is never used
[INFO] [stdout]  --> exercises/02_basic_calculator/00_intro/src/lib.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn intro() -> &'static str {
[INFO] [stdout]   |    ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking references_in_memory v0.1.0 (/opt/rustwide/workdir/exercises/03_ticket_v1/10_references_in_memory)
[INFO] [stdout] warning: struct `DropBomb` is never constructed
[INFO] [stdout]  --> exercises/04_traits/12_drop/src/lib.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | struct DropBomb {
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `defuse` are never used
[INFO] [stdout]   --> exercises/04_traits/12_drop/src/lib.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 9  | impl DropBomb {
[INFO] [stdout]    | ------------- associated items in this implementation
[INFO] [stdout] 10 |     fn new() -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     fn defuse(mut self) -> () {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]  --> exercises/03_ticket_v1/04_visibility/src/lib.rs:2:16
[INFO] [stdout]   |
[INFO] [stdout] 2 |     pub struct Ticket {
[INFO] [stdout]   |                ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]  --> exercises/03_ticket_v1/04_visibility/src/lib.rs:9:16
[INFO] [stdout]   |
[INFO] [stdout] 8 |     impl Ticket {
[INFO] [stdout]   |     ----------- associated function in this implementation
[INFO] [stdout] 9 |         pub fn new(title: String, description: String, status: String) -> Ticket {
[INFO] [stdout]   |                ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `outro` is never used
[INFO] [stdout]  --> exercises/03_ticket_v1/11_destructor/src/lib.rs:4:4
[INFO] [stdout]   |
[INFO] [stdout] 4 | fn outro() -> &'static str {
[INFO] [stdout]   |    ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]  --> exercises/05_ticket_v2/01_enum/src/lib.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | struct Ticket {
[INFO] [stdout]   |        ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sum` is never used
[INFO] [stdout]  --> exercises/06_ticket_management/10_slices/src/lib.rs:3:4
[INFO] [stdout]   |
[INFO] [stdout] 3 | fn sum(slice: &[u32]) -> u32 {
[INFO] [stdout]   |    ^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking as_cast v0.1.0 (/opt/rustwide/workdir/exercises/02_basic_calculator/10_as_casting)
[INFO] [stdout] warning: enum `Status` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/01_enum/src/lib.rs:14:6
[INFO] [stdout]    |
[INFO] [stdout] 14 | enum Status {
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `title`, `description`, and `status` are never used
[INFO] [stdout]   --> exercises/05_ticket_v2/01_enum/src/lib.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl Ticket {
[INFO] [stdout]    | ----------- associated items in this implementation
[INFO] [stdout] 21 |     pub fn new(title: String, description: String, status: Status) -> Ticket {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn title(&self) -> &String {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn description(&self) -> &String {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn status(&self) -> &Status {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `title`, `description`, and `status` are never read
[INFO] [stdout]  --> exercises/03_ticket_v1/10_references_in_memory/src/lib.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct Ticket {
[INFO] [stdout]   |            ------ fields in this struct
[INFO] [stdout] 2 |     title: String,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 3 |     description: String,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 4 |     status: String,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wrapping`
[INFO] [stdout]   --> exercises/04_traits/08_from/src/lib.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let wrapping: WrappingU32 = 42.into();
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_wrapping`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `wrapping`
[INFO] [stdout]   --> exercises/04_traits/08_from/src/lib.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 |     let wrapping = WrappingU32::from(42);
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_wrapping`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `value` is never read
[INFO] [stdout]  --> exercises/04_traits/08_from/src/lib.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub struct WrappingU32 {
[INFO] [stdout]   |            ----------- field in this struct
[INFO] [stdout] 4 |     value: u32,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `example` is never used
[INFO] [stdout]   --> exercises/04_traits/08_from/src/lib.rs:15:4
[INFO] [stdout]    |
[INFO] [stdout] 15 | fn example() {
[INFO] [stdout]    |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FibNumbers` is never constructed
[INFO] [stdout]   --> exercises/06_ticket_management/02_vec/src/lib.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | struct FibNumbers {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `intro` is never used
[INFO] [stdout]  --> exercises/04_traits/00_intro/src/lib.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn intro() -> &'static str {
[INFO] [stdout]   |    ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Power` is never used
[INFO] [stdout]   --> exercises/04_traits/09_assoc_vs_generic/src/lib.rs:15:7
[INFO] [stdout]    |
[INFO] [stdout] 15 | trait Power<T> {
[INFO] [stdout]    |       ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `bomb`
[INFO] [stdout]   --> exercises/04_traits/12_drop/src/lib.rs:36:13
[INFO] [stdout]    |
[INFO] [stdout] 36 |         let bomb = DropBomb::new();
[INFO] [stdout]    |             ^^^^ help: if this is intentional, prefix it with an underscore: `_bomb`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> exercises/04_traits/12_drop/src/lib.rs:42:13
[INFO] [stdout]    |
[INFO] [stdout] 42 |         let mut bomb = DropBomb::new();
[INFO] [stdout]    |             ----^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `msg`
[INFO] [stdout]   --> exercises/05_ticket_v2/09_error_trait/src/lib.rs:44:46
[INFO] [stdout]    |
[INFO] [stdout] 44 |         Err(TicketNewError::DescriptionError(msg)) => {
[INFO] [stdout]    |                                              ^^^ help: if this is intentional, prefix it with an underscore: `_msg`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `title`, `description`, and `status` are never read
[INFO] [stdout]  --> exercises/03_ticket_v1/10_references_in_memory/src/lib.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct Ticket {
[INFO] [stdout]   |            ------ fields in this struct
[INFO] [stdout] 2 |     title: String,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 3 |     description: String,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 4 |     status: String,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TicketNewError` is never used
[INFO] [stdout]  --> exercises/05_ticket_v2/09_error_trait/src/lib.rs:9:6
[INFO] [stdout]   |
[INFO] [stdout] 9 | enum TicketNewError {
[INFO] [stdout]   |      ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `easy_ticket` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/09_error_trait/src/lib.rs:40:4
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn easy_ticket(title: String, description: String, status: Status) -> Ticket {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]   --> exercises/05_ticket_v2/09_error_trait/src/lib.rs:51:8
[INFO] [stdout]    |
[INFO] [stdout] 51 | struct Ticket {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Status` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/09_error_trait/src/lib.rs:58:6
[INFO] [stdout]    |
[INFO] [stdout] 58 | enum Status {
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/09_error_trait/src/lib.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout] 64 | impl Ticket {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 65 |     pub fn new(
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling quote v1.0.36
[INFO] [stderr]    Compiling syn v2.0.63
[INFO] [stderr]     Checking signal-hook-registry v1.4.2
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking mio v0.8.11
[INFO] [stderr]     Checking socket2 v0.5.7
[INFO] [stderr]     Checking parking_lot v0.12.2
[INFO] [stderr]    Compiling thiserror-impl v1.0.60
[INFO] [stderr]    Compiling tokio-macros v2.2.0
[INFO] [stderr]     Checking tokio v1.37.0
[INFO] [stderr]     Checking ticket_fields v0.1.0 (/opt/rustwide/workdir/helpers/ticket_fields)
[INFO] [stderr]     Checking outro_04 v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/15_outro)
[INFO] [stderr]     Checking thiserror_ v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/12_thiserror)
[INFO] [stderr]     Checking tryfrom v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/13_try_from)
[INFO] [stderr]     Checking source v0.1.0 (/opt/rustwide/workdir/exercises/05_ticket_v2/14_source)
[INFO] [stdout] warning: enum `TicketNewError` is never used
[INFO] [stdout]  --> exercises/05_ticket_v2/12_thiserror/src/lib.rs:9:6
[INFO] [stdout]   |
[INFO] [stdout] 9 | enum TicketNewError {
[INFO] [stdout]   |      ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ticket` is never constructed
[INFO] [stdout]   --> exercises/05_ticket_v2/12_thiserror/src/lib.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | struct Ticket {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Status` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/12_thiserror/src/lib.rs:29:6
[INFO] [stdout]    |
[INFO] [stdout] 29 | enum Status {
[INFO] [stdout]    |      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> exercises/05_ticket_v2/12_thiserror/src/lib.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 35 | impl Ticket {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] 36 |     pub fn new(
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `InProgress` and `Done` are never constructed
[INFO] [stdout]   --> exercises/05_ticket_v2/12_thiserror/src/lib.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 29 | enum Status {
[INFO] [stdout]    |      ------ variants in this enum
[INFO] [stdout] 30 |     ToDo,
[INFO] [stdout] 31 |     InProgress { assigned_to: String },
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 32 |     Done,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Status` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking locks v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/11_locks)
[INFO] [stderr]     Checking rwlock v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/12_rw_lock)
[INFO] [stderr]     Checking patch v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/10_patch)
[INFO] [stderr]     Checking response v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/07_ack)
[INFO] [stderr]     Checking client v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/08_client)
[INFO] [stderr]     Checking without_channels v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/13_without_channels)
[INFO] [stderr]     Checking bounded v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/09_bounded)
[INFO] [stderr]     Checking channels v0.1.0 (/opt/rustwide/workdir/exercises/07_threads/05_channels)
[INFO] [stderr]     Checking two_states v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/12_two_states)
[INFO] [stdout] warning: field `invalid_status` is never read
[INFO] [stdout]   --> exercises/05_ticket_v2/15_outro/src/status.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct ParsingError {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 17 |     invalid_status: String
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParsingError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking index v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/13_index)
[INFO] [stderr]     Checking hashmap v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/15_hashmap)
[INFO] [stdout] warning: field `invalid_status` is never read
[INFO] [stdout]   --> exercises/05_ticket_v2/15_outro/src/status.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct ParsingError {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 17 |     invalid_status: String
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParsingError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TrySendError`
[INFO] [stdout]  --> exercises/07_threads/11_locks/src/lib.rs:4:59
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::mpsc::{sync_channel, Receiver, SyncSender, TrySendError};
[INFO] [stdout]   |                                                           ^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Status` is never used
[INFO] [stdout]  --> exercises/05_ticket_v2/13_try_from/src/lib.rs:7:6
[INFO] [stdout]   |
[INFO] [stdout] 7 | enum Status {
[INFO] [stdout]   |      ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Command` is more private than the item `server`
[INFO] [stdout]   --> exercises/07_threads/08_client/src/lib.rs:52:1
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn server(receiver: Receiver<Command>) {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ function `server` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `Command` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> exercises/07_threads/08_client/src/lib.rs:41:1
[INFO] [stdout]    |
[INFO] [stdout] 41 | enum Command {
[INFO] [stdout]    | ^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Command` is more private than the item `server`
[INFO] [stdout]   --> exercises/07_threads/11_locks/src/lib.rs:63:1
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub fn server(receiver: Receiver<Command>) {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ function `server` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `Command` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> exercises/07_threads/11_locks/src/lib.rs:52:1
[INFO] [stdout]    |
[INFO] [stdout] 52 | enum Command {
[INFO] [stdout]    | ^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking index_mut v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/14_index_mut)
[INFO] [stdout] warning: unused import: `Sender`
[INFO] [stdout]  --> exercises/07_threads/09_bounded/src/lib.rs:4:58
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::mpsc::{sync_channel, Receiver, RecvError, Sender, SyncSender};
[INFO] [stdout]   |                                                          ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking iterators v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/04_iterators)
[INFO] [stderr]     Checking iter v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/05_iter)
[INFO] [stdout] warning: unused import: `TrySendError`
[INFO] [stdout]  --> exercises/07_threads/12_rw_lock/src/lib.rs:3:59
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::sync::mpsc::{sync_channel, Receiver, SyncSender, TrySendError};
[INFO] [stdout]   |                                                           ^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]  --> exercises/07_threads/12_rw_lock/src/store.rs:3:22
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::sync::{Arc, Mutex, RwLock};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Command` is more private than the item `server`
[INFO] [stdout]   --> exercises/07_threads/09_bounded/src/lib.rs:49:1
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub fn server(receiver: Receiver<Command>) {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ function `server` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `Command` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> exercises/07_threads/09_bounded/src/lib.rs:38:1
[INFO] [stdout]    |
[INFO] [stdout] 38 | enum Command {
[INFO] [stdout]    | ^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking combinators v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/07_combinators)
[INFO] [stdout] warning: unused variable: `ticket2`
[INFO] [stdout]    --> exercises/06_ticket_management/13_index/src/lib.rs:103:13
[INFO] [stdout]     |
[INFO] [stdout] 103 |         let ticket2 = &store[&id2];
[INFO] [stdout]     |             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ticket2`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TrySendError`
[INFO] [stdout]  --> exercises/07_threads/11_locks/src/lib.rs:4:59
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::mpsc::{sync_channel, Receiver, SyncSender, TrySendError};
[INFO] [stdout]   |                                                           ^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]   --> exercises/06_ticket_management/05_iter/src/lib.rs:41:17
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn iter(&self) -> std::slice::Iter<Ticket> {
[INFO] [stdout]    |                 ^^^^^     ------------------------ the lifetime gets resolved as `'_`
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 this lifetime flows to the output
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn iter(&self) -> std::slice::Iter<'_, Ticket> {
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking lifetime v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/06_lifetimes)
[INFO] [stderr]     Checking impl_trait v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/08_impl_trait)
[INFO] [stderr]     Checking btreemap v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/16_btreemap)
[INFO] [stderr]     Checking impl_trait_2 v0.1.0 (/opt/rustwide/workdir/exercises/06_ticket_management/09_impl_trait_2)
[INFO] [stdout] warning: type `Command` is more private than the item `server`
[INFO] [stdout]   --> exercises/07_threads/11_locks/src/lib.rs:63:1
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub fn server(receiver: Receiver<Command>) {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ function `server` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `Command` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> exercises/07_threads/11_locks/src/lib.rs:52:1
[INFO] [stdout]    |
[INFO] [stdout] 52 | enum Command {
[INFO] [stdout]    | ^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/07_threads/07_ack/src/lib.rs:34:17
[INFO] [stdout]    |
[INFO] [stdout] 34 |                 response_sender.send(id);
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 34 |                 let _ = response_sender.send(id);
[INFO] [stdout]    |                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/07_threads/07_ack/src/lib.rs:46:17
[INFO] [stdout]    |
[INFO] [stdout] 46 |                 response_sender.send(store.get(id).cloned());
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 46 |                 let _ = response_sender.send(store.get(id).cloned());
[INFO] [stdout]    |                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Command` is more private than the item `server`
[INFO] [stdout]   --> exercises/07_threads/12_rw_lock/src/lib.rs:62:1
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub fn server(receiver: Receiver<Command>) {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ function `server` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `Command` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> exercises/07_threads/12_rw_lock/src/lib.rs:51:1
[INFO] [stdout]    |
[INFO] [stdout] 51 | enum Command {
[INFO] [stdout]    | ^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Command` is more private than the item `server`
[INFO] [stdout]   --> exercises/07_threads/10_patch/src/lib.rs:74:1
[INFO] [stdout]    |
[INFO] [stdout] 74 | pub fn server(receiver: Receiver<Command>) {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ function `server` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `Command` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> exercises/07_threads/10_patch/src/lib.rs:59:1
[INFO] [stdout]    |
[INFO] [stdout] 59 | enum Command {
[INFO] [stdout]    | ^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TrySendError`
[INFO] [stdout]  --> exercises/07_threads/12_rw_lock/src/lib.rs:3:59
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::sync::mpsc::{sync_channel, Receiver, SyncSender, TrySendError};
[INFO] [stdout]   |                                                           ^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]  --> exercises/07_threads/12_rw_lock/src/store.rs:3:22
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::sync::{Arc, Mutex, RwLock};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ticket2`
[INFO] [stdout]   --> exercises/06_ticket_management/12_two_states/src/lib.rs:88:13
[INFO] [stdout]    |
[INFO] [stdout] 88 |         let ticket2 = store.get(id2).unwrap();
[INFO] [stdout]    |             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ticket2`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Command` is more private than the item `server`
[INFO] [stdout]   --> exercises/07_threads/12_rw_lock/src/lib.rs:62:1
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub fn server(receiver: Receiver<Command>) {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ function `server` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `Command` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> exercises/07_threads/12_rw_lock/src/lib.rs:51:1
[INFO] [stdout]    |
[INFO] [stdout] 51 | enum Command {
[INFO] [stdout]    | ^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> exercises/06_ticket_management/16_btreemap/src/lib.rs:121:13
[INFO] [stdout]     |
[INFO] [stdout] 121 |         for i in 0..n_tickets {
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Sender`
[INFO] [stdout]  --> exercises/07_threads/09_bounded/src/lib.rs:4:58
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::mpsc::{sync_channel, Receiver, RecvError, Sender, SyncSender};
[INFO] [stdout]   |                                                          ^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing
[INFO] [stdout]   --> exercises/06_ticket_management/05_iter/src/lib.rs:41:17
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn iter(&self) -> std::slice::Iter<Ticket> {
[INFO] [stdout]    |                 ^^^^^     ------------------------ the lifetime gets resolved as `'_`
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 this lifetime flows to the output
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths
[INFO] [stdout]    |
[INFO] [stdout] 41 |     pub fn iter(&self) -> std::slice::Iter<'_, Ticket> {
[INFO] [stdout]    |                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/07_threads/07_ack/src/lib.rs:34:17
[INFO] [stdout]    |
[INFO] [stdout] 34 |                 response_sender.send(id);
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 34 |                 let _ = response_sender.send(id);
[INFO] [stdout]    |                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/07_threads/07_ack/src/lib.rs:46:17
[INFO] [stdout]    |
[INFO] [stdout] 46 |                 response_sender.send(store.get(id).cloned());
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 46 |                 let _ = response_sender.send(store.get(id).cloned());
[INFO] [stdout]    |                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Command` is more private than the item `server`
[INFO] [stdout]   --> exercises/07_threads/10_patch/src/lib.rs:74:1
[INFO] [stdout]    |
[INFO] [stdout] 74 | pub fn server(receiver: Receiver<Command>) {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ function `server` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `Command` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> exercises/07_threads/10_patch/src/lib.rs:59:1
[INFO] [stdout]    |
[INFO] [stdout] 59 | enum Command {
[INFO] [stdout]    | ^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Command` is more private than the item `server`
[INFO] [stdout]   --> exercises/07_threads/09_bounded/src/lib.rs:49:1
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub fn server(receiver: Receiver<Command>) {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ function `server` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `Command` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> exercises/07_threads/09_bounded/src/lib.rs:38:1
[INFO] [stdout]    |
[INFO] [stdout] 38 | enum Command {
[INFO] [stdout]    | ^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Command` is more private than the item `server`
[INFO] [stdout]   --> exercises/07_threads/08_client/src/lib.rs:52:1
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn server(receiver: Receiver<Command>) {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ function `server` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `Command` is only usable at visibility `pub(crate)`
[INFO] [stdout]   --> exercises/07_threads/08_client/src/lib.rs:41:1
[INFO] [stdout]    |
[INFO] [stdout] 41 | enum Command {
[INFO] [stdout]    | ^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking async_fn v0.1.0 (/opt/rustwide/workdir/exercises/08_futures/01_async_fn)
[INFO] [stderr]     Checking blocking v0.1.0 (/opt/rustwide/workdir/exercises/08_futures/05_blocking)
[INFO] [stderr]     Checking cancellation v0.1.0 (/opt/rustwide/workdir/exercises/08_futures/07_cancellation)
[INFO] [stderr]     Checking future v0.1.0 (/opt/rustwide/workdir/exercises/08_futures/04_future)
[INFO] [stderr]     Checking spawn v0.1.0 (/opt/rustwide/workdir/exercises/08_futures/02_spawn)
[INFO] [stderr]     Checking outro_08 v0.1.0 (/opt/rustwide/workdir/exercises/08_futures/08_outro)
[INFO] [stderr]     Checking runtime v0.1.0 (/opt/rustwide/workdir/exercises/08_futures/03_runtime)
[INFO] [stderr]     Checking async_locks v0.1.0 (/opt/rustwide/workdir/exercises/08_futures/06_async_aware_primitives)
[INFO] [stdout] warning: unused imports: `AsyncReadExt` and `AsyncWriteExt`
[INFO] [stdout]  --> exercises/08_futures/01_async_fn/src/lib.rs:1:18
[INFO] [stdout]   |
[INFO] [stdout] 1 | use tokio::{io::{AsyncReadExt, AsyncWriteExt}, net::TcpListener};
[INFO] [stdout]   |                  ^^^^^^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AsyncReadExt` and `AsyncWriteExt`
[INFO] [stdout]  --> exercises/08_futures/01_async_fn/src/lib.rs:1:18
[INFO] [stdout]   |
[INFO] [stdout] 1 | use tokio::{io::{AsyncReadExt, AsyncWriteExt}, net::TcpListener};
[INFO] [stdout]   |                  ^^^^^^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `socket_addr`
[INFO] [stdout]   --> exercises/08_futures/01_async_fn/src/lib.rs:15:30
[INFO] [stdout]    |
[INFO] [stdout] 15 |         let (mut tcp_stream, socket_addr) = listener.accept().await?;
[INFO] [stdout]    |                              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_socket_addr`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `spawner` is never used
[INFO] [stdout]  --> exercises/08_futures/04_future/src/lib.rs:8:4
[INFO] [stdout]   |
[INFO] [stdout] 8 | fn spawner() {
[INFO] [stdout]   |    ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `example` is never used
[INFO] [stdout]   --> exercises/08_futures/04_future/src/lib.rs:12:10
[INFO] [stdout]    |
[INFO] [stdout] 12 | async fn example() {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `socket_addr`
[INFO] [stdout]   --> exercises/08_futures/01_async_fn/src/lib.rs:15:30
[INFO] [stdout]    |
[INFO] [stdout] 15 |         let (mut tcp_stream, socket_addr) = listener.accept().await?;
[INFO] [stdout]    |                              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_socket_addr`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Pointer` and `panic`
[INFO] [stdout]  --> exercises/08_futures/03_runtime/src/lib.rs:4:26
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::{fmt::{Display, Pointer}, panic};
[INFO] [stdout]   |                          ^^^^^^^   ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]  --> exercises/08_futures/03_runtime/src/lib.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::sync::{Arc, Mutex};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `spawner` is never used
[INFO] [stdout]  --> exercises/08_futures/04_future/src/lib.rs:8:4
[INFO] [stdout]   |
[INFO] [stdout] 8 | fn spawner() {
[INFO] [stdout]   |    ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `example` is never used
[INFO] [stdout]   --> exercises/08_futures/04_future/src/lib.rs:12:10
[INFO] [stdout]    |
[INFO] [stdout] 12 | async fn example() {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `addr`
[INFO] [stdout]   --> exercises/08_futures/03_runtime/src/lib.rs:16:26
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let (mut socket, addr) = listener.accept().await.unwrap();
[INFO] [stdout]    |                          ^^^^ help: if this is intentional, prefix it with an underscore: `_addr`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/06_async_aware_primitives/src/lib.rs:24:13
[INFO] [stdout]    |
[INFO] [stdout] 24 | /             msg.response_channel
[INFO] [stdout] 25 | |                 .send(Message {
[INFO] [stdout] 26 | |                     payload: "pong".into(),
[INFO] [stdout] 27 | |                     response_channel: sender,
[INFO] [stdout] 28 | |                 }).await;
[INFO] [stdout]    | |________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 24 |             let _ = msg.response_channel
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Pointer` and `panic`
[INFO] [stdout]  --> exercises/08_futures/03_runtime/src/lib.rs:4:26
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::{fmt::{Display, Pointer}, panic};
[INFO] [stdout]   |                          ^^^^^^^   ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]  --> exercises/08_futures/03_runtime/src/lib.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::sync::{Arc, Mutex};
[INFO] [stdout]   |                      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `addr`
[INFO] [stdout]   --> exercises/08_futures/03_runtime/src/lib.rs:16:26
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let (mut socket, addr) = listener.accept().await.unwrap();
[INFO] [stdout]    |                          ^^^^ help: if this is intentional, prefix it with an underscore: `_addr`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/02_spawn/src/lib.rs:13:13
[INFO] [stdout]    |
[INFO] [stdout] 13 |             tokio::io::copy(&mut reader, &mut writer).await;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 13 |             let _ = tokio::io::copy(&mut reader, &mut writer).await;
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/02_spawn/src/lib.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     handle1.await;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 28 |     let _ = handle1.await;
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/02_spawn/src/lib.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     handle2.await;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let _ = handle2.await;
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/03_runtime/src/lib.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     handle1.await;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let _ = handle1.await;
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/03_runtime/src/lib.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     handle2.await;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 37 |     let _ = handle2.await;
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/06_async_aware_primitives/src/lib.rs:24:13
[INFO] [stdout]    |
[INFO] [stdout] 24 | /             msg.response_channel
[INFO] [stdout] 25 | |                 .send(Message {
[INFO] [stdout] 26 | |                     payload: "pong".into(),
[INFO] [stdout] 27 | |                     response_channel: sender,
[INFO] [stdout] 28 | |                 }).await;
[INFO] [stdout]    | |________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 24 |             let _ = msg.response_channel
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/06_async_aware_primitives/src/lib.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 45 | /         sender
[INFO] [stdout] 46 | |             .send(Message {
[INFO] [stdout] 47 | |                 payload: "pong".into(),
[INFO] [stdout] 48 | |                 response_channel: response_sender,
[INFO] [stdout] 49 | |             }).await;
[INFO] [stdout]    | |____________________^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 45 |         let _ = sender
[INFO] [stdout]    |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/02_spawn/src/lib.rs:13:13
[INFO] [stdout]    |
[INFO] [stdout] 13 |             tokio::io::copy(&mut reader, &mut writer).await;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 13 |             let _ = tokio::io::copy(&mut reader, &mut writer).await;
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/02_spawn/src/lib.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     handle1.await;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 28 |     let _ = handle1.await;
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/02_spawn/src/lib.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     handle2.await;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let _ = handle2.await;
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/03_runtime/src/lib.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     handle1.await;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let _ = handle1.await;
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> exercises/08_futures/03_runtime/src/lib.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     handle2.await;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 37 |     let _ = handle2.await;
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 8.82s
[INFO] running `Command { std: "docker" "inspect" "67ce9a0a54e745bd19d54aa8c46e8d9a9d0a97f0a4918d2f6cbf4cd6faf31d44", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "67ce9a0a54e745bd19d54aa8c46e8d9a9d0a97f0a4918d2f6cbf4cd6faf31d44", kill_on_drop: false }`
[INFO] [stdout] 67ce9a0a54e745bd19d54aa8c46e8d9a9d0a97f0a4918d2f6cbf4cd6faf31d44
