[INFO] cloning repository https://github.com/Nat-Rubin/Solitaire
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Nat-Rubin/Solitaire" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FNat-Rubin%2FSolitaire", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FNat-Rubin%2FSolitaire'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 4518902bcf9159f8a1dbb0c4a8887c4c92edbd35
[INFO] testing Nat-Rubin/Solitaire against beta-2025-09-21 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FNat-Rubin%2FSolitaire" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Nat-Rubin/Solitaire
[INFO] finished tweaking git repo https://github.com/Nat-Rubin/Solitaire
[INFO] tweaked toml for git repo https://github.com/Nat-Rubin/Solitaire written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Nat-Rubin/Solitaire on toolchain beta-2025-09-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Nat-Rubin/Solitaire 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" "+beta-2025-09-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7163c5b850122cddce2a1e5464f10e9adcb36005a15bc0d54e3b55a0ab67f7ba
[INFO] running `Command { std: "docker" "start" "-a" "7163c5b850122cddce2a1e5464f10e9adcb36005a15bc0d54e3b55a0ab67f7ba", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7163c5b850122cddce2a1e5464f10e9adcb36005a15bc0d54e3b55a0ab67f7ba", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7163c5b850122cddce2a1e5464f10e9adcb36005a15bc0d54e3b55a0ab67f7ba", kill_on_drop: false }`
[INFO] [stdout] 7163c5b850122cddce2a1e5464f10e9adcb36005a15bc0d54e3b55a0ab67f7ba
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5f45eed0c7853d57d24abcddad7608dd8ef51b5592408b4f5bbaaa55ac37f2eb
[INFO] running `Command { std: "docker" "start" "-a" "5f45eed0c7853d57d24abcddad7608dd8ef51b5592408b4f5bbaaa55ac37f2eb", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.78
[INFO] [stderr]    Compiling libc v0.2.153
[INFO] [stderr]    Compiling pkg-config v0.3.30
[INFO] [stderr]    Compiling libm v0.2.8
[INFO] [stderr]    Compiling smallvec v1.13.1
[INFO] [stderr]    Compiling arrayvec v0.7.4
[INFO] [stderr]    Compiling log v0.4.20
[INFO] [stderr]    Compiling once_cell v1.19.0
[INFO] [stderr]    Compiling crossbeam-utils v0.8.19
[INFO] [stderr]    Compiling xml-rs v0.8.19
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling lock_api v0.4.11
[INFO] [stderr]    Compiling libloading v0.8.1
[INFO] [stderr]    Compiling serde v1.0.197
[INFO] [stderr]    Compiling simd-adler32 v0.3.7
[INFO] [stderr]    Compiling thiserror v1.0.57
[INFO] [stderr]    Compiling adler v1.0.2
[INFO] [stderr]    Compiling crc32fast v1.4.0
[INFO] [stderr]    Compiling rayon-core v1.12.1
[INFO] [stderr]    Compiling miniz_oxide v0.7.2
[INFO] [stderr]    Compiling bitflags v2.4.2
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling dlib v0.5.2
[INFO] [stderr]    Compiling parking_lot_core v0.9.9
[INFO] [stderr]    Compiling ahash v0.8.9
[INFO] [stderr]    Compiling ttf-parser v0.20.0
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling wayland-sys v0.29.5
[INFO] [stderr]    Compiling unicase v2.7.0
[INFO] [stderr]    Compiling serde_json v1.0.114
[INFO] [stderr]    Compiling either v1.10.0
[INFO] [stderr]    Compiling zerocopy v0.7.32
[INFO] [stderr]    Compiling ab_glyph_rasterizer v0.1.8
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling semver v1.0.22
[INFO] [stderr]    Compiling rustix v0.38.31
[INFO] [stderr]    Compiling camino v1.1.6
[INFO] [stderr]    Compiling crossbeam-deque v0.8.5
[INFO] [stderr]    Compiling flate2 v1.0.28
[INFO] [stderr]    Compiling cc v1.0.88
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling quote v1.0.35
[INFO] [stderr]    Compiling fdeflate v0.3.4
[INFO] [stderr]    Compiling error-chain v0.12.4
[INFO] [stderr]    Compiling bit-vec v0.6.3
[INFO] [stderr]    Compiling linux-raw-sys v0.4.13
[INFO] [stderr]    Compiling allocator-api2 v0.2.16
[INFO] [stderr]    Compiling syn v2.0.50
[INFO] [stderr]    Compiling wayland-scanner v0.29.5
[INFO] [stderr]    Compiling ash v0.37.3+1.3.251
[INFO] [stderr]    Compiling khronos-egl v4.1.0
[INFO] [stderr]    Compiling rayon v1.8.1
[INFO] [stderr]    Compiling ryu v1.0.17
[INFO] [stderr]    Compiling itoa v1.0.10
[INFO] [stderr]    Compiling unicode-width v0.1.11
[INFO] [stderr]    Compiling pulldown-cmark v0.9.6
[INFO] [stderr]    Compiling codespan-reporting v0.11.1
[INFO] [stderr]    Compiling bit-set v0.5.3
[INFO] [stderr]    Compiling hashbrown v0.14.3
[INFO] [stderr]    Compiling euclid v0.22.9
[INFO] [stderr]    Compiling spirv v0.2.0+1.5.4
[INFO] [stderr]    Compiling png v0.17.13
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]    Compiling smithay-client-toolkit v0.16.1
[INFO] [stderr]    Compiling gpu-descriptor-types v0.1.2
[INFO] [stderr]    Compiling gpu-alloc-types v0.2.0
[INFO] [stderr]    Compiling encoding_rs v0.8.33
[INFO] [stderr]    Compiling unicode-xid v0.2.4
[INFO] [stderr]    Compiling nix v0.24.3
[INFO] [stderr]    Compiling getrandom v0.2.12
[INFO] [stderr]    Compiling nix v0.25.1
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling parking_lot v0.12.1
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling fastrand v2.0.1
[INFO] [stderr]    Compiling strict-num v0.1.1
[INFO] [stderr]    Compiling zstd-safe v5.0.2+zstd.1.5.2
[INFO] [stderr]    Compiling xcursor v0.3.5
[INFO] [stderr]    Compiling arrayref v0.3.7
[INFO] [stderr]    Compiling hexf-parse v0.2.1
[INFO] [stderr]    Compiling memchr v2.7.1
[INFO] [stderr]    Compiling raw-window-handle v0.5.2
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]    Compiling zstd-sys v2.0.9+zstd.1.5.5
[INFO] [stderr]    Compiling wayland-client v0.29.5
[INFO] [stderr]    Compiling wayland-protocols v0.29.5
[INFO] [stderr]    Compiling bzip2-sys v0.1.11+1.0.8
[INFO] [stderr]    Compiling walkdir v2.4.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling gpu-descriptor v0.2.4
[INFO] [stderr]    Compiling lyon_geom v1.0.5
[INFO] [stderr]    Compiling memmap2 v0.5.10
[INFO] [stderr]    Compiling owned_ttf_parser v0.20.0
[INFO] [stderr]    Compiling lyon_path v1.0.4
[INFO] [stderr]    Compiling ab_glyph v0.2.23
[INFO] [stderr]    Compiling wayland-commons v0.29.5
[INFO] [stderr]    Compiling inotify-sys v0.1.5
[INFO] [stderr]    Compiling gpu-alloc v0.5.4
[INFO] [stderr]    Compiling tempfile v3.10.0
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]    Compiling spin v0.9.8
[INFO] [stderr]    Compiling wgpu-types v0.16.1
[INFO] [stderr]    Compiling tinyvec_macros v0.1.1
[INFO] [stderr]    Compiling renderdoc-sys v1.0.0
[INFO] [stderr]    Compiling glob v0.3.1
[INFO] [stderr]    Compiling glow v0.12.3
[INFO] [stderr]    Compiling bytecount v0.6.7
[INFO] [stderr]    Compiling cpal v0.15.2
[INFO] [stderr]    Compiling weezl v0.1.8
[INFO] [stderr]    Compiling static_assertions v1.1.0
[INFO] [stderr]    Compiling cfg_aliases v0.1.1
[INFO] [stderr]    Compiling profiling v1.0.15
[INFO] [stderr]    Compiling winit v0.28.7
[INFO] [stderr]    Compiling tinyvec v1.6.0
[INFO] [stderr]    Compiling flume v0.11.0
[INFO] [stderr]    Compiling alsa v0.7.1
[INFO] [stderr]    Compiling jpeg-decoder v0.3.1
[INFO] [stderr]    Compiling bytemuck_derive v1.5.0
[INFO] [stderr]    Compiling serde_derive v1.0.197
[INFO] [stderr]    Compiling thiserror-impl v1.0.57
[INFO] [stderr]    Compiling inotify v0.10.2
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling nix v0.27.1
[INFO] [stderr]    Compiling approx v0.5.1
[INFO] [stderr]    Compiling ogg v0.8.0
[INFO] [stderr]    Compiling crossbeam-channel v0.5.11
[INFO] [stderr]    Compiling wayland-cursor v0.29.5
[INFO] [stderr]    Compiling bytemuck v1.14.3
[INFO] [stderr]    Compiling zune-inflate v0.2.54
[INFO] [stderr]    Compiling memoffset v0.8.0
[INFO] [stderr]    Compiling symphonia-core v0.5.3
[INFO] [stderr]    Compiling tiny-skia-path v0.8.4
[INFO] [stderr]    Compiling half v2.3.1
[INFO] [stderr]    Compiling color_quant v1.1.0
[INFO] [stderr]    Compiling option-ext v0.2.0
[INFO] [stderr]    Compiling linked-hash-map v0.5.6
[INFO] [stderr]    Compiling float_next_after v1.0.0
[INFO] [stderr]    Compiling lebe v0.5.2
[INFO] [stderr]    Compiling dasp_sample v0.11.0
[INFO] [stderr]    Compiling xi-unicode v0.3.0
[INFO] [stderr]    Compiling calloop v0.10.6
[INFO] [stderr]    Compiling naga v0.12.3
[INFO] [stderr]    Compiling bit_field v0.10.2
[INFO] [stderr]    Compiling gilrs v0.10.4
[INFO] [stderr]    Compiling uuid v1.7.0
[INFO] [stderr]    Compiling mint v0.5.9
[INFO] [stderr]    Compiling exr v1.72.0
[INFO] [stderr]    Compiling tiny-skia v0.8.4
[INFO] [stderr]    Compiling gilrs-core v0.5.10
[INFO] [stderr]    Compiling glyph_brush_layout v0.2.3
[INFO] [stderr]    Compiling glyph_brush_draw_cache v0.1.5
[INFO] [stderr]    Compiling lyon_tessellation v1.0.13
[INFO] [stderr]    Compiling twox-hash v1.6.3
[INFO] [stderr]    Compiling dirs-sys v0.4.1
[INFO] [stderr]    Compiling symphonia-metadata v0.5.3
[INFO] [stderr]    Compiling gif v0.13.1
[INFO] [stderr]    Compiling qoi v0.4.1
[INFO] [stderr]    Compiling lewton v0.10.2
[INFO] [stderr]    Compiling symphonia-bundle-mp3 v0.5.3
[INFO] [stderr]    Compiling tiff v0.9.1
[INFO] [stderr]    Compiling bzip2 v0.4.4
[INFO] [stderr]    Compiling crevice-derive v0.10.0
[INFO] [stderr]    Compiling lyon_algorithms v1.0.4
[INFO] [stderr]    Compiling mio v0.8.10
[INFO] [stderr]    Compiling symphonia v0.5.3
[INFO] [stderr]    Compiling ordered-float v4.2.0
[INFO] [stderr]    Compiling claxon v0.4.3
[INFO] [stderr]    Compiling hound v3.5.1
[INFO] [stderr]    Compiling lyon v1.0.1
[INFO] [stderr]    Compiling glyph_brush v0.7.8
[INFO] [stderr]    Compiling crevice v0.13.0
[INFO] [stderr]    Compiling rodio v0.17.3
[INFO] [stderr]    Compiling directories v5.0.1
[INFO] [stderr]    Compiling glam v0.24.2
[INFO] [stderr]    Compiling smart-default v0.7.1
[INFO] [stderr]    Compiling ordered-float v3.9.2
[INFO] [stderr]    Compiling pollster v0.3.0
[INFO] [stderr]    Compiling oorandom v11.1.3
[INFO] [stderr]    Compiling image v0.24.9
[INFO] [stderr]    Compiling zstd v0.11.2+zstd.1.5.2
[INFO] [stderr]    Compiling zip v0.6.6
[INFO] [stderr]    Compiling cargo-platform v0.1.7
[INFO] [stderr]    Compiling toml v0.5.11
[INFO] [stderr]    Compiling wgpu-hal v0.16.2
[INFO] [stderr]    Compiling cargo_metadata v0.14.2
[INFO] [stderr]    Compiling skeptic v0.13.7
[INFO] [stderr]    Compiling ggez v0.9.3
[INFO] [stderr]    Compiling wgpu-core v0.16.1
[INFO] [stderr]    Compiling wgpu v0.16.3
[INFO] [stderr]    Compiling sctk-adwaita v0.5.4
[INFO] [stderr]    Compiling Solitaire v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `GameError`
[INFO] [stdout]  --> src/main.rs:5:38
[INFO] [stdout]   |
[INFO] [stdout] 5 | use ggez::{event, graphics, Context, GameError, GameResult};
[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: `std::process::exit`
[INFO] [stdout]  --> src/main.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::process::exit;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `oorandom::Rand32`
[INFO] [stdout]  --> src/structs.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use oorandom::Rand32;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]   --> src/main.rs:66:63
[INFO] [stdout]    |
[INFO] [stdout] 66 |         draw_cards(ctx, &mut self.seventh, &mut canvas, true);;
[INFO] [stdout]    |                                                               ^ help: remove this semicolon
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(redundant_semicolons)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around pattern
[INFO] [stdout]    --> src/main.rs:465:17
[INFO] [stdout]     |
[INFO] [stdout] 465 |                 (_) => println!("{:?} is not yet implemented!", self.current_pile)
[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] 465 -                 (_) => println!("{:?} is not yet implemented!", self.current_pile)
[INFO] [stdout] 465 +                 _ => println!("{:?} is not yet implemented!", self.current_pile)
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `current_pile`
[INFO] [stdout]    --> src/structs.rs:183:37
[INFO] [stdout]     |
[INFO] [stdout] 183 |     pub fn is_aces_valid(&mut self, current_pile: &mut Pile) -> bool{
[INFO] [stdout]     |                                     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_current_pile`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/structs.rs:191:39
[INFO] [stdout]     |
[INFO] [stdout] 191 |     pub fn is_number_valid(&mut self, mut current_pile: &mut Pile) -> bool{
[INFO] [stdout]     |                                       ----^^^^^^^^^^^^
[INFO] [stdout]     |                                       |
[INFO] [stdout]     |                                       help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ctx`
[INFO] [stdout]   --> src/main.rs:47:26
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn update(&mut self, ctx: &mut Context) -> GameResult {
[INFO] [stdout]    |                          ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:331:37
[INFO] [stdout]     |
[INFO] [stdout] 331 | ...                   let mut card: &mut Card = self.deck.cards.first_mut().unwrap();
[INFO] [stdout]     |                           ----^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:346:29
[INFO] [stdout]     |
[INFO] [stdout] 346 |                         let mut card: &mut Card = self.current_cards.as_mut().unwrap().cards.first_mut().unwrap();
[INFO] [stdout]     |                             ----^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dx`
[INFO] [stdout]    --> src/main.rs:478:9
[INFO] [stdout]     |
[INFO] [stdout] 478 |         dx: f32,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 478 |         _dx: f32,
[INFO] [stdout]     |         +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `CARD_IMAGE_SCALE`
[INFO] [stdout]     |
[INFO] [stdout] 478 -         dx: f32,
[INFO] [stdout] 478 +         CARD_IMAGE_SCALE: f32,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dy`
[INFO] [stdout]    --> src/main.rs:479:9
[INFO] [stdout]     |
[INFO] [stdout] 479 |         dy: f32,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 479 |         _dy: f32,
[INFO] [stdout]     |         +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `CARD_IMAGE_SCALE`
[INFO] [stdout]     |
[INFO] [stdout] 479 -         dy: f32,
[INFO] [stdout] 479 +         CARD_IMAGE_SCALE: f32,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:481:13
[INFO] [stdout]     |
[INFO] [stdout] 481 |         let mut current_cards: &mut Option<&mut Pile> = &mut self.current_cards.as_mut();
[INFO] [stdout]     |             ----^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `structs::Color` is more private than the item `Card::color`
[INFO] [stdout]   --> src/structs.rs:53:5
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub color: Color,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ field `Card::color` is reachable at visibility `pub(crate)`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `structs::Color` is only usable at visibility `pub(self)`
[INFO] [stdout]   --> src/structs.rs:22:1
[INFO] [stdout]    |
[INFO] [stdout] 22 | enum Color {
[INFO] [stdout]    | ^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Down` is never constructed
[INFO] [stdout]   --> src/structs.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub enum Direction {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] 10 |     Down,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Direction` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GridPosition` is never constructed
[INFO] [stdout]   --> src/structs.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub struct GridPosition {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `suit` and `rect` are never read
[INFO] [stdout]   --> src/structs.rs:52:9
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub struct Card {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] 51 |     pub num: u8,
[INFO] [stdout] 52 |     pub suit: Suit,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub rect: graphics::Mesh,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Card` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `direction` is never read
[INFO] [stdout]    --> src/structs.rs:134:9
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub struct Pile {
[INFO] [stdout]     |            ---- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 134 |     pub direction: Option<Direction>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Pile` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `on_click` and `shuffle` are never used
[INFO] [stdout]    --> src/structs.rs:148:8
[INFO] [stdout]     |
[INFO] [stdout] 138 | impl Pile {
[INFO] [stdout]     | --------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 148 |     fn on_click(&self, ) {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 152 |     pub fn shuffle(&mut self) {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `screen` and `gameover` are never read
[INFO] [stdout]    --> src/structs.rs:333:9
[INFO] [stdout]     |
[INFO] [stdout] 332 | pub struct GameState<> {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 333 |     pub screen: graphics::ScreenImage,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 348 |     pub gameover: bool,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_mouse_position` and `set_current_pile` are never used
[INFO] [stdout]    --> src/structs.rs:396:12
[INFO] [stdout]     |
[INFO] [stdout] 353 | impl<> GameState<> {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 396 |     pub fn set_mouse_position(&mut self, position: (f32, f32)) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 400 |     pub fn set_current_pile(&mut self, pile: Option<Piles>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 55s
[INFO] running `Command { std: "docker" "inspect" "5f45eed0c7853d57d24abcddad7608dd8ef51b5592408b4f5bbaaa55ac37f2eb", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5f45eed0c7853d57d24abcddad7608dd8ef51b5592408b4f5bbaaa55ac37f2eb", kill_on_drop: false }`
[INFO] [stdout] 5f45eed0c7853d57d24abcddad7608dd8ef51b5592408b4f5bbaaa55ac37f2eb
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f874fdc8d07dcbd1c1c963cc5d8d7474581c86245c9d496324712e02a867eeff
[INFO] running `Command { std: "docker" "start" "-a" "f874fdc8d07dcbd1c1c963cc5d8d7474581c86245c9d496324712e02a867eeff", kill_on_drop: false }`
[INFO] [stderr]    Compiling Solitaire v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `GameError`
[INFO] [stdout]  --> src/main.rs:5:38
[INFO] [stdout]   |
[INFO] [stdout] 5 | use ggez::{event, graphics, Context, GameError, GameResult};
[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: `std::process::exit`
[INFO] [stdout]  --> src/main.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::process::exit;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `oorandom::Rand32`
[INFO] [stdout]  --> src/structs.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use oorandom::Rand32;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]   --> src/main.rs:66:63
[INFO] [stdout]    |
[INFO] [stdout] 66 |         draw_cards(ctx, &mut self.seventh, &mut canvas, true);;
[INFO] [stdout]    |                                                               ^ help: remove this semicolon
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(redundant_semicolons)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around pattern
[INFO] [stdout]    --> src/main.rs:465:17
[INFO] [stdout]     |
[INFO] [stdout] 465 |                 (_) => println!("{:?} is not yet implemented!", self.current_pile)
[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] 465 -                 (_) => println!("{:?} is not yet implemented!", self.current_pile)
[INFO] [stdout] 465 +                 _ => println!("{:?} is not yet implemented!", self.current_pile)
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `current_pile`
[INFO] [stdout]    --> src/structs.rs:183:37
[INFO] [stdout]     |
[INFO] [stdout] 183 |     pub fn is_aces_valid(&mut self, current_pile: &mut Pile) -> bool{
[INFO] [stdout]     |                                     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_current_pile`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/structs.rs:191:39
[INFO] [stdout]     |
[INFO] [stdout] 191 |     pub fn is_number_valid(&mut self, mut current_pile: &mut Pile) -> bool{
[INFO] [stdout]     |                                       ----^^^^^^^^^^^^
[INFO] [stdout]     |                                       |
[INFO] [stdout]     |                                       help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ctx`
[INFO] [stdout]   --> src/main.rs:47:26
[INFO] [stdout]    |
[INFO] [stdout] 47 |     fn update(&mut self, ctx: &mut Context) -> GameResult {
[INFO] [stdout]    |                          ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:331:37
[INFO] [stdout]     |
[INFO] [stdout] 331 | ...                   let mut card: &mut Card = self.deck.cards.first_mut().unwrap();
[INFO] [stdout]     |                           ----^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:346:29
[INFO] [stdout]     |
[INFO] [stdout] 346 |                         let mut card: &mut Card = self.current_cards.as_mut().unwrap().cards.first_mut().unwrap();
[INFO] [stdout]     |                             ----^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dx`
[INFO] [stdout]    --> src/main.rs:478:9
[INFO] [stdout]     |
[INFO] [stdout] 478 |         dx: f32,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 478 |         _dx: f32,
[INFO] [stdout]     |         +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `CARD_IMAGE_SCALE`
[INFO] [stdout]     |
[INFO] [stdout] 478 -         dx: f32,
[INFO] [stdout] 478 +         CARD_IMAGE_SCALE: f32,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dy`
[INFO] [stdout]    --> src/main.rs:479:9
[INFO] [stdout]     |
[INFO] [stdout] 479 |         dy: f32,
[INFO] [stdout]     |         ^^
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 479 |         _dy: f32,
[INFO] [stdout]     |         +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `CARD_IMAGE_SCALE`
[INFO] [stdout]     |
[INFO] [stdout] 479 -         dy: f32,
[INFO] [stdout] 479 +         CARD_IMAGE_SCALE: f32,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:481:13
[INFO] [stdout]     |
[INFO] [stdout] 481 |         let mut current_cards: &mut Option<&mut Pile> = &mut self.current_cards.as_mut();
[INFO] [stdout]     |             ----^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `structs::Color` is more private than the item `Card::color`
[INFO] [stdout]   --> src/structs.rs:53:5
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub color: Color,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^ field `Card::color` is reachable at visibility `pub(crate)`
[INFO] [stdout]    |
[INFO] [stdout] note: but type `structs::Color` is only usable at visibility `pub(self)`
[INFO] [stdout]   --> src/structs.rs:22:1
[INFO] [stdout]    |
[INFO] [stdout] 22 | enum Color {
[INFO] [stdout]    | ^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Down` is never constructed
[INFO] [stdout]   --> src/structs.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub enum Direction {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] 10 |     Down,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Direction` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GridPosition` is never constructed
[INFO] [stdout]   --> src/structs.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub struct GridPosition {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `suit` and `rect` are never read
[INFO] [stdout]   --> src/structs.rs:52:9
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub struct Card {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] 51 |     pub num: u8,
[INFO] [stdout] 52 |     pub suit: Suit,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub rect: graphics::Mesh,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Card` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `direction` is never read
[INFO] [stdout]    --> src/structs.rs:134:9
[INFO] [stdout]     |
[INFO] [stdout] 131 | pub struct Pile {
[INFO] [stdout]     |            ---- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 134 |     pub direction: Option<Direction>,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Pile` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `on_click` and `shuffle` are never used
[INFO] [stdout]    --> src/structs.rs:148:8
[INFO] [stdout]     |
[INFO] [stdout] 138 | impl Pile {
[INFO] [stdout]     | --------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 148 |     fn on_click(&self, ) {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 152 |     pub fn shuffle(&mut self) {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `screen` and `gameover` are never read
[INFO] [stdout]    --> src/structs.rs:333:9
[INFO] [stdout]     |
[INFO] [stdout] 332 | pub struct GameState<> {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 333 |     pub screen: graphics::ScreenImage,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 348 |     pub gameover: bool,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_mouse_position` and `set_current_pile` are never used
[INFO] [stdout]    --> src/structs.rs:396:12
[INFO] [stdout]     |
[INFO] [stdout] 353 | impl<> GameState<> {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 396 |     pub fn set_mouse_position(&mut self, position: (f32, f32)) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 400 |     pub fn set_current_pile(&mut self, pile: Option<Piles>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.38s
[INFO] running `Command { std: "docker" "inspect" "f874fdc8d07dcbd1c1c963cc5d8d7474581c86245c9d496324712e02a867eeff", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f874fdc8d07dcbd1c1c963cc5d8d7474581c86245c9d496324712e02a867eeff", kill_on_drop: false }`
[INFO] [stdout] f874fdc8d07dcbd1c1c963cc5d8d7474581c86245c9d496324712e02a867eeff
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 8fde86c2aa3b0a60d8b428329bf465e6a0ee1218fa5d64494d25f62b382ea22d
[INFO] running `Command { std: "docker" "start" "-a" "8fde86c2aa3b0a60d8b428329bf465e6a0ee1218fa5d64494d25f62b382ea22d", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `GameError`
[INFO] [stderr]  --> src/main.rs:5:38
[INFO] [stderr]   |
[INFO] [stderr] 5 | use ggez::{event, graphics, Context, GameError, GameResult};
[INFO] [stderr]   |                                      ^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::process::exit`
[INFO] [stderr]  --> src/main.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use std::process::exit;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `oorandom::Rand32`
[INFO] [stderr]  --> src/structs.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use oorandom::Rand32;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary trailing semicolon
[INFO] [stderr]   --> src/main.rs:66:63
[INFO] [stderr]    |
[INFO] [stderr] 66 |         draw_cards(ctx, &mut self.seventh, &mut canvas, true);;
[INFO] [stderr]    |                                                               ^ help: remove this semicolon
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(redundant_semicolons)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around pattern
[INFO] [stderr]    --> src/main.rs:465:17
[INFO] [stderr]     |
[INFO] [stderr] 465 |                 (_) => println!("{:?} is not yet implemented!", self.current_pile)
[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] 465 -                 (_) => println!("{:?} is not yet implemented!", self.current_pile)
[INFO] [stderr] 465 +                 _ => println!("{:?} is not yet implemented!", self.current_pile)
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `current_pile`
[INFO] [stderr]    --> src/structs.rs:183:37
[INFO] [stderr]     |
[INFO] [stderr] 183 |     pub fn is_aces_valid(&mut self, current_pile: &mut Pile) -> bool{
[INFO] [stderr]     |                                     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_current_pile`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/structs.rs:191:39
[INFO] [stderr]     |
[INFO] [stderr] 191 |     pub fn is_number_valid(&mut self, mut current_pile: &mut Pile) -> bool{
[INFO] [stderr]     |                                       ----^^^^^^^^^^^^
[INFO] [stderr]     |                                       |
[INFO] [stderr]     |                                       help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `ctx`
[INFO] [stderr]   --> src/main.rs:47:26
[INFO] [stderr]    |
[INFO] [stderr] 47 |     fn update(&mut self, ctx: &mut Context) -> GameResult {
[INFO] [stderr]    |                          ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/main.rs:331:37
[INFO] [stderr]     |
[INFO] [stderr] 331 | ...                   let mut card: &mut Card = self.deck.cards.first_mut().unwrap();
[INFO] [stderr]     |                           ----^^^^
[INFO] [stderr]     |                           |
[INFO] [stderr]     |                           help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/main.rs:346:29
[INFO] [stderr]     |
[INFO] [stderr] 346 |                         let mut card: &mut Card = self.current_cards.as_mut().unwrap().cards.first_mut().unwrap();
[INFO] [stderr]     |                             ----^^^^
[INFO] [stderr]     |                             |
[INFO] [stderr]     |                             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dx`
[INFO] [stderr]    --> src/main.rs:478:9
[INFO] [stderr]     |
[INFO] [stderr] 478 |         dx: f32,
[INFO] [stderr]     |         ^^
[INFO] [stderr]     |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]     |
[INFO] [stderr] 478 |         _dx: f32,
[INFO] [stderr]     |         +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named constant `CARD_IMAGE_SCALE`
[INFO] [stderr]     |
[INFO] [stderr] 478 -         dx: f32,
[INFO] [stderr] 478 +         CARD_IMAGE_SCALE: f32,
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dy`
[INFO] [stderr]    --> src/main.rs:479:9
[INFO] [stderr]     |
[INFO] [stderr] 479 |         dy: f32,
[INFO] [stderr]     |         ^^
[INFO] [stderr]     |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]     |
[INFO] [stderr] 479 |         _dy: f32,
[INFO] [stderr]     |         +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named constant `CARD_IMAGE_SCALE`
[INFO] [stderr]     |
[INFO] [stderr] 479 -         dy: f32,
[INFO] [stderr] 479 +         CARD_IMAGE_SCALE: f32,
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/main.rs:481:13
[INFO] [stderr]     |
[INFO] [stderr] 481 |         let mut current_cards: &mut Option<&mut Pile> = &mut self.current_cards.as_mut();
[INFO] [stderr]     |             ----^^^^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: type `structs::Color` is more private than the item `Card::color`
[INFO] [stderr]   --> src/structs.rs:53:5
[INFO] [stderr]    |
[INFO] [stderr] 53 |     pub color: Color,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^ field `Card::color` is reachable at visibility `pub(crate)`
[INFO] [stderr]    |
[INFO] [stderr] note: but type `structs::Color` is only usable at visibility `pub(self)`
[INFO] [stderr]   --> src/structs.rs:22:1
[INFO] [stderr]    |
[INFO] [stderr] 22 | enum Color {
[INFO] [stderr]    | ^^^^^^^^^^
[INFO] [stderr]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Down` is never constructed
[INFO] [stderr]   --> src/structs.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr]  9 | pub enum Direction {
[INFO] [stderr]    |          --------- variant in this enum
[INFO] [stderr] 10 |     Down,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Direction` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: struct `GridPosition` is never constructed
[INFO] [stderr]   --> src/structs.rs:45:12
[INFO] [stderr]    |
[INFO] [stderr] 45 | pub struct GridPosition {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `suit` and `rect` are never read
[INFO] [stderr]   --> src/structs.rs:52:9
[INFO] [stderr]    |
[INFO] [stderr] 50 | pub struct Card {
[INFO] [stderr]    |            ---- fields in this struct
[INFO] [stderr] 51 |     pub num: u8,
[INFO] [stderr] 52 |     pub suit: Suit,
[INFO] [stderr]    |         ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 57 |     pub rect: graphics::Mesh,
[INFO] [stderr]    |         ^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Card` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `direction` is never read
[INFO] [stderr]    --> src/structs.rs:134:9
[INFO] [stderr]     |
[INFO] [stderr] 131 | pub struct Pile {
[INFO] [stderr]     |            ---- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 134 |     pub direction: Option<Direction>,
[INFO] [stderr]     |         ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `Pile` has derived impls for the traits `Debug` and `Clone`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `on_click` and `shuffle` are never used
[INFO] [stderr]    --> src/structs.rs:148:8
[INFO] [stderr]     |
[INFO] [stderr] 138 | impl Pile {
[INFO] [stderr]     | --------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 148 |     fn on_click(&self, ) {
[INFO] [stderr]     |        ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 152 |     pub fn shuffle(&mut self) {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `screen` and `gameover` are never read
[INFO] [stderr]    --> src/structs.rs:333:9
[INFO] [stderr]     |
[INFO] [stderr] 332 | pub struct GameState<> {
[INFO] [stderr]     |            --------- fields in this struct
[INFO] [stderr] 333 |     pub screen: graphics::ScreenImage,
[INFO] [stderr]     |         ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 348 |     pub gameover: bool,
[INFO] [stderr]     |         ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `set_mouse_position` and `set_current_pile` are never used
[INFO] [stderr]    --> src/structs.rs:396:12
[INFO] [stderr]     |
[INFO] [stderr] 353 | impl<> GameState<> {
[INFO] [stderr]     | ------------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 396 |     pub fn set_mouse_position(&mut self, position: (f32, f32)) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 400 |     pub fn set_current_pile(&mut self, pile: Option<Piles>) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `Solitaire` (bin "Solitaire" test) generated 21 warnings (run `cargo fix --bin "Solitaire" --tests` to apply 10 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.25s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/Solitaire-1d2feaa3e3d7fed4)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "8fde86c2aa3b0a60d8b428329bf465e6a0ee1218fa5d64494d25f62b382ea22d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8fde86c2aa3b0a60d8b428329bf465e6a0ee1218fa5d64494d25f62b382ea22d", kill_on_drop: false }`
[INFO] [stdout] 8fde86c2aa3b0a60d8b428329bf465e6a0ee1218fa5d64494d25f62b382ea22d
