[INFO] cloning repository https://github.com/RonitNath/trains
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/RonitNath/trains" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FRonitNath%2Ftrains", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FRonitNath%2Ftrains'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 8dacb66422419e1ebb7dec746f3612331376001a
[INFO] testing RonitNath/trains against beta-2026-03-05 for beta-1.95-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FRonitNath%2Ftrains" "/workspace/builds/worker-0-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc2/source'...
[INFO] [stderr] done.
[INFO] removed /workspace/builds/worker-0-tc2/source/rust-toolchain.toml
[INFO] started tweaking git repo https://github.com/RonitNath/trains
[INFO] finished tweaking git repo https://github.com/RonitNath/trains
[INFO] tweaked toml for git repo https://github.com/RonitNath/trains written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/RonitNath/trains on toolchain beta-2026-03-05
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/RonitNath/trains 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-2026-03-05" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] f7b4536868fcf140d4d71c418278ff53cb3450324e9800d6520388ed446d5c04
[INFO] running `Command { std: "docker" "start" "-a" "f7b4536868fcf140d4d71c418278ff53cb3450324e9800d6520388ed446d5c04", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "f7b4536868fcf140d4d71c418278ff53cb3450324e9800d6520388ed446d5c04", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f7b4536868fcf140d4d71c418278ff53cb3450324e9800d6520388ed446d5c04", kill_on_drop: false }`
[INFO] [stdout] f7b4536868fcf140d4d71c418278ff53cb3450324e9800d6520388ed446d5c04
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f181fab0e1b91189c8a93c0113e24b73c951d4cba80158bc3bd8166c398053b5
[INFO] running `Command { std: "docker" "start" "-a" "f181fab0e1b91189c8a93c0113e24b73c951d4cba80158bc3bd8166c398053b5", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.66
[INFO] [stderr]    Compiling unicode-ident v1.0.11
[INFO] [stderr]    Compiling libc v0.2.147
[INFO] [stderr]    Compiling serde v1.0.188
[INFO] [stderr]    Compiling once_cell v1.18.0
[INFO] [stderr]    Compiling crossbeam-utils v0.8.16
[INFO] [stderr]    Compiling parking_lot_core v0.9.8
[INFO] [stderr]    Compiling libm v0.2.7
[INFO] [stderr]    Compiling thiserror v1.0.48
[INFO] [stderr]    Compiling lock_api v0.4.10
[INFO] [stderr]    Compiling num-traits v0.2.16
[INFO] [stderr]    Compiling ahash v0.8.3
[INFO] [stderr]    Compiling hashbrown v0.14.0
[INFO] [stderr]    Compiling toml_datetime v0.6.3
[INFO] [stderr]    Compiling pin-project-lite v0.2.13
[INFO] [stderr]    Compiling log v0.4.20
[INFO] [stderr]    Compiling winnow v0.5.15
[INFO] [stderr]    Compiling tracing-core v0.1.31
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]    Compiling futures-core v0.3.28
[INFO] [stderr]    Compiling allocator-api2 v0.2.16
[INFO] [stderr]    Compiling instant v0.1.12
[INFO] [stderr]    Compiling bit-vec v0.6.3
[INFO] [stderr]    Compiling fastrand v1.9.0
[INFO] [stderr]    Compiling downcast-rs v1.2.0
[INFO] [stderr]    Compiling futures-io v0.3.28
[INFO] [stderr]    Compiling parking v2.1.0
[INFO] [stderr]    Compiling bit-set v0.5.3
[INFO] [stderr]    Compiling async-lock v2.8.0
[INFO] [stderr]    Compiling async-task v4.4.0
[INFO] [stderr]    Compiling indexmap v2.0.0
[INFO] [stderr]    Compiling thread_local v1.1.7
[INFO] [stderr]    Compiling smol_str v0.2.0
[INFO] [stderr]    Compiling bevy_ptr v0.11.2
[INFO] [stderr]    Compiling aho-corasick v1.0.5
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]    Compiling concurrent-queue v2.2.0
[INFO] [stderr]    Compiling quote v1.0.33
[INFO] [stderr]    Compiling futures-lite v1.13.0
[INFO] [stderr]    Compiling tracing-log v0.1.3
[INFO] [stderr]    Compiling pkg-config v0.3.27
[INFO] [stderr]    Compiling async-channel v1.9.0
[INFO] [stderr]    Compiling crossbeam-channel v0.5.8
[INFO] [stderr]    Compiling syn v2.0.31
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]    Compiling termcolor v1.2.0
[INFO] [stderr]    Compiling getrandom v0.2.10
[INFO] [stderr]    Compiling pp-rs v0.2.1
[INFO] [stderr]    Compiling miniz_oxide v0.7.1
[INFO] [stderr]    Compiling uuid v1.4.1
[INFO] [stderr]    Compiling codespan-reporting v0.11.1
[INFO] [stderr]    Compiling gpu-descriptor-types v0.1.1
[INFO] [stderr]    Compiling anyhow v1.0.75
[INFO] [stderr]    Compiling walkdir v2.3.3
[INFO] [stderr]    Compiling fdeflate v0.3.0
[INFO] [stderr]    Compiling libloading v0.8.0
[INFO] [stderr]    Compiling mio v0.8.8
[INFO] [stderr]    Compiling inotify-sys v0.1.5
[INFO] [stderr]    Compiling ahash v0.7.6
[INFO] [stderr]    Compiling inotify v0.9.6
[INFO] [stderr]    Compiling sysinfo v0.29.9
[INFO] [stderr]    Compiling khronos-egl v4.1.0
[INFO] [stderr]    Compiling async-executor v1.5.1
[INFO] [stderr]    Compiling flate2 v1.0.27
[INFO] [stderr]    Compiling hashbrown v0.12.3
[INFO] [stderr]    Compiling regex-automata v0.3.8
[INFO] [stderr]    Compiling bevy_tasks v0.11.2
[INFO] [stderr]    Compiling toml_edit v0.19.14
[INFO] [stderr]    Compiling spirv v0.2.0+1.5.4
[INFO] [stderr]    Compiling filetime v0.2.22
[INFO] [stderr]    Compiling thiserror-core v1.0.38
[INFO] [stderr]    Compiling profiling v1.0.10
[INFO] [stderr]    Compiling renderdoc-sys v1.0.0
[INFO] [stderr]    Compiling png v0.17.10
[INFO] [stderr]    Compiling notify v6.1.1
[INFO] [stderr]    Compiling constgebra v0.1.3
[INFO] [stderr]    Compiling data-encoding v2.4.0
[INFO] [stderr]    Compiling approx v0.5.1
[INFO] [stderr]    Compiling nix v0.24.3
[INFO] [stderr]    Compiling percent-encoding v2.3.0
[INFO] [stderr]    Compiling ttf-parser v0.19.1
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling xml-rs v0.8.16
[INFO] [stderr]    Compiling euclid v0.22.9
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling gpu-descriptor v0.2.3
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]    Compiling svg_fmt v0.4.1
[INFO] [stderr]    Compiling serde_json v1.0.105
[INFO] [stderr]    Compiling wayland-scanner v0.29.5
[INFO] [stderr]    Compiling slotmap v1.0.6
[INFO] [stderr]    Compiling guillotiere v0.6.2
[INFO] [stderr]    Compiling itoa v1.0.9
[INFO] [stderr]    Compiling cpal v0.15.2
[INFO] [stderr]    Compiling ryu v1.0.15
[INFO] [stderr]    Compiling accesskit v0.11.2
[INFO] [stderr]    Compiling nix v0.26.4
[INFO] [stderr]    Compiling ogg v0.8.0
[INFO] [stderr]    Compiling gilrs v0.10.2
[INFO] [stderr]    Compiling base64 v0.21.3
[INFO] [stderr]    Compiling lewton v0.10.2
[INFO] [stderr]    Compiling base64 v0.13.1
[INFO] [stderr]    Compiling owned_ttf_parser v0.19.0
[INFO] [stderr]    Compiling bevy_macro_utils v0.11.2
[INFO] [stderr]    Compiling encase_derive_impl v0.6.1
[INFO] [stderr]    Compiling ab_glyph v0.2.21
[INFO] [stderr]    Compiling taffy v0.3.13
[INFO] [stderr]    Compiling matrixmultiply v0.3.7
[INFO] [stderr]    Compiling num-complex v0.4.4
[INFO] [stderr]    Compiling unicode-normalization v0.1.22
[INFO] [stderr]    Compiling winit v0.28.6
[INFO] [stderr]    Compiling glyph_brush_layout v0.2.3
[INFO] [stderr]    Compiling regex v1.9.5
[INFO] [stderr]    Compiling crossbeam-queue v0.3.8
[INFO] [stderr]    Compiling unicode-bidi v0.3.13
[INFO] [stderr]    Compiling thiserror-core-impl v1.0.38
[INFO] [stderr]    Compiling nalgebra-macros v0.2.1
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.15
[INFO] [stderr]    Compiling form_urlencoded v1.2.0
[INFO] [stderr]    Compiling idna v0.4.0
[INFO] [stderr]    Compiling gethostname v0.2.3
[INFO] [stderr]    Compiling optional v0.5.0
[INFO] [stderr]    Compiling num-derive v0.3.3
[INFO] [stderr]    Compiling crossbeam-deque v0.8.3
[INFO] [stderr]    Compiling home v0.5.5
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling pretty-type-name v1.0.1
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling crossbeam v0.8.2
[INFO] [stderr]    Compiling url v2.4.1
[INFO] [stderr]    Compiling ruzstd v0.4.0
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling serde_derive v1.0.188
[INFO] [stderr]    Compiling bytemuck_derive v1.4.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.48
[INFO] [stderr]    Compiling tracing-attributes v0.1.26
[INFO] [stderr]    Compiling bevy_utils_proc_macros v0.11.2
[INFO] [stderr]    Compiling bevy_reflect_derive v0.11.2
[INFO] [stderr]    Compiling bevy_ecs_macros v0.11.2
[INFO] [stderr]    Compiling bevy_derive v0.11.2
[INFO] [stderr]    Compiling encase_derive v0.6.1
[INFO] [stderr]    Compiling bevy_encase_derive v0.11.2
[INFO] [stderr]    Compiling bytemuck v1.13.1
[INFO] [stderr]    Compiling bevy_render_macros v0.11.2
[INFO] [stderr]    Compiling alsa v0.7.1
[INFO] [stderr]    Compiling gltf-derive v1.3.0
[INFO] [stderr]    Compiling accesskit_winit v0.14.4
[INFO] [stderr]    Compiling image v0.24.7
[INFO] [stderr]    Compiling safe_arch v0.7.1
[INFO] [stderr]    Compiling emath v0.22.0
[INFO] [stderr]    Compiling ecolor v0.22.0
[INFO] [stderr]    Compiling x11rb-protocol v0.10.0
[INFO] [stderr]    Compiling webbrowser v0.8.11
[INFO] [stderr]    Compiling bevy-inspector-egui-derive v0.19.0
[INFO] [stderr]    Compiling wide v0.7.11
[INFO] [stderr]    Compiling tracing v0.1.37
[INFO] [stderr]    Compiling naga v0.12.3
[INFO] [stderr]    Compiling simba v0.8.1
[INFO] [stderr]    Compiling x11rb v0.10.1
[INFO] [stderr]    Compiling smallvec v1.11.0
[INFO] [stderr]    Compiling glam v0.24.1
[INFO] [stderr]    Compiling erased-serde v0.3.31
[INFO] [stderr]    Compiling bitflags v2.4.0
[INFO] [stderr]    Compiling ndarray v0.15.6
[INFO] [stderr]    Compiling tracing-subscriber v0.3.17
[INFO] [stderr]    Compiling spade v2.2.0
[INFO] [stderr]    Compiling gilrs-core v0.5.7
[INFO] [stderr]    Compiling naga_oil v0.8.2
[INFO] [stderr]    Compiling wgpu-types v0.16.1
[INFO] [stderr]    Compiling ron v0.8.1
[INFO] [stderr]    Compiling parking_lot v0.12.1
[INFO] [stderr]    Compiling epaint v0.22.0
[INFO] [stderr]    Compiling arboard v3.2.1
[INFO] [stderr]    Compiling petgraph v0.6.4
[INFO] [stderr]    Compiling rodio v0.17.1
[INFO] [stderr]    Compiling gltf-json v1.3.0
[INFO] [stderr]    Compiling wgpu-hal v0.16.2
[INFO] [stderr]    Compiling egui v0.22.0
[INFO] [stderr]    Compiling bevy_utils v0.11.2
[INFO] [stderr]    Compiling bevy_math v0.11.2
[INFO] [stderr]    Compiling bevy_mikktspace v0.11.2
[INFO] [stderr]    Compiling hexasphere v9.1.0
[INFO] [stderr]    Compiling encase v0.6.1
[INFO] [stderr]    Compiling nalgebra v0.32.3
[INFO] [stderr]    Compiling bevy_reflect v0.11.2
[INFO] [stderr]    Compiling gltf v1.3.0
[INFO] [stderr]    Compiling wgpu-core v0.16.1
[INFO] [stderr]    Compiling bevy_ecs v0.11.2
[INFO] [stderr]    Compiling wgpu v0.16.3
[INFO] [stderr]    Compiling parry2d v0.13.5
[INFO] [stderr]    Compiling rapier2d v0.17.2
[INFO] [stderr]    Compiling bevy_app v0.11.2
[INFO] [stderr]    Compiling bevy_log v0.11.2
[INFO] [stderr]    Compiling bevy_core v0.11.2
[INFO] [stderr]    Compiling bevy_time v0.11.2
[INFO] [stderr]    Compiling bevy_input v0.11.2
[INFO] [stderr]    Compiling bevy_a11y v0.11.2
[INFO] [stderr]    Compiling bevy_hierarchy v0.11.2
[INFO] [stderr]    Compiling bevy_diagnostic v0.11.2
[INFO] [stderr]    Compiling bevy_transform v0.11.2
[INFO] [stderr]    Compiling bevy_asset v0.11.2
[INFO] [stderr]    Compiling bevy_window v0.11.2
[INFO] [stderr]    Compiling bevy_gilrs v0.11.2
[INFO] [stderr]    Compiling bevy_audio v0.11.2
[INFO] [stderr]    Compiling bevy_render v0.11.2
[INFO] [stderr]    Compiling bevy_winit v0.11.2
[INFO] [stderr]    Compiling bevy_core_pipeline v0.11.2
[INFO] [stderr]    Compiling bevy_animation v0.11.2
[INFO] [stderr]    Compiling bevy_scene v0.11.2
[INFO] [stderr]    Compiling bevy_sprite v0.11.2
[INFO] [stderr]    Compiling bevy_pbr v0.11.2
[INFO] [stderr]    Compiling bevy_text v0.11.2
[INFO] [stderr]    Compiling bevy_ui v0.11.2
[INFO] [stderr]    Compiling bevy_gltf v0.11.2
[INFO] [stderr]    Compiling bevy_gizmos v0.11.2
[INFO] [stderr]    Compiling bevy_internal v0.11.2
[INFO] [stderr]    Compiling bevy_dylib v0.11.2
[INFO] [stderr]    Compiling bevy v0.11.2
[INFO] [stderr]    Compiling bevy_egui v0.21.0
[INFO] [stderr]    Compiling bevy_rapier2d v0.22.0
[INFO] [stderr]    Compiling bevy_prototype_debug_lines v0.11.1
[INFO] [stderr]    Compiling bevy-inspector-egui v0.19.0
[INFO] [stderr]    Compiling trains v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::f32::consts::PI`
[INFO] [stdout]  --> src/setup.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f32::consts::PI;
[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 imports: `Line`, `PlotPoints`, and `Plot`
[INFO] [stdout]  --> src/setup.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 | use egui::plot::{ Line, Plot, PlotPoints };
[INFO] [stdout]   |                   ^^^^  ^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `mesh::Indices`, `render_resource::PrimitiveTopology`, and `sprite::Mesh2dHandle`
[INFO] [stdout]   --> src/setup.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout] 11 |         render_resource::PrimitiveTopology,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 12 |         mesh::Indices,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 13 |     },
[INFO] [stdout] 14 |     sprite::Mesh2dHandle,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ColliderBuilder` and `Isometry`
[INFO] [stdout]   --> src/setup.rs:24:39
[INFO] [stdout]    |
[INFO] [stdout] 24 | use bevy_rapier2d::rapier::prelude::{ Isometry, ColliderBuilder };
[INFO] [stdout]    |                                       ^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::f32::consts::PI`
[INFO] [stdout]  --> src/prelude.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f32::consts::PI;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `time::Stopwatch`
[INFO] [stdout]  --> src/controls.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy::{ time::Stopwatch };
[INFO] [stdout]   |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::seq::IteratorRandom`
[INFO] [stdout]  --> src/controls.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use rand::seq::IteratorRandom;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::transform::commands`
[INFO] [stdout]  --> src/world/mod.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use bevy::transform::commands;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `logic::body::BodyBundle`
[INFO] [stdout]  --> src/world/mod.rs:3:26
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::{ prelude::*, logic::body::BodyBundle };
[INFO] [stdout]   |                          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `init_assets`
[INFO] [stdout]  --> src/world/base.rs:3:41
[INFO] [stdout]   |
[INFO] [stdout] 3 | use super::{ assets::{ GeneratedAssets, init_assets }, Tag };
[INFO] [stdout]   |                                         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::Rng`
[INFO] [stdout]  --> src/logic/spawning.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use rand::Rng;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Agent` and `Movement`
[INFO] [stdout]  --> src/logic/hud.rs:3:42
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::{ prelude::*, world::agent::{ Agent, S1, Movement, Action, Goal, Missions } };
[INFO] [stdout]   |                                          ^^^^^      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BinaryHeap` and `VecDeque`
[INFO] [stdout]  --> src/logic/sk.rs:1:25
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{ VecDeque, BTreeMap, BinaryHeap };
[INFO] [stdout]   |                         ^^^^^^^^            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::Rng`
[INFO] [stdout]  --> src/main.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use rand::Rng;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rotated_angle`
[INFO] [stdout]    --> src/prelude.rs:168:13
[INFO] [stdout]     |
[INFO] [stdout] 168 |         let rotated_angle = Vec2::Y.angle_between(rotated_dir);
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rotated_angle`
[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/controls.rs:50:13
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let mut r = 0.0;
[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: `r`
[INFO] [stdout]   --> src/controls.rs:50:13
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let mut r = 0.0;
[INFO] [stdout]    |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `pressed` is assigned to, but never used
[INFO] [stdout]   --> src/controls.rs:51:13
[INFO] [stdout]    |
[INFO] [stdout] 51 |         let mut pressed = false;
[INFO] [stdout]    |             ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_pressed` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `pressed` is never read
[INFO] [stdout]   --> src/controls.rs:65:13
[INFO] [stdout]    |
[INFO] [stdout] 65 |             pressed = true;
[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: value assigned to `pressed` is never read
[INFO] [stdout]   --> src/controls.rs:69:13
[INFO] [stdout]    |
[INFO] [stdout] 69 |             pressed = true;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `pressed` is never read
[INFO] [stdout]   --> src/controls.rs:73:13
[INFO] [stdout]    |
[INFO] [stdout] 73 |             pressed = true;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `pressed` is never read
[INFO] [stdout]   --> src/controls.rs:77:13
[INFO] [stdout]    |
[INFO] [stdout] 77 |             pressed = true;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/controls.rs:141:5
[INFO] [stdout]     |
[INFO] [stdout] 141 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/controls.rs:141:5
[INFO] [stdout]     |
[INFO] [stdout] 141 |     mut commands: Commands,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/world/agent.rs:117:5
[INFO] [stdout]     |
[INFO] [stdout] 117 |     mut stage_2: EventWriter<S2>
[INFO] [stdout]     |     ----^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `stage_2`
[INFO] [stdout]    --> src/world/agent.rs:117:5
[INFO] [stdout]     |
[INFO] [stdout] 117 |     mut stage_2: EventWriter<S2>
[INFO] [stdout]     |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stage_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `body`
[INFO] [stdout]    --> src/world/agent.rs:119:34
[INFO] [stdout]     |
[INFO] [stdout] 119 |     for (entity, tf, mut vision, body, agent, sk) in agents.iter_mut() {
[INFO] [stdout]     |                                  ^^^^ help: if this is intentional, prefix it with an underscore: `_body`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `agent`
[INFO] [stdout]    --> src/world/agent.rs:119:40
[INFO] [stdout]     |
[INFO] [stdout] 119 |     for (entity, tf, mut vision, body, agent, sk) in agents.iter_mut() {
[INFO] [stdout]     |                                        ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: you might have meant to pattern match on the similarly named struct `Agent`
[INFO] [stdout]     |
[INFO] [stdout] 119 -     for (entity, tf, mut vision, body, agent, sk) in agents.iter_mut() {
[INFO] [stdout] 119 +     for (entity, tf, mut vision, body, world::agent::Agent, sk) in agents.iter_mut() {
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 119 |     for (entity, tf, mut vision, body, _agent, sk) in agents.iter_mut() {
[INFO] [stdout]     |                                        +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `agent`
[INFO] [stdout]    --> src/world/agent.rs:173:23
[INFO] [stdout]     |
[INFO] [stdout] 173 |     for (e, tf, body, agent, stamina, goal, sk) in agents.iter() {
[INFO] [stdout]     |                       ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: you might have meant to pattern match on the similarly named struct `Agent`
[INFO] [stdout]     |
[INFO] [stdout] 173 -     for (e, tf, body, agent, stamina, goal, sk) in agents.iter() {
[INFO] [stdout] 173 +     for (e, tf, body, world::agent::Agent, stamina, goal, sk) in agents.iter() {
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 173 |     for (e, tf, body, _agent, stamina, goal, sk) in agents.iter() {
[INFO] [stdout]     |                       +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `stamina`
[INFO] [stdout]    --> src/world/agent.rs:173:30
[INFO] [stdout]     |
[INFO] [stdout] 173 |     for (e, tf, body, agent, stamina, goal, sk) in agents.iter() {
[INFO] [stdout]     |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stamina`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `acolor`
[INFO] [stdout]    --> src/world/agent.rs:409:14
[INFO] [stdout]     |
[INFO] [stdout] 409 |         let (acolor, amaterial) = assets.colors.get(&format!("A{}", color)).unwrap();
[INFO] [stdout]     |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_acolor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `acolor`
[INFO] [stdout]   --> src/world/base.rs:42:14
[INFO] [stdout]    |
[INFO] [stdout] 42 |         let (acolor, amaterial) = assets.colors.get(&format!("A{}", color)).unwrap();
[INFO] [stdout]    |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_acolor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/world/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     mut meshes: ResMut<Assets<Mesh>>,
[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/world/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     mut materials: ResMut<Assets<ColorMaterial>>,
[INFO] [stdout]    |     ----^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `meshes`
[INFO] [stdout]   --> src/world/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     mut meshes: ResMut<Assets<Mesh>>,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_meshes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `materials`
[INFO] [stdout]   --> src/world/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     mut materials: ResMut<Assets<ColorMaterial>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_materials`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/logic/spawning.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout] 10 |     let mut filter = QueryFilter::default();
[INFO] [stdout]    |         ----^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ix`
[INFO] [stdout]   --> src/logic/spawning.rs:14:77
[INFO] [stdout]    |
[INFO] [stdout] 14 |     rc.intersections_with_shape(pos, rot, &Collider::ball(radius), filter, |ix| {
[INFO] [stdout]    |                                                                             ^^ help: if this is intentional, prefix it with an underscore: `_ix`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]   --> src/logic/hud.rs:97:44
[INFO] [stdout]    |
[INFO] [stdout] 97 | ...                   let (path, b) = sk.path(my_pos, *pos);
[INFO] [stdout]    |                                  ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `goal`
[INFO] [stdout]    --> src/logic/hud.rs:117:40
[INFO] [stdout]     |
[INFO] [stdout] 117 |                         if let Ok((sk, goal, tf)) = info.get(e) {
[INFO] [stdout]     |                                        ^^^^ help: if this is intentional, prefix it with an underscore: `_goal`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `my_pos`
[INFO] [stdout]    --> src/logic/hud.rs:118:33
[INFO] [stdout]     |
[INFO] [stdout] 118 | ...                   let my_pos = tf.translation.truncate();
[INFO] [stdout]     |                           ^^^^^^ help: if this is intentional, prefix it with an underscore: `_my_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `spawn_more` is never read
[INFO] [stdout]   --> src/setup.rs:55:9
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub struct GameControl {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] 55 |     pub spawn_more: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: path statement with no effect
[INFO] [stdout]  --> src/world/base.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 |         app;
[INFO] [stdout]   |         ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(path_statements)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 37s
[INFO] running `Command { std: "docker" "inspect" "f181fab0e1b91189c8a93c0113e24b73c951d4cba80158bc3bd8166c398053b5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f181fab0e1b91189c8a93c0113e24b73c951d4cba80158bc3bd8166c398053b5", kill_on_drop: false }`
[INFO] [stdout] f181fab0e1b91189c8a93c0113e24b73c951d4cba80158bc3bd8166c398053b5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 970343a9253ca3a037434113e394fa3c928b567f64597973663f40c277690b37
[INFO] running `Command { std: "docker" "start" "-a" "970343a9253ca3a037434113e394fa3c928b567f64597973663f40c277690b37", kill_on_drop: false }`
[INFO] [stderr]    Compiling trains v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::f32::consts::PI`
[INFO] [stdout]  --> src/setup.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f32::consts::PI;
[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 imports: `Line`, `PlotPoints`, and `Plot`
[INFO] [stdout]  --> src/setup.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 | use egui::plot::{ Line, Plot, PlotPoints };
[INFO] [stdout]   |                   ^^^^  ^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `mesh::Indices`, `render_resource::PrimitiveTopology`, and `sprite::Mesh2dHandle`
[INFO] [stdout]   --> src/setup.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout] 11 |         render_resource::PrimitiveTopology,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 12 |         mesh::Indices,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 13 |     },
[INFO] [stdout] 14 |     sprite::Mesh2dHandle,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ColliderBuilder` and `Isometry`
[INFO] [stdout]   --> src/setup.rs:24:39
[INFO] [stdout]    |
[INFO] [stdout] 24 | use bevy_rapier2d::rapier::prelude::{ Isometry, ColliderBuilder };
[INFO] [stdout]    |                                       ^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::f32::consts::PI`
[INFO] [stdout]  --> src/prelude.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f32::consts::PI;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `time::Stopwatch`
[INFO] [stdout]  --> src/controls.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy::{ time::Stopwatch };
[INFO] [stdout]   |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::seq::IteratorRandom`
[INFO] [stdout]  --> src/controls.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use rand::seq::IteratorRandom;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::transform::commands`
[INFO] [stdout]  --> src/world/mod.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use bevy::transform::commands;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `logic::body::BodyBundle`
[INFO] [stdout]  --> src/world/mod.rs:3:26
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::{ prelude::*, logic::body::BodyBundle };
[INFO] [stdout]   |                          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `init_assets`
[INFO] [stdout]  --> src/world/base.rs:3:41
[INFO] [stdout]   |
[INFO] [stdout] 3 | use super::{ assets::{ GeneratedAssets, init_assets }, Tag };
[INFO] [stdout]   |                                         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::Rng`
[INFO] [stdout]  --> src/logic/spawning.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use rand::Rng;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Agent` and `Movement`
[INFO] [stdout]  --> src/logic/hud.rs:3:42
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::{ prelude::*, world::agent::{ Agent, S1, Movement, Action, Goal, Missions } };
[INFO] [stdout]   |                                          ^^^^^      ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BinaryHeap` and `VecDeque`
[INFO] [stdout]  --> src/logic/sk.rs:1:25
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{ VecDeque, BTreeMap, BinaryHeap };
[INFO] [stdout]   |                         ^^^^^^^^            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rotated_angle`
[INFO] [stdout]    --> src/prelude.rs:168:13
[INFO] [stdout]     |
[INFO] [stdout] 168 |         let rotated_angle = Vec2::Y.angle_between(rotated_dir);
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rotated_angle`
[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/controls.rs:50:13
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let mut r = 0.0;
[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: `r`
[INFO] [stdout]   --> src/controls.rs:50:13
[INFO] [stdout]    |
[INFO] [stdout] 50 |         let mut r = 0.0;
[INFO] [stdout]    |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `pressed` is assigned to, but never used
[INFO] [stdout]   --> src/controls.rs:51:13
[INFO] [stdout]    |
[INFO] [stdout] 51 |         let mut pressed = false;
[INFO] [stdout]    |             ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_pressed` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `pressed` is never read
[INFO] [stdout]   --> src/controls.rs:65:13
[INFO] [stdout]    |
[INFO] [stdout] 65 |             pressed = true;
[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: value assigned to `pressed` is never read
[INFO] [stdout]   --> src/controls.rs:69:13
[INFO] [stdout]    |
[INFO] [stdout] 69 |             pressed = true;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `pressed` is never read
[INFO] [stdout]   --> src/controls.rs:73:13
[INFO] [stdout]    |
[INFO] [stdout] 73 |             pressed = true;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `pressed` is never read
[INFO] [stdout]   --> src/controls.rs:77:13
[INFO] [stdout]    |
[INFO] [stdout] 77 |             pressed = true;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/controls.rs:141:5
[INFO] [stdout]     |
[INFO] [stdout] 141 |     mut commands: Commands,
[INFO] [stdout]     |     ----^^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/controls.rs:141:5
[INFO] [stdout]     |
[INFO] [stdout] 141 |     mut commands: Commands,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/world/agent.rs:117:5
[INFO] [stdout]     |
[INFO] [stdout] 117 |     mut stage_2: EventWriter<S2>
[INFO] [stdout]     |     ----^^^^^^^
[INFO] [stdout]     |     |
[INFO] [stdout]     |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `stage_2`
[INFO] [stdout]    --> src/world/agent.rs:117:5
[INFO] [stdout]     |
[INFO] [stdout] 117 |     mut stage_2: EventWriter<S2>
[INFO] [stdout]     |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stage_2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `body`
[INFO] [stdout]    --> src/world/agent.rs:119:34
[INFO] [stdout]     |
[INFO] [stdout] 119 |     for (entity, tf, mut vision, body, agent, sk) in agents.iter_mut() {
[INFO] [stdout]     |                                  ^^^^ help: if this is intentional, prefix it with an underscore: `_body`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `agent`
[INFO] [stdout]    --> src/world/agent.rs:119:40
[INFO] [stdout]     |
[INFO] [stdout] 119 |     for (entity, tf, mut vision, body, agent, sk) in agents.iter_mut() {
[INFO] [stdout]     |                                        ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: you might have meant to pattern match on the similarly named struct `Agent`
[INFO] [stdout]     |
[INFO] [stdout] 119 -     for (entity, tf, mut vision, body, agent, sk) in agents.iter_mut() {
[INFO] [stdout] 119 +     for (entity, tf, mut vision, body, world::agent::Agent, sk) in agents.iter_mut() {
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 119 |     for (entity, tf, mut vision, body, _agent, sk) in agents.iter_mut() {
[INFO] [stdout]     |                                        +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `agent`
[INFO] [stdout]    --> src/world/agent.rs:173:23
[INFO] [stdout]     |
[INFO] [stdout] 173 |     for (e, tf, body, agent, stamina, goal, sk) in agents.iter() {
[INFO] [stdout]     |                       ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: you might have meant to pattern match on the similarly named struct `Agent`
[INFO] [stdout]     |
[INFO] [stdout] 173 -     for (e, tf, body, agent, stamina, goal, sk) in agents.iter() {
[INFO] [stdout] 173 +     for (e, tf, body, world::agent::Agent, stamina, goal, sk) in agents.iter() {
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 173 |     for (e, tf, body, _agent, stamina, goal, sk) in agents.iter() {
[INFO] [stdout]     |                       +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `stamina`
[INFO] [stdout]    --> src/world/agent.rs:173:30
[INFO] [stdout]     |
[INFO] [stdout] 173 |     for (e, tf, body, agent, stamina, goal, sk) in agents.iter() {
[INFO] [stdout]     |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stamina`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `acolor`
[INFO] [stdout]    --> src/world/agent.rs:409:14
[INFO] [stdout]     |
[INFO] [stdout] 409 |         let (acolor, amaterial) = assets.colors.get(&format!("A{}", color)).unwrap();
[INFO] [stdout]     |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_acolor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `acolor`
[INFO] [stdout]   --> src/world/base.rs:42:14
[INFO] [stdout]    |
[INFO] [stdout] 42 |         let (acolor, amaterial) = assets.colors.get(&format!("A{}", color)).unwrap();
[INFO] [stdout]    |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_acolor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/world/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     mut meshes: ResMut<Assets<Mesh>>,
[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/world/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     mut materials: ResMut<Assets<ColorMaterial>>,
[INFO] [stdout]    |     ----^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `meshes`
[INFO] [stdout]   --> src/world/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     mut meshes: ResMut<Assets<Mesh>>,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_meshes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `materials`
[INFO] [stdout]   --> src/world/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     mut materials: ResMut<Assets<ColorMaterial>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_materials`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/logic/spawning.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout] 10 |     let mut filter = QueryFilter::default();
[INFO] [stdout]    |         ----^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ix`
[INFO] [stdout]   --> src/logic/spawning.rs:14:77
[INFO] [stdout]    |
[INFO] [stdout] 14 |     rc.intersections_with_shape(pos, rot, &Collider::ball(radius), filter, |ix| {
[INFO] [stdout]    |                                                                             ^^ help: if this is intentional, prefix it with an underscore: `_ix`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]   --> src/logic/hud.rs:97:44
[INFO] [stdout]    |
[INFO] [stdout] 97 | ...                   let (path, b) = sk.path(my_pos, *pos);
[INFO] [stdout]    |                                  ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `goal`
[INFO] [stdout]    --> src/logic/hud.rs:117:40
[INFO] [stdout]     |
[INFO] [stdout] 117 |                         if let Ok((sk, goal, tf)) = info.get(e) {
[INFO] [stdout]     |                                        ^^^^ help: if this is intentional, prefix it with an underscore: `_goal`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `my_pos`
[INFO] [stdout]    --> src/logic/hud.rs:118:33
[INFO] [stdout]     |
[INFO] [stdout] 118 | ...                   let my_pos = tf.translation.truncate();
[INFO] [stdout]     |                           ^^^^^^ help: if this is intentional, prefix it with an underscore: `_my_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `spawn_more` is never read
[INFO] [stdout]   --> src/setup.rs:55:9
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub struct GameControl {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] 55 |     pub spawn_more: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: path statement with no effect
[INFO] [stdout]  --> src/world/base.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 |         app;
[INFO] [stdout]   |         ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(path_statements)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.81s
[INFO] running `Command { std: "docker" "inspect" "970343a9253ca3a037434113e394fa3c928b567f64597973663f40c277690b37", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "970343a9253ca3a037434113e394fa3c928b567f64597973663f40c277690b37", kill_on_drop: false }`
[INFO] [stdout] 970343a9253ca3a037434113e394fa3c928b567f64597973663f40c277690b37
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2026-03-05" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 0a2b9826fa53b8be20899c36ebeded5469f95dccf0dbc60efaeb0b799bdd627e
[INFO] running `Command { std: "docker" "start" "-a" "0a2b9826fa53b8be20899c36ebeded5469f95dccf0dbc60efaeb0b799bdd627e", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `std::f32::consts::PI`
[INFO] [stderr]  --> src/setup.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::f32::consts::PI;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Line`, `PlotPoints`, and `Plot`
[INFO] [stderr]  --> src/setup.rs:3:19
[INFO] [stderr]   |
[INFO] [stderr] 3 | use egui::plot::{ Line, Plot, PlotPoints };
[INFO] [stderr]   |                   ^^^^  ^^^^  ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `mesh::Indices`, `render_resource::PrimitiveTopology`, and `sprite::Mesh2dHandle`
[INFO] [stderr]   --> src/setup.rs:11:9
[INFO] [stderr]    |
[INFO] [stderr] 11 |         render_resource::PrimitiveTopology,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 12 |         mesh::Indices,
[INFO] [stderr]    |         ^^^^^^^^^^^^^
[INFO] [stderr] 13 |     },
[INFO] [stderr] 14 |     sprite::Mesh2dHandle,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `ColliderBuilder` and `Isometry`
[INFO] [stderr]   --> src/setup.rs:24:39
[INFO] [stderr]    |
[INFO] [stderr] 24 | use bevy_rapier2d::rapier::prelude::{ Isometry, ColliderBuilder };
[INFO] [stderr]    |                                       ^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::f32::consts::PI`
[INFO] [stderr]  --> src/prelude.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::f32::consts::PI;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `time::Stopwatch`
[INFO] [stderr]  --> src/controls.rs:3:13
[INFO] [stderr]   |
[INFO] [stderr] 3 | use bevy::{ time::Stopwatch };
[INFO] [stderr]   |             ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::seq::IteratorRandom`
[INFO] [stderr]  --> src/controls.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use rand::seq::IteratorRandom;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `bevy::transform::commands`
[INFO] [stderr]  --> src/world/mod.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use bevy::transform::commands;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `logic::body::BodyBundle`
[INFO] [stderr]  --> src/world/mod.rs:3:26
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::{ prelude::*, logic::body::BodyBundle };
[INFO] [stderr]   |                          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `init_assets`
[INFO] [stderr]  --> src/world/base.rs:3:41
[INFO] [stderr]   |
[INFO] [stderr] 3 | use super::{ assets::{ GeneratedAssets, init_assets }, Tag };
[INFO] [stderr]   |                                         ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::Rng`
[INFO] [stderr]  --> src/logic/spawning.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use rand::Rng;
[INFO] [stderr]   |     ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Agent` and `Movement`
[INFO] [stderr]  --> src/logic/hud.rs:3:42
[INFO] [stderr]   |
[INFO] [stderr] 3 | use crate::{ prelude::*, world::agent::{ Agent, S1, Movement, Action, Goal, Missions } };
[INFO] [stderr]   |                                          ^^^^^      ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `BinaryHeap` and `VecDeque`
[INFO] [stderr]  --> src/logic/sk.rs:1:25
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::collections::{ VecDeque, BTreeMap, BinaryHeap };
[INFO] [stderr]   |                         ^^^^^^^^            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rotated_angle`
[INFO] [stderr]    --> src/prelude.rs:168:13
[INFO] [stderr]     |
[INFO] [stderr] 168 |         let rotated_angle = Vec2::Y.angle_between(rotated_dir);
[INFO] [stderr]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rotated_angle`
[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/controls.rs:50:13
[INFO] [stderr]    |
[INFO] [stderr] 50 |         let mut r = 0.0;
[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: `r`
[INFO] [stderr]   --> src/controls.rs:50:13
[INFO] [stderr]    |
[INFO] [stderr] 50 |         let mut r = 0.0;
[INFO] [stderr]    |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `pressed` is assigned to, but never used
[INFO] [stderr]   --> src/controls.rs:51:13
[INFO] [stderr]    |
[INFO] [stderr] 51 |         let mut pressed = false;
[INFO] [stderr]    |             ^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: consider using `_pressed` instead
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `pressed` is never read
[INFO] [stderr]   --> src/controls.rs:65:13
[INFO] [stderr]    |
[INFO] [stderr] 65 |             pressed = true;
[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: value assigned to `pressed` is never read
[INFO] [stderr]   --> src/controls.rs:69:13
[INFO] [stderr]    |
[INFO] [stderr] 69 |             pressed = true;
[INFO] [stderr]    |             ^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `pressed` is never read
[INFO] [stderr]   --> src/controls.rs:73:13
[INFO] [stderr]    |
[INFO] [stderr] 73 |             pressed = true;
[INFO] [stderr]    |             ^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `pressed` is never read
[INFO] [stderr]   --> src/controls.rs:77:13
[INFO] [stderr]    |
[INFO] [stderr] 77 |             pressed = true;
[INFO] [stderr]    |             ^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/controls.rs:141:5
[INFO] [stderr]     |
[INFO] [stderr] 141 |     mut commands: Commands,
[INFO] [stderr]     |     ----^^^^^^^^
[INFO] [stderr]     |     |
[INFO] [stderr]     |     help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `commands`
[INFO] [stderr]    --> src/controls.rs:141:5
[INFO] [stderr]     |
[INFO] [stderr] 141 |     mut commands: Commands,
[INFO] [stderr]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/world/agent.rs:117:5
[INFO] [stderr]     |
[INFO] [stderr] 117 |     mut stage_2: EventWriter<S2>
[INFO] [stderr]     |     ----^^^^^^^
[INFO] [stderr]     |     |
[INFO] [stderr]     |     help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `stage_2`
[INFO] [stderr]    --> src/world/agent.rs:117:5
[INFO] [stderr]     |
[INFO] [stderr] 117 |     mut stage_2: EventWriter<S2>
[INFO] [stderr]     |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stage_2`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `body`
[INFO] [stderr]    --> src/world/agent.rs:119:34
[INFO] [stderr]     |
[INFO] [stderr] 119 |     for (entity, tf, mut vision, body, agent, sk) in agents.iter_mut() {
[INFO] [stderr]     |                                  ^^^^ help: if this is intentional, prefix it with an underscore: `_body`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `agent`
[INFO] [stderr]    --> src/world/agent.rs:119:40
[INFO] [stderr]     |
[INFO] [stderr] 119 |     for (entity, tf, mut vision, body, agent, sk) in agents.iter_mut() {
[INFO] [stderr]     |                                        ^^^^^
[INFO] [stderr]     |
[INFO] [stderr] help: you might have meant to pattern match on the similarly named struct `Agent`
[INFO] [stderr]     |
[INFO] [stderr] 119 -     for (entity, tf, mut vision, body, agent, sk) in agents.iter_mut() {
[INFO] [stderr] 119 +     for (entity, tf, mut vision, body, world::agent::Agent, sk) in agents.iter_mut() {
[INFO] [stderr]     |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]     |
[INFO] [stderr] 119 |     for (entity, tf, mut vision, body, _agent, sk) in agents.iter_mut() {
[INFO] [stderr]     |                                        +
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `agent`
[INFO] [stderr]    --> src/world/agent.rs:173:23
[INFO] [stderr]     |
[INFO] [stderr] 173 |     for (e, tf, body, agent, stamina, goal, sk) in agents.iter() {
[INFO] [stderr]     |                       ^^^^^
[INFO] [stderr]     |
[INFO] [stderr] help: you might have meant to pattern match on the similarly named struct `Agent`
[INFO] [stderr]     |
[INFO] [stderr] 173 -     for (e, tf, body, agent, stamina, goal, sk) in agents.iter() {
[INFO] [stderr] 173 +     for (e, tf, body, world::agent::Agent, stamina, goal, sk) in agents.iter() {
[INFO] [stderr]     |
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]     |
[INFO] [stderr] 173 |     for (e, tf, body, _agent, stamina, goal, sk) in agents.iter() {
[INFO] [stderr]     |                       +
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `stamina`
[INFO] [stderr]    --> src/world/agent.rs:173:30
[INFO] [stderr]     |
[INFO] [stderr] 173 |     for (e, tf, body, agent, stamina, goal, sk) in agents.iter() {
[INFO] [stderr]     |                              ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_stamina`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `acolor`
[INFO] [stderr]    --> src/world/agent.rs:409:14
[INFO] [stderr]     |
[INFO] [stderr] 409 |         let (acolor, amaterial) = assets.colors.get(&format!("A{}", color)).unwrap();
[INFO] [stderr]     |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_acolor`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `acolor`
[INFO] [stderr]   --> src/world/base.rs:42:14
[INFO] [stderr]    |
[INFO] [stderr] 42 |         let (acolor, amaterial) = assets.colors.get(&format!("A{}", color)).unwrap();
[INFO] [stderr]    |              ^^^^^^ help: if this is intentional, prefix it with an underscore: `_acolor`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/world/mod.rs:24:5
[INFO] [stderr]    |
[INFO] [stderr] 24 |     mut meshes: ResMut<Assets<Mesh>>,
[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/world/mod.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 |     mut materials: ResMut<Assets<ColorMaterial>>,
[INFO] [stderr]    |     ----^^^^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `meshes`
[INFO] [stderr]   --> src/world/mod.rs:24:5
[INFO] [stderr]    |
[INFO] [stderr] 24 |     mut meshes: ResMut<Assets<Mesh>>,
[INFO] [stderr]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_meshes`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `materials`
[INFO] [stderr]   --> src/world/mod.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 |     mut materials: ResMut<Assets<ColorMaterial>>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_materials`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/logic/spawning.rs:10:9
[INFO] [stderr]    |
[INFO] [stderr] 10 |     let mut filter = QueryFilter::default();
[INFO] [stderr]    |         ----^^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `ix`
[INFO] [stderr]   --> src/logic/spawning.rs:14:77
[INFO] [stderr]    |
[INFO] [stderr] 14 |     rc.intersections_with_shape(pos, rot, &Collider::ball(radius), filter, |ix| {
[INFO] [stderr]    |                                                                             ^^ help: if this is intentional, prefix it with an underscore: `_ix`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `b`
[INFO] [stderr]   --> src/logic/hud.rs:97:44
[INFO] [stderr]    |
[INFO] [stderr] 97 | ...                   let (path, b) = sk.path(my_pos, *pos);
[INFO] [stderr]    |                                  ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `goal`
[INFO] [stderr]    --> src/logic/hud.rs:117:40
[INFO] [stderr]     |
[INFO] [stderr] 117 |                         if let Ok((sk, goal, tf)) = info.get(e) {
[INFO] [stderr]     |                                        ^^^^ help: if this is intentional, prefix it with an underscore: `_goal`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `my_pos`
[INFO] [stderr]    --> src/logic/hud.rs:118:33
[INFO] [stderr]     |
[INFO] [stderr] 118 | ...                   let my_pos = tf.translation.truncate();
[INFO] [stderr]     |                           ^^^^^^ help: if this is intentional, prefix it with an underscore: `_my_pos`
[INFO] [stderr] 
[INFO] [stderr] warning: field `spawn_more` is never read
[INFO] [stderr]   --> src/setup.rs:55:9
[INFO] [stderr]    |
[INFO] [stderr] 54 | pub struct GameControl {
[INFO] [stderr]    |            ----------- field in this struct
[INFO] [stderr] 55 |     pub spawn_more: bool,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: path statement with no effect
[INFO] [stderr]  --> src/world/base.rs:9:9
[INFO] [stderr]   |
[INFO] [stderr] 9 |         app;
[INFO] [stderr]   |         ^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(path_statements)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `trains` (bin "trains" test) generated 42 warnings (run `cargo fix --bin "trains" -p trains --tests` to apply 35 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/trains-69dfd236fffd490e)
[INFO] [stdout] 
[INFO] [stdout] running 4 tests
[INFO] [stdout] test prelude::test_distance ... ok
[INFO] [stdout] test prelude::test_sig ... ok
[INFO] [stdout] test dice ... ok
[INFO] [stdout] test logic::sk::test_path ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "0a2b9826fa53b8be20899c36ebeded5469f95dccf0dbc60efaeb0b799bdd627e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0a2b9826fa53b8be20899c36ebeded5469f95dccf0dbc60efaeb0b799bdd627e", kill_on_drop: false }`
[INFO] [stdout] 0a2b9826fa53b8be20899c36ebeded5469f95dccf0dbc60efaeb0b799bdd627e
