[INFO] cloning repository https://github.com/OrtheSnowJames/RustSandbox
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/OrtheSnowJames/RustSandbox" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FOrtheSnowJames%2FRustSandbox", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FOrtheSnowJames%2FRustSandbox'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 7aab3d7362233af3bd815f43ea23cb11397b74b4
[INFO] testing OrtheSnowJames/RustSandbox against master#ec6f9a5b4413f74386267ef8efc93712c2ce6db6 for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FOrtheSnowJames%2FRustSandbox" "/workspace/builds/worker-5-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/OrtheSnowJames/RustSandbox
[INFO] finished tweaking git repo https://github.com/OrtheSnowJames/RustSandbox
[INFO] tweaked toml for git repo https://github.com/OrtheSnowJames/RustSandbox written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/OrtheSnowJames/RustSandbox on toolchain ec6f9a5b4413f74386267ef8efc93712c2ce6db6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/OrtheSnowJames/RustSandbox 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" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded windows-targets v0.52.6
[INFO] [stderr]   Downloaded objc_id v0.1.1
[INFO] [stderr]   Downloaded thiserror v1.0.69
[INFO] [stderr]   Downloaded raw-window-handle v0.5.2
[INFO] [stderr]   Downloaded thiserror-impl v1.0.69
[INFO] [stderr]   Downloaded objc v0.2.7
[INFO] [stderr]   Downloaded foreign-types-shared v0.3.1
[INFO] [stderr]   Downloaded get_if_addrs-sys v0.1.1
[INFO] [stderr]   Downloaded c_linked_list v1.1.1
[INFO] [stderr]   Downloaded get_if_addrs v0.5.3
[INFO] [stderr]   Downloaded core-foundation v0.9.4
[INFO] [stderr]   Downloaded mopa v0.2.2
[INFO] [stderr]   Downloaded windows-interface v0.58.0
[INFO] [stderr]   Downloaded shrev v1.1.3
[INFO] [stderr]   Downloaded core-graphics-types v0.1.3
[INFO] [stderr]   Downloaded async-task v4.7.1
[INFO] [stderr]   Downloaded windows-result v0.2.0
[INFO] [stderr]   Downloaded async-io v2.4.0
[INFO] [stderr]   Downloaded libredox v0.1.3
[INFO] [stderr]   Downloaded foreign-types-macros v0.2.3
[INFO] [stderr]   Downloaded ascii v1.1.0
[INFO] [stderr]   Downloaded dirs-sys-next v0.1.2
[INFO] [stderr]   Downloaded redox_users v0.4.6
[INFO] [stderr]   Downloaded itoa v1.0.14
[INFO] [stderr]   Downloaded cfg-if v1.0.0
[INFO] [stderr]   Downloaded wasi v0.11.0+wasi-snapshot-preview1
[INFO] [stderr]   Downloaded gcc v0.3.55
[INFO] [stderr]   Downloaded adler2 v2.0.0
[INFO] [stderr]   Downloaded cocoa-foundation v0.1.2
[INFO] [stderr]   Downloaded rustc-demangle v0.1.24
[INFO] [stderr]   Downloaded tuple_utils v0.3.0
[INFO] [stderr]   Downloaded tynm v0.1.10
[INFO] [stderr]   Downloaded autocfg v1.4.0
[INFO] [stderr]   Downloaded ahash v0.3.8
[INFO] [stderr]   Downloaded piper v0.2.4
[INFO] [stderr]   Downloaded atomic-waker v1.1.2
[INFO] [stderr]   Downloaded objc-foundation v0.1.1
[INFO] [stderr]   Downloaded foreign-types v0.5.0
[INFO] [stderr]   Downloaded futures-core v0.3.31
[INFO] [stderr]   Downloaded fastrand v2.3.0
[INFO] [stderr]   Downloaded event-listener-strategy v0.5.3
[INFO] [stderr]   Downloaded async-channel v2.3.1
[INFO] [stderr]   Downloaded malloc_buf v0.0.6
[INFO] [stderr]   Downloaded wasm-bindgen-shared v0.2.99
[INFO] [stderr]   Downloaded pin-utils v0.1.0
[INFO] [stderr]   Downloaded parking v2.2.1
[INFO] [stderr]   Downloaded event-listener v2.5.3
[INFO] [stderr]   Downloaded wasm-bindgen-futures v0.4.49
[INFO] [stderr]   Downloaded specs-derive v0.4.1
[INFO] [stderr]   Downloaded async-global-executor v2.4.1
[INFO] [stderr]   Downloaded windows-strings v0.1.0
[INFO] [stderr]   Downloaded home v0.5.11
[INFO] [stderr]   Downloaded futures-io v0.3.31
[INFO] [stderr]   Downloaded async-attributes v1.1.2
[INFO] [stderr]   Downloaded crossbeam-queue v0.2.3
[INFO] [stderr]   Downloaded lazy_static v1.5.0
[INFO] [stderr]   Downloaded wasm-bindgen-macro v0.2.99
[INFO] [stderr]   Downloaded gloo-timers v0.3.0
[INFO] [stderr]   Downloaded dirs-next v2.0.0
[INFO] [stderr]   Downloaded bitflags v1.3.2
[INFO] [stderr]   Downloaded async-channel v1.9.0
[INFO] [stderr]   Downloaded lazycell v1.3.0
[INFO] [stderr]   Downloaded block v0.1.6
[INFO] [stderr]   Downloaded scopeguard v1.2.0
[INFO] [stderr]   Downloaded getrandom v0.2.15
[INFO] [stderr]   Downloaded maybe-uninit v2.0.0
[INFO] [stderr]   Downloaded cfg-if v0.1.10
[INFO] [stderr]   Downloaded which v4.4.2
[INFO] [stderr]   Downloaded wfd v0.1.7
[INFO] [stderr]   Downloaded addr2line v0.24.2
[INFO] [stderr]   Downloaded wasm-bindgen-macro-support v0.2.99
[INFO] [stderr]   Downloaded wasm-bindgen-backend v0.2.99
[INFO] [stderr]   Downloaded kv-log-macro v1.0.7
[INFO] [stderr]   Downloaded futures-channel v0.3.31
[INFO] [stderr]   Downloaded concurrent-queue v2.5.0
[INFO] [stderr]   Downloaded hermit-abi v0.4.0
[INFO] [stderr]   Downloaded core-foundation-sys v0.8.7
[INFO] [stderr]   Downloaded core-graphics v0.23.2
[INFO] [stderr]   Downloaded blocking v1.6.1
[INFO] [stderr]   Downloaded async-executor v1.13.1
[INFO] [stderr]   Downloaded slab v0.4.9
[INFO] [stderr]   Downloaded futures-lite v2.5.0
[INFO] [stderr]   Downloaded crossbeam-utils v0.8.21
[INFO] [stderr]   Downloaded async-lock v3.4.0
[INFO] [stderr]   Downloaded event-listener v5.3.1
[INFO] [stderr]   Downloaded quote v1.0.37
[INFO] [stderr]   Downloaded cocoa v0.25.0
[INFO] [stderr]   Downloaded wasm-bindgen v0.2.99
[INFO] [stderr]   Downloaded tracing-core v0.1.33
[INFO] [stderr]   Downloaded polling v3.7.4
[INFO] [stderr]   Downloaded windows-implement v0.58.0
[INFO] [stderr]   Downloaded versions v5.0.1
[INFO] [stderr]   Downloaded rustc-hash v1.1.0
[INFO] [stderr]   Downloaded errno v0.3.10
[INFO] [stderr]   Downloaded js-sys v0.3.76
[INFO] [stderr]   Downloaded bumpalo v3.16.0
[INFO] [stderr]   Downloaded tracing v0.1.41
[INFO] [stderr]   Downloaded value-bag v1.10.0
[INFO] [stderr]   Downloaded async-std v1.13.0
[INFO] [stderr]   Downloaded log v0.4.22
[INFO] [stderr]   Downloaded arrayvec v0.5.2
[INFO] [stderr]   Downloaded hibitset v0.6.4
[INFO] [stderr]   Downloaded ryu v1.0.18
[INFO] [stderr]   Downloaded pin-project-lite v0.2.15
[INFO] [stderr]   Downloaded cexpr v0.6.0
[INFO] [stderr]   Downloaded parking_lot_core v0.9.10
[INFO] [stderr]   Downloaded glob v0.3.1
[INFO] [stderr]   Downloaded libloading v0.8.6
[INFO] [stderr]   Downloaded shlex v1.3.0
[INFO] [stderr]   Downloaded redox_syscall v0.5.8
[INFO] [stderr]   Downloaded lock_api v0.4.12
[INFO] [stderr]   Downloaded proc-macro2 v1.0.92
[INFO] [stderr]   Downloaded smallvec v1.13.2
[INFO] [stderr]   Downloaded cmake v0.1.52
[INFO] [stderr]   Downloaded winapi v0.2.8
[INFO] [stderr]   Downloaded unicode-ident v1.0.14
[INFO] [stderr]   Downloaded miniz_oxide v0.8.2
[INFO] [stderr]   Downloaded raylib_interactive v0.1.4
[INFO] [stderr]   Downloaded shred v0.10.2
[INFO] [stderr]   Downloaded web-sys v0.3.76
[INFO] [stderr]   Downloaded fs_extra v1.3.0
[INFO] [stderr]   Downloaded native-dialog v0.7.0
[INFO] [stderr]   Downloaded bitflags v2.6.0
[INFO] [stderr]   Downloaded once_cell v1.20.2
[INFO] [stderr]   Downloaded serde_derive v1.0.216
[INFO] [stderr]   Downloaded windows-core v0.58.0
[INFO] [stderr]   Downloaded crossbeam-utils v0.7.2
[INFO] [stderr]   Downloaded either v1.13.0
[INFO] [stderr]   Downloaded clang-sys v1.8.1
[INFO] [stderr]   Downloaded backtrace v0.3.74
[INFO] [stderr]   Downloaded parking_lot v0.12.3
[INFO] [stderr]   Downloaded prettyplease v0.2.25
[INFO] [stderr]   Downloaded serde v1.0.216
[INFO] [stderr]   Downloaded hashbrown v0.7.2
[INFO] [stderr]   Downloaded raylib v5.0.2
[INFO] [stderr]   Downloaded minimal-lexical v0.2.1
[INFO] [stderr]   Downloaded memchr v2.7.4
[INFO] [stderr]   Downloaded nom v7.1.3
[INFO] [stderr]   Downloaded cc v1.2.5
[INFO] [stderr]   Downloaded specs v0.16.1
[INFO] [stderr]   Downloaded itertools v0.11.0
[INFO] [stderr]   Downloaded serde_json v1.0.134
[INFO] [stderr]   Downloaded itertools v0.12.1
[INFO] [stderr]   Downloaded aho-corasick v1.1.3
[INFO] [stderr]   Downloaded syn v1.0.109
[INFO] [stderr]   Downloaded bindgen v0.69.5
[INFO] [stderr]   Downloaded gimli v0.31.1
[INFO] [stderr]   Downloaded regex v1.11.1
[INFO] [stderr]   Downloaded syn v2.0.91
[INFO] [stderr]   Downloaded object v0.36.7
[INFO] [stderr]   Downloaded windows_x86_64_gnullvm v0.52.6
[INFO] [stderr]   Downloaded rustix v0.38.42
[INFO] [stderr]   Downloaded regex-syntax v0.8.5
[INFO] [stderr]   Downloaded windows_aarch64_gnullvm v0.52.6
[INFO] [stderr]   Downloaded windows_i686_gnullvm v0.52.6
[INFO] [stderr]   Downloaded regex-automata v0.4.9
[INFO] [stderr]   Downloaded libc v0.2.169
[INFO] [stderr]   Downloaded windows_x86_64_msvc v0.52.6
[INFO] [stderr]   Downloaded windows_x86_64_gnu v0.52.6
[INFO] [stderr]   Downloaded tokio v1.42.0
[INFO] [stderr]   Downloaded windows_aarch64_msvc v0.52.6
[INFO] [stderr]   Downloaded windows_i686_gnu v0.52.6
[INFO] [stderr]   Downloaded windows_i686_msvc v0.52.6
[INFO] [stderr]   Downloaded winapi v0.3.9
[INFO] [stderr]   Downloaded linux-raw-sys v0.4.14
[INFO] [stderr]   Downloaded windows-sys v0.59.0
[INFO] [stderr]   Downloaded raylib-sys v5.0.2
[INFO] [stderr]   Downloaded winapi-x86_64-pc-windows-gnu v0.4.0
[INFO] [stderr]   Downloaded winapi-i686-pc-windows-gnu v0.4.0
[INFO] [stderr]   Downloaded windows v0.58.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 5026f477cf35872d678d55390fe2d3dd985650b8c3964026580e17a0b9ec5a68
[INFO] running `Command { std: "docker" "start" "-a" "5026f477cf35872d678d55390fe2d3dd985650b8c3964026580e17a0b9ec5a68", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "5026f477cf35872d678d55390fe2d3dd985650b8c3964026580e17a0b9ec5a68", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5026f477cf35872d678d55390fe2d3dd985650b8c3964026580e17a0b9ec5a68", kill_on_drop: false }`
[INFO] [stdout] 5026f477cf35872d678d55390fe2d3dd985650b8c3964026580e17a0b9ec5a68
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d9fd1921beca6d916c86b5b91cf18c62e92bd03573c65b43ce0a3b357f44e967
[INFO] running `Command { std: "docker" "start" "-a" "d9fd1921beca6d916c86b5b91cf18c62e92bd03573c65b43ce0a3b357f44e967", kill_on_drop: false }`
[INFO] [stderr]    Compiling autocfg v1.4.0
[INFO] [stderr]    Compiling cfg-if v1.0.0
[INFO] [stderr]    Compiling proc-macro2 v1.0.92
[INFO] [stderr]    Compiling unicode-ident v1.0.14
[INFO] [stderr]    Compiling bitflags v2.6.0
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling pin-project-lite v0.2.15
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling either v1.13.0
[INFO] [stderr]    Compiling parking v2.2.1
[INFO] [stderr]    Compiling libc v0.2.169
[INFO] [stderr]    Compiling memchr v2.7.4
[INFO] [stderr]    Compiling glob v0.3.1
[INFO] [stderr]    Compiling rustix v0.38.42
[INFO] [stderr]    Compiling lazy_static v1.5.0
[INFO] [stderr]    Compiling home v0.5.11
[INFO] [stderr]    Compiling prettyplease v0.2.25
[INFO] [stderr]    Compiling futures-core v0.3.31
[INFO] [stderr]    Compiling regex-syntax v0.8.5
[INFO] [stderr]    Compiling shlex v1.3.0
[INFO] [stderr]    Compiling linux-raw-sys v0.4.14
[INFO] [stderr]    Compiling libloading v0.8.6
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling futures-io v0.3.31
[INFO] [stderr]    Compiling bindgen v0.69.5
[INFO] [stderr]    Compiling hashbrown v0.7.2
[INFO] [stderr]    Compiling clang-sys v1.8.1
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling cc v1.2.5
[INFO] [stderr]    Compiling itertools v0.12.1
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling smallvec v1.13.2
[INFO] [stderr]    Compiling lazycell v1.3.0
[INFO] [stderr]    Compiling maybe-uninit v2.0.0
[INFO] [stderr]    Compiling concurrent-queue v2.5.0
[INFO] [stderr]    Compiling quote v1.0.37
[INFO] [stderr]    Compiling value-bag v1.10.0
[INFO] [stderr]    Compiling log v0.4.22
[INFO] [stderr]    Compiling event-listener v5.3.1
[INFO] [stderr]    Compiling futures-lite v2.5.0
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]    Compiling syn v2.0.91
[INFO] [stderr]    Compiling event-listener-strategy v0.5.3
[INFO] [stderr]    Compiling fs_extra v1.3.0
[INFO] [stderr]    Compiling cfg-if v0.1.10
[INFO] [stderr]    Compiling tracing-core v0.1.33
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling ahash v0.3.8
[INFO] [stderr]    Compiling cmake v0.1.52
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling atomic-waker v1.1.2
[INFO] [stderr]    Compiling mopa v0.2.2
[INFO] [stderr]    Compiling arrayvec v0.5.2
[INFO] [stderr]    Compiling async-task v4.7.1
[INFO] [stderr]    Compiling scopeguard v1.2.0
[INFO] [stderr]    Compiling crossbeam-queue v0.2.3
[INFO] [stderr]    Compiling piper v0.2.4
[INFO] [stderr]    Compiling tynm v0.1.10
[INFO] [stderr]    Compiling async-channel v2.3.1
[INFO] [stderr]    Compiling async-lock v3.4.0
[INFO] [stderr]    Compiling shrev v1.1.3
[INFO] [stderr]    Compiling tuple_utils v0.3.0
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling hibitset v0.6.4
[INFO] [stderr]    Compiling serde v1.0.216
[INFO] [stderr]    Compiling blocking v1.6.1
[INFO] [stderr]    Compiling parking_lot v0.12.3
[INFO] [stderr]    Compiling which v4.4.2
[INFO] [stderr]    Compiling shred v0.10.2
[INFO] [stderr]    Compiling async-executor v1.13.1
[INFO] [stderr]    Compiling dirs-sys-next v0.1.2
[INFO] [stderr]    Compiling itertools v0.11.0
[INFO] [stderr]    Compiling cexpr v0.6.0
[INFO] [stderr]    Compiling event-listener v2.5.3
[INFO] [stderr]    Compiling serde_json v1.0.134
[INFO] [stderr]    Compiling once_cell v1.20.2
[INFO] [stderr]    Compiling async-channel v1.9.0
[INFO] [stderr]    Compiling dirs-next v2.0.0
[INFO] [stderr]    Compiling kv-log-macro v1.0.7
[INFO] [stderr]    Compiling ryu v1.0.18
[INFO] [stderr]    Compiling ascii v1.1.0
[INFO] [stderr]    Compiling itoa v1.0.14
[INFO] [stderr]    Compiling specs v0.16.1
[INFO] [stderr]    Compiling pin-utils v0.1.0
[INFO] [stderr]    Compiling c_linked_list v1.1.1
[INFO] [stderr]    Compiling raw-window-handle v0.5.2
[INFO] [stderr]    Compiling tokio v1.42.0
[INFO] [stderr]    Compiling get_if_addrs v0.5.3
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling versions v5.0.1
[INFO] [stderr]    Compiling specs-derive v0.4.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling polling v3.7.4
[INFO] [stderr]    Compiling async-io v2.4.0
[INFO] [stderr]    Compiling native-dialog v0.7.0
[INFO] [stderr]    Compiling async-global-executor v2.4.1
[INFO] [stderr]    Compiling async-std v1.13.0
[INFO] [stderr]    Compiling raylib-sys v5.0.2
[INFO] [stderr]    Compiling raylib v5.0.2
[INFO] [stderr]    Compiling raylib_interactive v0.1.4
[INFO] [stderr]    Compiling RustSandbox v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `serde_json::json`
[INFO] [stdout]  --> src/movement.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_json::json;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `line` should have an upper camel case name
[INFO] [stdout]   --> src/movement.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct line {
[INFO] [stdout]    |            ^^^^ help: convert the identifier to upper camel case: `Line`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/movement.rs:112:8
[INFO] [stdout]     |
[INFO] [stdout] 112 | ...if (check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))) {
[INFO] [stdout]     |       ^                                                                                                                                                ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 112 -     if (check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))) {
[INFO] [stdout] 112 +     if check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::json`
[INFO] [stdout]  --> src/pathfinding.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json::json;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `line` should have an upper camel case name
[INFO] [stdout]  --> src/pathfinding.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct line {
[INFO] [stdout]   |            ^^^^ help: convert the identifier to upper camel case: `Line`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::path::PathBuf`
[INFO] [stdout]  --> src/client.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::randommods`
[INFO] [stdout]   --> src/client.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::randommods;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/settings.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 |     if (!path.exists()) {
[INFO] [stdout]    |        ^              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 15 -     if (!path.exists()) {
[INFO] [stdout] 15 +     if !path.exists()  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/networking.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]   --> src/networking.rs:10:17
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::sync::{Mutex};
[INFO] [stdout]    |                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SocketAddr`
[INFO] [stdout]    --> src/networking.rs:266:34
[INFO] [stdout]     |
[INFO] [stdout] 266 | use std::net::{IpAddr, Ipv4Addr, SocketAddr};
[INFO] [stdout]     |                                  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `handle_readd` should have an upper camel case name
[INFO] [stdout]  --> src/handle_read.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct handle_readd;
[INFO] [stdout]   |            ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `HandleReadd`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::io::prelude::*`
[INFO] [stdout]  --> src/randommods.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_std::io::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::TcpStream`
[INFO] [stdout]  --> src/randommods.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::TcpStream;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::IpAddr`
[INFO] [stdout]  --> src/server.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::IpAddr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::Ipv4Addr`
[INFO] [stdout]  --> src/server.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::Ipv4Addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]  --> src/server.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::thread;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::to_string`
[INFO] [stdout]  --> src/server.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use serde_json::to_string;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::networking`
[INFO] [stdout]   --> src/server.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::networking;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::os::unix::io::AsRawFd`
[INFO] [stdout]  --> src/randommods.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use async_std::os::unix::io::AsRawFd as AsyncRawFd;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/client.rs:66:9
[INFO] [stdout]    |
[INFO] [stdout] 66 |     let mut client = AsyncTcpClient::new(format!("{}:{}", settings["IP"].as_str().unwrap(), settings["PORT"].as_str().unwrap()).as_s...
[INFO] [stdout]    |         ----^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/client.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 114 |     let mut checklist: Value = json!({
[INFO] [stdout]     |         ----^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `checklist`
[INFO] [stdout]    --> src/client.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 114 |     let mut checklist: Value = json!({
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_checklist`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `open` is never read
[INFO] [stdout]    --> src/client.rs:238:5
[INFO] [stdout]     |
[INFO] [stdout] 238 |     open = rl.window_should_close();
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `monitor`
[INFO] [stdout]    --> src/settings.rs:118:9
[INFO] [stdout]     |
[INFO] [stdout] 118 |     let monitor: i32 = 0;
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_monitor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_field`
[INFO] [stdout]   --> src/randommods.rs:70:23
[INFO] [stdout]    |
[INFO] [stdout] 70 |             for (key, old_field) in old_obj {
[INFO] [stdout]    |                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_field`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `point1` and `point_on` are never read
[INFO] [stdout]   --> src/movement.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct line {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] 63 |     point1: Vector2,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 64 |     point2: Vector2,
[INFO] [stdout] 65 |     point_on: Vector2
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `point1`, `point2`, and `point_on` are never read
[INFO] [stdout]  --> src/pathfinding.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct line {
[INFO] [stdout]   |            ---- fields in this struct
[INFO] [stdout] 6 |     point1: Vector2,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 7 |     point2: Vector2,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 8 |     point_on: Vector2
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_changes` is never used
[INFO] [stdout]   --> src/randommods.rs:28:4
[INFO] [stdout]    |
[INFO] [stdout] 28 | fn find_changes(old_value: &Value, new_value: &Value) -> Value {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `sockID` should have a snake case name
[INFO] [stdout]   --> src/client.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let sockID: i32 = AsyncTcpClient::get_socket_id(&io_stream.lock().unwrap()) as i32;
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `sock_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Write` and `self`
[INFO] [stdout]  --> src/main.rs:8:15
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::{self, Write};
[INFO] [stdout]   |               ^^^^  ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `native_dialog::FileDialog`
[INFO] [stdout]  --> src/main.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use native_dialog::FileDialog;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::path::PathBuf`
[INFO] [stdout]  --> src/client.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::randommods`
[INFO] [stdout]   --> src/client.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::randommods;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::IpAddr`
[INFO] [stdout]  --> src/server.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::IpAddr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::Ipv4Addr`
[INFO] [stdout]  --> src/server.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::Ipv4Addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]  --> src/server.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::thread;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::to_string`
[INFO] [stdout]  --> src/server.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use serde_json::to_string;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::networking`
[INFO] [stdout]   --> src/server.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::networking;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::io::prelude::*`
[INFO] [stdout]  --> src/randommods.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_std::io::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::TcpStream`
[INFO] [stdout]  --> src/randommods.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::TcpStream;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/settings.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 |     if (!path.exists()) {
[INFO] [stdout]    |        ^              ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 15 -     if (!path.exists()) {
[INFO] [stdout] 15 +     if !path.exists()  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/networking.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]   --> src/networking.rs:10:17
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::sync::{Mutex};
[INFO] [stdout]    |                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SocketAddr`
[INFO] [stdout]    --> src/networking.rs:266:34
[INFO] [stdout]     |
[INFO] [stdout] 266 | use std::net::{IpAddr, Ipv4Addr, SocketAddr};
[INFO] [stdout]     |                                  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `handle_readd` should have an upper camel case name
[INFO] [stdout]  --> src/handle_read.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct handle_readd;
[INFO] [stdout]   |            ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `HandleReadd`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::os::unix::io::AsRawFd`
[INFO] [stdout]  --> src/randommods.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use async_std::os::unix::io::AsRawFd as AsyncRawFd;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/client.rs:66:9
[INFO] [stdout]    |
[INFO] [stdout] 66 |     let mut client = AsyncTcpClient::new(format!("{}:{}", settings["IP"].as_str().unwrap(), settings["PORT"].as_str().unwrap()).as_s...
[INFO] [stdout]    |         ----^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/client.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 114 |     let mut checklist: Value = json!({
[INFO] [stdout]     |         ----^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `checklist`
[INFO] [stdout]    --> src/client.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 114 |     let mut checklist: Value = json!({
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_checklist`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `open` is never read
[INFO] [stdout]    --> src/client.rs:238:5
[INFO] [stdout]     |
[INFO] [stdout] 238 |     open = rl.window_should_close();
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_field`
[INFO] [stdout]   --> src/randommods.rs:70:23
[INFO] [stdout]    |
[INFO] [stdout] 70 |             for (key, old_field) in old_obj {
[INFO] [stdout]    |                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_field`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `monitor`
[INFO] [stdout]    --> src/settings.rs:118:9
[INFO] [stdout]     |
[INFO] [stdout] 118 |     let monitor: i32 = 0;
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_monitor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]   --> src/main.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let args: Vec<String> = env::args().collect();
[INFO] [stdout]    |         ^^^^ help: if this is intentional, prefix it with an underscore: `_args`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `server_thread`
[INFO] [stdout]   --> src/main.rs:89:13
[INFO] [stdout]    |
[INFO] [stdout] 89 |         let server_thread: thread::JoinHandle<()> = thread::spawn(|| {
[INFO] [stdout]    |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_server_thread`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_changes` is never used
[INFO] [stdout]   --> src/randommods.rs:28:4
[INFO] [stdout]    |
[INFO] [stdout] 28 | fn find_changes(old_value: &Value, new_value: &Value) -> Value {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_collision` is never used
[INFO] [stdout]   --> src/collision.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub fn check_collision(player: &Movement, rect: &Rectangle) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `handler` is never read
[INFO] [stdout]   --> src/networking.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct AsyncTcpServer {
[INFO] [stdout]    |            -------------- field in this struct
[INFO] [stdout] 15 |     address: String,
[INFO] [stdout] 16 |     handler: ClientHandler,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `run` and `receive` are never used
[INFO] [stdout]    --> src/networking.rs:31:18
[INFO] [stdout]     |
[INFO] [stdout]  19 | impl AsyncTcpServer {
[INFO] [stdout]     | ------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  31 |     pub async fn run(&self) -> async_std::io::Result<()> {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub async fn receive(stream: &mut TcpStream) -> async_std::io::Result<String> {
[INFO] [stdout]     |                  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `start_interactive_session` is never used
[INFO] [stdout]    --> src/networking.rs:203:18
[INFO] [stdout]     |
[INFO] [stdout] 140 | impl AsyncTcpClient {
[INFO] [stdout]     | ------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 203 |     pub async fn start_interactive_session(mut stream: TcpStream) -> async_std::io::Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_local_ip` is never used
[INFO] [stdout]    --> src/networking.rs:294:8
[INFO] [stdout]     |
[INFO] [stdout] 294 | pub fn get_local_ip() -> Result<IpAddr, Box<dyn std::error::Error>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `sockID` should have a snake case name
[INFO] [stdout]   --> src/client.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let sockID: i32 = AsyncTcpClient::get_socket_id(&io_stream.lock().unwrap()) as i32;
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `sock_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 44.73s
[INFO] running `Command { std: "docker" "inspect" "d9fd1921beca6d916c86b5b91cf18c62e92bd03573c65b43ce0a3b357f44e967", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d9fd1921beca6d916c86b5b91cf18c62e92bd03573c65b43ce0a3b357f44e967", kill_on_drop: false }`
[INFO] [stdout] d9fd1921beca6d916c86b5b91cf18c62e92bd03573c65b43ce0a3b357f44e967
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cc3ce205b236b775795d639e5c8de37cc9d281701f5260892b502d0611118b43
[INFO] running `Command { std: "docker" "start" "-a" "cc3ce205b236b775795d639e5c8de37cc9d281701f5260892b502d0611118b43", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling specs-derive v0.4.1
[INFO] [stderr]    Compiling async-attributes v1.1.2
[INFO] [stderr]    Compiling async-std v1.13.0
[INFO] [stderr]    Compiling raylib v5.0.2
[INFO] [stderr]    Compiling raylib_interactive v0.1.4
[INFO] [stderr]    Compiling RustSandbox v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `serde_json::json`
[INFO] [stdout]  --> src/movement.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_json::json;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `line` should have an upper camel case name
[INFO] [stdout]   --> src/movement.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct line {
[INFO] [stdout]    |            ^^^^ help: convert the identifier to upper camel case: `Line`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/movement.rs:112:8
[INFO] [stdout]     |
[INFO] [stdout] 112 | ...if (check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))) {
[INFO] [stdout]     |       ^                                                                                                                                                ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 112 -     if (check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))) {
[INFO] [stdout] 112 +     if check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::json`
[INFO] [stdout]  --> src/pathfinding.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json::json;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `line` should have an upper camel case name
[INFO] [stdout]  --> src/pathfinding.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct line {
[INFO] [stdout]   |            ^^^^ help: convert the identifier to upper camel case: `Line`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::path::PathBuf`
[INFO] [stdout]  --> src/client.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::randommods`
[INFO] [stdout]   --> src/client.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::randommods;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/settings.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 |     if (!path.exists()) {
[INFO] [stdout]    |        ^              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 15 -     if (!path.exists()) {
[INFO] [stdout] 15 +     if !path.exists()  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/networking.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]   --> src/networking.rs:10:17
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::sync::{Mutex};
[INFO] [stdout]    |                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SocketAddr`
[INFO] [stdout]    --> src/networking.rs:266:34
[INFO] [stdout]     |
[INFO] [stdout] 266 | use std::net::{IpAddr, Ipv4Addr, SocketAddr};
[INFO] [stdout]     |                                  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `handle_readd` should have an upper camel case name
[INFO] [stdout]  --> src/handle_read.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct handle_readd;
[INFO] [stdout]   |            ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `HandleReadd`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::io::prelude::*`
[INFO] [stdout]  --> src/randommods.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_std::io::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::TcpStream`
[INFO] [stdout]  --> src/randommods.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::TcpStream;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::IpAddr`
[INFO] [stdout]  --> src/server.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::IpAddr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::Ipv4Addr`
[INFO] [stdout]  --> src/server.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::Ipv4Addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]  --> src/server.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::thread;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::to_string`
[INFO] [stdout]  --> src/server.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use serde_json::to_string;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::networking`
[INFO] [stdout]   --> src/server.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::networking;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::os::unix::io::AsRawFd`
[INFO] [stdout]  --> src/randommods.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use async_std::os::unix::io::AsRawFd as AsyncRawFd;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/client.rs:66:9
[INFO] [stdout]    |
[INFO] [stdout] 66 |     let mut client = AsyncTcpClient::new(format!("{}:{}", settings["IP"].as_str().unwrap(), settings["PORT"].as_str().unwrap()).as_s...
[INFO] [stdout]    |         ----^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/client.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 114 |     let mut checklist: Value = json!({
[INFO] [stdout]     |         ----^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `checklist`
[INFO] [stdout]    --> src/client.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 114 |     let mut checklist: Value = json!({
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_checklist`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `open` is never read
[INFO] [stdout]    --> src/client.rs:238:5
[INFO] [stdout]     |
[INFO] [stdout] 238 |     open = rl.window_should_close();
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `monitor`
[INFO] [stdout]    --> src/settings.rs:118:9
[INFO] [stdout]     |
[INFO] [stdout] 118 |     let monitor: i32 = 0;
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_monitor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_field`
[INFO] [stdout]   --> src/randommods.rs:70:23
[INFO] [stdout]    |
[INFO] [stdout] 70 |             for (key, old_field) in old_obj {
[INFO] [stdout]    |                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_field`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `point1` and `point_on` are never read
[INFO] [stdout]   --> src/movement.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct line {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] 63 |     point1: Vector2,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 64 |     point2: Vector2,
[INFO] [stdout] 65 |     point_on: Vector2
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `point1`, `point2`, and `point_on` are never read
[INFO] [stdout]  --> src/pathfinding.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct line {
[INFO] [stdout]   |            ---- fields in this struct
[INFO] [stdout] 6 |     point1: Vector2,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 7 |     point2: Vector2,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 8 |     point_on: Vector2
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_changes` is never used
[INFO] [stdout]   --> src/randommods.rs:28:4
[INFO] [stdout]    |
[INFO] [stdout] 28 | fn find_changes(old_value: &Value, new_value: &Value) -> Value {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `sockID` should have a snake case name
[INFO] [stdout]   --> src/client.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let sockID: i32 = AsyncTcpClient::get_socket_id(&io_stream.lock().unwrap()) as i32;
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `sock_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::json`
[INFO] [stdout]  --> src/movement.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_json::json;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `line` should have an upper camel case name
[INFO] [stdout]   --> src/movement.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct line {
[INFO] [stdout]    |            ^^^^ help: convert the identifier to upper camel case: `Line`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/movement.rs:112:8
[INFO] [stdout]     |
[INFO] [stdout] 112 | ...if (check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))) {
[INFO] [stdout]     |       ^                                                                                                                                                ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 112 -     if (check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))) {
[INFO] [stdout] 112 +     if check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::json`
[INFO] [stdout]  --> src/pathfinding.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde_json::json;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `line` should have an upper camel case name
[INFO] [stdout]  --> src/pathfinding.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct line {
[INFO] [stdout]   |            ^^^^ help: convert the identifier to upper camel case: `Line`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::path::PathBuf`
[INFO] [stdout]  --> src/client.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::randommods`
[INFO] [stdout]   --> src/client.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::randommods;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/settings.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 |     if (!path.exists()) {
[INFO] [stdout]    |        ^              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 15 -     if (!path.exists()) {
[INFO] [stdout] 15 +     if !path.exists()  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]   --> src/networking.rs:10:17
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::sync::{Mutex};
[INFO] [stdout]    |                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SocketAddr`
[INFO] [stdout]    --> src/networking.rs:266:34
[INFO] [stdout]     |
[INFO] [stdout] 266 | use std::net::{IpAddr, Ipv4Addr, SocketAddr};
[INFO] [stdout]     |                                  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `handle_readd` should have an upper camel case name
[INFO] [stdout]  --> src/handle_read.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct handle_readd;
[INFO] [stdout]   |            ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `HandleReadd`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::io::prelude::*`
[INFO] [stdout]  --> src/randommods.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_std::io::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::TcpStream`
[INFO] [stdout]  --> src/randommods.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::TcpStream;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::IpAddr`
[INFO] [stdout]  --> src/server.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::IpAddr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::Ipv4Addr`
[INFO] [stdout]  --> src/server.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::Ipv4Addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]  --> src/server.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::thread;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::to_string`
[INFO] [stdout]  --> src/server.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use serde_json::to_string;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::networking`
[INFO] [stdout]   --> src/server.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::networking;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::os::unix::io::AsRawFd`
[INFO] [stdout]  --> src/randommods.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use async_std::os::unix::io::AsRawFd as AsyncRawFd;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/client.rs:66:9
[INFO] [stdout]    |
[INFO] [stdout] 66 |     let mut client = AsyncTcpClient::new(format!("{}:{}", settings["IP"].as_str().unwrap(), settings["PORT"].as_str().unwrap()).as_s...
[INFO] [stdout]    |         ----^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/client.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 114 |     let mut checklist: Value = json!({
[INFO] [stdout]     |         ----^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `checklist`
[INFO] [stdout]    --> src/client.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 114 |     let mut checklist: Value = json!({
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_checklist`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `open` is never read
[INFO] [stdout]    --> src/client.rs:238:5
[INFO] [stdout]     |
[INFO] [stdout] 238 |     open = rl.window_should_close();
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `monitor`
[INFO] [stdout]    --> src/settings.rs:118:9
[INFO] [stdout]     |
[INFO] [stdout] 118 |     let monitor: i32 = 0;
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_monitor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_field`
[INFO] [stdout]   --> src/randommods.rs:70:23
[INFO] [stdout]    |
[INFO] [stdout] 70 |             for (key, old_field) in old_obj {
[INFO] [stdout]    |                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_field`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `point1` and `point_on` are never read
[INFO] [stdout]   --> src/movement.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 62 | pub struct line {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] 63 |     point1: Vector2,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 64 |     point2: Vector2,
[INFO] [stdout] 65 |     point_on: Vector2
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `point1`, `point2`, and `point_on` are never read
[INFO] [stdout]  --> src/pathfinding.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct line {
[INFO] [stdout]   |            ---- fields in this struct
[INFO] [stdout] 6 |     point1: Vector2,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 7 |     point2: Vector2,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 8 |     point_on: Vector2
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_changes` is never used
[INFO] [stdout]   --> src/randommods.rs:28:4
[INFO] [stdout]    |
[INFO] [stdout] 28 | fn find_changes(old_value: &Value, new_value: &Value) -> Value {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `sockID` should have a snake case name
[INFO] [stdout]   --> src/client.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let sockID: i32 = AsyncTcpClient::get_socket_id(&io_stream.lock().unwrap()) as i32;
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `sock_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Write` and `self`
[INFO] [stdout]  --> src/main.rs:8:15
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::{self, Write};
[INFO] [stdout]   |               ^^^^  ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `native_dialog::FileDialog`
[INFO] [stdout]  --> src/main.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use native_dialog::FileDialog;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::path::PathBuf`
[INFO] [stdout]  --> src/client.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::randommods`
[INFO] [stdout]   --> src/client.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use crate::randommods;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::IpAddr`
[INFO] [stdout]  --> src/server.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::net::IpAddr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::Ipv4Addr`
[INFO] [stdout]  --> src/server.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::Ipv4Addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]  --> src/server.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::thread;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::to_string`
[INFO] [stdout]  --> src/server.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use serde_json::to_string;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::networking`
[INFO] [stdout]   --> src/server.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::networking;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::io::prelude::*`
[INFO] [stdout]  --> src/randommods.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use async_std::io::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::TcpStream`
[INFO] [stdout]  --> src/randommods.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::TcpStream;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/settings.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 |     if (!path.exists()) {
[INFO] [stdout]    |        ^              ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 15 -     if (!path.exists()) {
[INFO] [stdout] 15 +     if !path.exists()  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]   --> src/networking.rs:10:17
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::sync::{Mutex};
[INFO] [stdout]    |                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SocketAddr`
[INFO] [stdout]    --> src/networking.rs:266:34
[INFO] [stdout]     |
[INFO] [stdout] 266 | use std::net::{IpAddr, Ipv4Addr, SocketAddr};
[INFO] [stdout]     |                                  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `handle_readd` should have an upper camel case name
[INFO] [stdout]  --> src/handle_read.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct handle_readd;
[INFO] [stdout]   |            ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `HandleReadd`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `async_std::os::unix::io::AsRawFd`
[INFO] [stdout]  --> src/randommods.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use async_std::os::unix::io::AsRawFd as AsyncRawFd;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/client.rs:66:9
[INFO] [stdout]    |
[INFO] [stdout] 66 |     let mut client = AsyncTcpClient::new(format!("{}:{}", settings["IP"].as_str().unwrap(), settings["PORT"].as_str().unwrap()).as_s...
[INFO] [stdout]    |         ----^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/client.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 114 |     let mut checklist: Value = json!({
[INFO] [stdout]     |         ----^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `checklist`
[INFO] [stdout]    --> src/client.rs:114:9
[INFO] [stdout]     |
[INFO] [stdout] 114 |     let mut checklist: Value = json!({
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_checklist`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `open` is never read
[INFO] [stdout]    --> src/client.rs:238:5
[INFO] [stdout]     |
[INFO] [stdout] 238 |     open = rl.window_should_close();
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `old_field`
[INFO] [stdout]   --> src/randommods.rs:70:23
[INFO] [stdout]    |
[INFO] [stdout] 70 |             for (key, old_field) in old_obj {
[INFO] [stdout]    |                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_field`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `monitor`
[INFO] [stdout]    --> src/settings.rs:118:9
[INFO] [stdout]     |
[INFO] [stdout] 118 |     let monitor: i32 = 0;
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_monitor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]   --> src/main.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let args: Vec<String> = env::args().collect();
[INFO] [stdout]    |         ^^^^ help: if this is intentional, prefix it with an underscore: `_args`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `server_thread`
[INFO] [stdout]   --> src/main.rs:89:13
[INFO] [stdout]    |
[INFO] [stdout] 89 |         let server_thread: thread::JoinHandle<()> = thread::spawn(|| {
[INFO] [stdout]    |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_server_thread`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_changes` is never used
[INFO] [stdout]   --> src/randommods.rs:28:4
[INFO] [stdout]    |
[INFO] [stdout] 28 | fn find_changes(old_value: &Value, new_value: &Value) -> Value {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_collision` is never used
[INFO] [stdout]   --> src/collision.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub fn check_collision(player: &Movement, rect: &Rectangle) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `receive` is never used
[INFO] [stdout]    --> src/networking.rs:107:18
[INFO] [stdout]     |
[INFO] [stdout]  19 | impl AsyncTcpServer {
[INFO] [stdout]     | ------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub async fn receive(stream: &mut TcpStream) -> async_std::io::Result<String> {
[INFO] [stdout]     |                  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `start_interactive_session` is never used
[INFO] [stdout]    --> src/networking.rs:203:18
[INFO] [stdout]     |
[INFO] [stdout] 140 | impl AsyncTcpClient {
[INFO] [stdout]     | ------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 203 |     pub async fn start_interactive_session(mut stream: TcpStream) -> async_std::io::Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_local_ip` is never used
[INFO] [stdout]    --> src/networking.rs:294:8
[INFO] [stdout]     |
[INFO] [stdout] 294 | pub fn get_local_ip() -> Result<IpAddr, Box<dyn std::error::Error>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `sockID` should have a snake case name
[INFO] [stdout]   --> src/client.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let sockID: i32 = AsyncTcpClient::get_socket_id(&io_stream.lock().unwrap()) as i32;
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `sock_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 11.47s
[INFO] running `Command { std: "docker" "inspect" "cc3ce205b236b775795d639e5c8de37cc9d281701f5260892b502d0611118b43", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cc3ce205b236b775795d639e5c8de37cc9d281701f5260892b502d0611118b43", kill_on_drop: false }`
[INFO] [stdout] cc3ce205b236b775795d639e5c8de37cc9d281701f5260892b502d0611118b43
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+ec6f9a5b4413f74386267ef8efc93712c2ce6db6" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 309078a19e9950724887a1688f7617fd8325d68e4aeaa2b4b68a598392cfbe8b
[INFO] running `Command { std: "docker" "start" "-a" "309078a19e9950724887a1688f7617fd8325d68e4aeaa2b4b68a598392cfbe8b", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `serde_json::json`
[INFO] [stderr]  --> src/movement.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use serde_json::json;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: type `line` should have an upper camel case name
[INFO] [stderr]   --> src/movement.rs:62:12
[INFO] [stderr]    |
[INFO] [stderr] 62 | pub struct line {
[INFO] [stderr]    |            ^^^^ help: convert the identifier to upper camel case: `Line`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/movement.rs:112:8
[INFO] [stderr]     |
[INFO] [stderr] 112 | ...if (check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))) {
[INFO] [stderr]     |       ^                                                                                                                                                ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 112 -     if (check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))) {
[INFO] [stderr] 112 +     if check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `serde_json::json`
[INFO] [stderr]  --> src/pathfinding.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use serde_json::json;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type `line` should have an upper camel case name
[INFO] [stderr]  --> src/pathfinding.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct line {
[INFO] [stderr]   |            ^^^^ help: convert the identifier to upper camel case: `Line`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `async_std::path::PathBuf`
[INFO] [stderr]  --> src/client.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use async_std::path::PathBuf;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::randommods`
[INFO] [stderr]   --> src/client.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 16 | use crate::randommods;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/settings.rs:15:8
[INFO] [stderr]    |
[INFO] [stderr] 15 |     if (!path.exists()) {
[INFO] [stderr]    |        ^              ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 15 -     if (!path.exists()) {
[INFO] [stderr] 15 +     if !path.exists()  {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::time::Duration`
[INFO] [stderr]  --> src/networking.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use std::time::Duration;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Mutex`
[INFO] [stderr]   --> src/networking.rs:10:17
[INFO] [stderr]    |
[INFO] [stderr] 10 | use std::sync::{Mutex};
[INFO] [stderr]    |                 ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `SocketAddr`
[INFO] [stderr]    --> src/networking.rs:266:34
[INFO] [stderr]     |
[INFO] [stderr] 266 | use std::net::{IpAddr, Ipv4Addr, SocketAddr};
[INFO] [stderr]     |                                  ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type `handle_readd` should have an upper camel case name
[INFO] [stderr]  --> src/handle_read.rs:9:12
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub struct handle_readd;
[INFO] [stderr]   |            ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `HandleReadd`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `async_std::io::prelude::*`
[INFO] [stderr]  --> src/randommods.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use async_std::io::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::net::TcpStream`
[INFO] [stderr]  --> src/randommods.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::net::TcpStream;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::net::IpAddr`
[INFO] [stderr]  --> src/server.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::net::IpAddr;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::net::Ipv4Addr`
[INFO] [stderr]  --> src/server.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use std::net::Ipv4Addr;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::thread`
[INFO] [stderr]  --> src/server.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::thread;
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `serde_json::to_string`
[INFO] [stderr]  --> src/server.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 | use serde_json::to_string;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::networking`
[INFO] [stderr]   --> src/server.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | use crate::networking;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `async_std::os::unix::io::AsRawFd`
[INFO] [stderr]  --> src/randommods.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use async_std::os::unix::io::AsRawFd as AsyncRawFd;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/client.rs:66:9
[INFO] [stderr]    |
[INFO] [stderr] 66 |     let mut client = AsyncTcpClient::new(format!("{}:{}", settings["IP"].as_str().unwrap(), settings["PORT"].as_str().unwrap()).as_s...
[INFO] [stderr]    |         ----^^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/client.rs:114:9
[INFO] [stderr]     |
[INFO] [stderr] 114 |     let mut checklist: Value = json!({
[INFO] [stderr]     |         ----^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `checklist`
[INFO] [stderr]    --> src/client.rs:114:9
[INFO] [stderr]     |
[INFO] [stderr] 114 |     let mut checklist: Value = json!({
[INFO] [stderr]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_checklist`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `open` is never read
[INFO] [stderr]    --> src/client.rs:238:5
[INFO] [stderr]     |
[INFO] [stderr] 238 |     open = rl.window_should_close();
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `monitor`
[INFO] [stderr]    --> src/settings.rs:118:9
[INFO] [stderr]     |
[INFO] [stderr] 118 |     let monitor: i32 = 0;
[INFO] [stderr]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_monitor`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `old_field`
[INFO] [stderr]   --> src/randommods.rs:70:23
[INFO] [stderr]    |
[INFO] [stderr] 70 |             for (key, old_field) in old_obj {
[INFO] [stderr]    |                       ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_old_field`
[INFO] [stderr] 
[INFO] [stderr] warning: fields `point1` and `point_on` are never read
[INFO] [stderr]   --> src/movement.rs:63:5
[INFO] [stderr]    |
[INFO] [stderr] 62 | pub struct line {
[INFO] [stderr]    |            ---- fields in this struct
[INFO] [stderr] 63 |     point1: Vector2,
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] 64 |     point2: Vector2,
[INFO] [stderr] 65 |     point_on: Vector2
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: fields `point1`, `point2`, and `point_on` are never read
[INFO] [stderr]  --> src/pathfinding.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct line {
[INFO] [stderr]   |            ---- fields in this struct
[INFO] [stderr] 6 |     point1: Vector2,
[INFO] [stderr]   |     ^^^^^^
[INFO] [stderr] 7 |     point2: Vector2,
[INFO] [stderr]   |     ^^^^^^
[INFO] [stderr] 8 |     point_on: Vector2
[INFO] [stderr]   |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `find_changes` is never used
[INFO] [stderr]   --> src/randommods.rs:28:4
[INFO] [stderr]    |
[INFO] [stderr] 28 | fn find_changes(old_value: &Value, new_value: &Value) -> Value {
[INFO] [stderr]    |    ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable `sockID` should have a snake case name
[INFO] [stderr]   --> src/client.rs:86:9
[INFO] [stderr]    |
[INFO] [stderr] 86 |     let sockID: i32 = AsyncTcpClient::get_socket_id(&io_stream.lock().unwrap()) as i32;
[INFO] [stderr]    |         ^^^^^^ help: convert the identifier to snake case: `sock_id`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `RustSandbox` (lib) generated 30 warnings (run `cargo fix --lib -p RustSandbox` to apply 21 suggestions)
[INFO] [stderr] warning: `RustSandbox` (lib test) generated 29 warnings (29 duplicates)
[INFO] [stderr] warning: unused imports: `Write` and `self`
[INFO] [stderr]  --> src/main.rs:8:15
[INFO] [stderr]   |
[INFO] [stderr] 8 | use std::io::{self, Write};
[INFO] [stderr]   |               ^^^^  ^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `native_dialog::FileDialog`
[INFO] [stderr]  --> src/main.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 | use native_dialog::FileDialog;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/settings.rs:15:8
[INFO] [stderr]    |
[INFO] [stderr] 15 |     if (!path.exists()) {
[INFO] [stderr]    |        ^              ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 15 -     if (!path.exists()) {
[INFO] [stderr] 15 +     if !path.exists()  {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: type `handle_readd` should have an upper camel case name
[INFO] [stderr]  --> src/handle_read.rs:9:12
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub struct handle_readd;
[INFO] [stderr]   |            ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `HandleReadd`
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `args`
[INFO] [stderr]   --> src/main.rs:27:9
[INFO] [stderr]    |
[INFO] [stderr] 27 |     let args: Vec<String> = env::args().collect();
[INFO] [stderr]    |         ^^^^ help: if this is intentional, prefix it with an underscore: `_args`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `server_thread`
[INFO] [stderr]   --> src/main.rs:89:13
[INFO] [stderr]    |
[INFO] [stderr] 89 |         let server_thread: thread::JoinHandle<()> = thread::spawn(|| {
[INFO] [stderr]    |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_server_thread`
[INFO] [stderr] 
[INFO] [stderr] warning: function `find_changes` is never used
[INFO] [stderr]   --> src/randommods.rs:28:4
[INFO] [stderr]    |
[INFO] [stderr] 28 | fn find_changes(old_value: &Value, new_value: &Value) -> Value {
[INFO] [stderr]    |    ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `check_collision` is never used
[INFO] [stderr]   --> src/collision.rs:25:8
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub fn check_collision(player: &Movement, rect: &Rectangle) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `receive` is never used
[INFO] [stderr]    --> src/networking.rs:107:18
[INFO] [stderr]     |
[INFO] [stderr]  19 | impl AsyncTcpServer {
[INFO] [stderr]     | ------------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 107 |     pub async fn receive(stream: &mut TcpStream) -> async_std::io::Result<String> {
[INFO] [stderr]     |                  ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `start_interactive_session` is never used
[INFO] [stderr]    --> src/networking.rs:203:18
[INFO] [stderr]     |
[INFO] [stderr] 140 | impl AsyncTcpClient {
[INFO] [stderr]     | ------------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 203 |     pub async fn start_interactive_session(mut stream: TcpStream) -> async_std::io::Result<()> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_local_ip` is never used
[INFO] [stderr]    --> src/networking.rs:294:8
[INFO] [stderr]     |
[INFO] [stderr] 294 | pub fn get_local_ip() -> Result<IpAddr, Box<dyn std::error::Error>> {
[INFO] [stderr]     |        ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `RustSandbox` (bin "RustSandbox" test) generated 30 warnings (19 duplicates) (run `cargo fix --bin "RustSandbox" -p RustSandbox --tests` to apply 5 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.24s
[INFO] [stdout] 
[INFO] [stdout] running 5 tests
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/rust_sandbox_lib-997661b477dc769d)
[INFO] [stdout] test networking::tests::test_basic_server_client_connection ... ok
[INFO] [stdout] test networking::tests::test_multiple_clients ... ok
[INFO] [stdout] test networking::tests::test_get_socket_id ... ok
[INFO] [stdout] test networking::tests::test_bidirectional_communication ... ok
[INFO] [stdout] test networking::tests::test_continuous_messaging ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.12s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/RustSandbox-42189f293146d8ad)
[INFO] [stdout] 
[INFO] [stdout] running 5 tests
[INFO] [stdout] test networking::tests::test_get_socket_id ... ok
[INFO] [stdout] test networking::tests::test_basic_server_client_connection ... ok
[INFO] [stdout] test networking::tests::test_multiple_clients ... ok
[INFO] [stdout] test networking::tests::test_bidirectional_communication ... ok
[INFO] [stdout] test networking::tests::test_continuous_messaging ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.14s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests rust_sandbox_lib
[INFO] [stderr] warning: type `line` should have an upper camel case name
[INFO] [stderr]   --> src/movement.rs:62:12
[INFO] [stderr]    |
[INFO] [stderr] 62 | pub struct line {
[INFO] [stderr]    |            ^^^^ help: convert the identifier to upper camel case: `Line`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/movement.rs:112:8
[INFO] [stderr]     |
[INFO] [stderr] 112 | ...if (check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))) {
[INFO] [stderr]     |       ^                                                                                                                                                ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 112 -     if (check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))) {
[INFO] [stderr] 112 +     if check_collision(&Rectangle::new(x1 as f32, y1 as f32, owidth as f32, oheight as f32), &Rectangle::new(ending_point.x, ending_point.y, 1.0, 1.0))  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: type `line` should have an upper camel case name
[INFO] [stderr]  --> src/pathfinding.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct line {
[INFO] [stderr]   |            ^^^^ help: convert the identifier to upper camel case: `Line`
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/settings.rs:15:8
[INFO] [stderr]    |
[INFO] [stderr] 15 |     if (!path.exists()) {
[INFO] [stderr]    |        ^              ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 15 -     if (!path.exists()) {
[INFO] [stderr] 15 +     if !path.exists()  {
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: type `handle_readd` should have an upper camel case name
[INFO] [stderr]  --> src/handle_read.rs:9:12
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub struct handle_readd;
[INFO] [stderr]   |            ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `HandleReadd`
[INFO] [stderr] 
[INFO] [stderr] warning: 5 warnings emitted
[INFO] [stderr] 
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test src/exec.rs - exec::Exec (line 17) ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- src/exec.rs - exec::Exec (line 17) stdout ----
[INFO] [stdout] error[E0433]: cannot find type `Exec` in this scope
[INFO] [stdout]   --> src/exec.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | let exec = Exec::new();
[INFO] [stdout]    |            ^^^^ use of undeclared type `Exec`
[INFO] [stdout]    |
[INFO] [stdout] help: consider importing this struct
[INFO] [stdout]    |
[INFO] [stdout] 17 + use rust_sandbox_lib::exec::Exec;
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 1 previous error
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0433`.
[INFO] [stdout] Couldn't compile the test.
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     src/exec.rs - exec::Exec (line 17)
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.12s
[INFO] [stdout] 
[INFO] [stderr] error: doctest failed, to rerun pass `--doc`
[INFO] running `Command { std: "docker" "inspect" "309078a19e9950724887a1688f7617fd8325d68e4aeaa2b4b68a598392cfbe8b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "309078a19e9950724887a1688f7617fd8325d68e4aeaa2b4b68a598392cfbe8b", kill_on_drop: false }`
[INFO] [stdout] 309078a19e9950724887a1688f7617fd8325d68e4aeaa2b4b68a598392cfbe8b
