[INFO] cloning repository https://github.com/zzhgithub/9tcg-2d
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/zzhgithub/9tcg-2d" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fzzhgithub%2F9tcg-2d", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fzzhgithub%2F9tcg-2d'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 276e9ffe75f4ad07605325d11a5bedc050a14b45
[INFO] checking zzhgithub/9tcg-2d against master#fcac501a73cdde54de46a0683567f1a890730555 for pr-151102
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fzzhgithub%2F9tcg-2d" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/zzhgithub/9tcg-2d
[INFO] finished tweaking git repo https://github.com/zzhgithub/9tcg-2d
[INFO] tweaked toml for git repo https://github.com/zzhgithub/9tcg-2d written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/zzhgithub/9tcg-2d on toolchain fcac501a73cdde54de46a0683567f1a890730555
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+fcac501a73cdde54de46a0683567f1a890730555" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/zzhgithub/9tcg-2d 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" "+fcac501a73cdde54de46a0683567f1a890730555" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded bevy_utils v0.15.0
[INFO] [stderr]   Downloaded bevy_internal v0.15.0
[INFO] [stderr]   Downloaded bevy_log v0.15.0
[INFO] [stderr]   Downloaded bevy_gilrs v0.15.0
[INFO] [stderr]   Downloaded bevy_window v0.15.0
[INFO] [stderr]   Downloaded bevy_winit v0.15.0
[INFO] [stderr]   Downloaded wayland-protocols-wlr v0.3.5
[INFO] [stderr]   Downloaded bevy_state_macros v0.15.0
[INFO] [stderr]   Downloaded bevy_state v0.15.0
[INFO] [stderr]   Downloaded bevy_time v0.15.0
[INFO] [stderr]   Downloaded bevy_eventwork v0.10.0
[INFO] [stderr]   Downloaded bevy_diagnostic v0.15.0
[INFO] [stderr]   Downloaded bevy-inspector-egui-derive v0.28.0
[INFO] [stderr]   Downloaded arboard v3.4.1
[INFO] [stderr]   Downloaded bevy-persistent v0.7.0
[INFO] [stderr]   Downloaded bevy_animation v0.15.0
[INFO] [stderr]   Downloaded bevy_sprite v0.15.0
[INFO] [stderr]   Downloaded bevy_render v0.15.0
[INFO] [stderr]   Downloaded bevy_simple_text_input v0.10.1
[INFO] [stderr]   Downloaded bevy_kira_audio v0.22.0
[INFO] [stderr]   Downloaded epaint v0.29.1
[INFO] [stderr]   Downloaded bevy-inspector-egui v0.28.0
[INFO] [stderr]   Downloaded bevy_math v0.15.0
[INFO] [stderr]   Downloaded bevy_ecs v0.15.0
[INFO] [stderr]   Downloaded bevy_pbr v0.15.0
[INFO] [stderr]   Downloaded bevy v0.15.0
[INFO] [stderr]   Downloaded bevy_ui v0.15.0
[INFO] [stderr]   Downloaded bevy_gizmos v0.15.0
[INFO] [stderr]   Downloaded bevy_gltf v0.15.0
[INFO] [stderr]   Downloaded bevy_egui v0.31.1
[INFO] [stderr]   Downloaded bevy_reflect v0.15.0
[INFO] [stderr]   Downloaded bevy_asset v0.15.0
[INFO] [stderr]   Downloaded bevy_app v0.15.0
[INFO] [stderr]   Downloaded bevy_ecs_macros v0.15.0
[INFO] [stderr]   Downloaded bevy_reflect_derive v0.15.0
[INFO] [stderr]   Downloaded emath v0.29.1
[INFO] [stderr]   Downloaded bevy_scene v0.15.0
[INFO] [stderr]   Downloaded read-fonts v0.22.5
[INFO] [stderr]   Downloaded egui v0.29.1
[INFO] [stderr]   Downloaded bevy_picking v0.15.0
[INFO] [stderr]   Downloaded bevy_mikktspace v0.15.0
[INFO] [stderr]   Downloaded hexasphere v15.0.0
[INFO] [stderr]   Downloaded bevy_transform v0.15.0
[INFO] [stderr]   Downloaded bevy_asset_macros v0.15.0
[INFO] [stderr]   Downloaded bevy_color v0.15.1
[INFO] [stderr]   Downloaded bevy_macro_utils v0.15.0
[INFO] [stderr]   Downloaded ecolor v0.29.1
[INFO] [stderr]   Downloaded bevy_gizmos_macros v0.15.0
[INFO] [stderr]   Downloaded bevy_encase_derive v0.15.0
[INFO] [stderr]   Downloaded bevy_image v0.15.0
[INFO] [stderr]   Downloaded bevy_render_macros v0.15.0
[INFO] [stderr]   Downloaded bevy_hierarchy v0.15.0
[INFO] [stderr]   Downloaded bevy_core v0.15.0
[INFO] [stderr]   Downloaded bevy_mesh v0.15.0
[INFO] [stderr]   Downloaded bevy_text v0.15.0
[INFO] [stderr]   Downloaded bevy_a11y v0.15.0
[INFO] [stderr]   Downloaded bevy_derive v0.15.0
[INFO] [stderr]   Downloaded bevy_tasks v0.15.0
[INFO] [stderr]   Downloaded bevy_input v0.15.0
[INFO] [stderr]   Downloaded wayland-protocols-plasma v0.3.5
[INFO] [stderr]   Downloaded bevy_core_pipeline v0.15.0
[INFO] [stderr]   Downloaded bevy_ptr v0.15.0
[INFO] [stderr]   Downloaded bevy_utils_proc_macros v0.15.0
[INFO] [stderr]   Downloaded epaint_default_fonts v0.29.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+fcac501a73cdde54de46a0683567f1a890730555" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] e192f7e9255038936b7f23266276f534a563c38f28bbc786f99f17e4225589b0
[INFO] running `Command { std: "docker" "start" "-a" "e192f7e9255038936b7f23266276f534a563c38f28bbc786f99f17e4225589b0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "e192f7e9255038936b7f23266276f534a563c38f28bbc786f99f17e4225589b0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e192f7e9255038936b7f23266276f534a563c38f28bbc786f99f17e4225589b0", kill_on_drop: false }`
[INFO] [stdout] e192f7e9255038936b7f23266276f534a563c38f28bbc786f99f17e4225589b0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+fcac501a73cdde54de46a0683567f1a890730555" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cbcc5afb0e13f977351612a935dd85b3de3dbaabbaa9741fa385cc675ac85622
[INFO] running `Command { std: "docker" "start" "-a" "cbcc5afb0e13f977351612a935dd85b3de3dbaabbaa9741fa385cc675ac85622", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde v1.0.217
[INFO] [stderr]    Compiling libc v0.2.168
[INFO] [stderr]    Compiling tiny-keccak v2.0.2
[INFO] [stderr]    Compiling once_cell v1.20.2
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]    Compiling syn v2.0.90
[INFO] [stderr]    Compiling toml_edit v0.22.22
[INFO] [stderr]     Checking mint v0.5.9
[INFO] [stderr]     Checking event-listener v5.3.1
[INFO] [stderr]     Checking futures-lite v2.5.0
[INFO] [stderr]    Compiling typeid v1.0.2
[INFO] [stderr]    Compiling nix v0.29.0
[INFO] [stderr]     Checking disqualified v1.0.0
[INFO] [stderr]     Checking bevy_ptr v0.15.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking fixedbitset v0.5.7
[INFO] [stderr]     Checking itertools v0.13.0
[INFO] [stderr]    Compiling naga v23.0.0
[INFO] [stderr]     Checking event-listener-strategy v0.5.3
[INFO] [stderr]     Checking miniz_oxide v0.8.0
[INFO] [stderr]    Compiling cc v1.2.3
[INFO] [stderr]    Compiling wgpu-hal v23.0.1
[INFO] [stderr]     Checking crossbeam-channel v0.5.13
[INFO] [stderr]    Compiling wgpu-core v23.0.1
[INFO] [stderr]     Checking zune-jpeg v0.4.13
[INFO] [stderr]     Checking async-channel v2.3.1
[INFO] [stderr]     Checking async-lock v3.4.0
[INFO] [stderr]    Compiling wgpu v23.0.1
[INFO] [stderr]     Checking const_panic v0.2.10
[INFO] [stderr]     Checking accesskit v0.17.1
[INFO] [stderr]     Checking stackfuture v0.3.0
[INFO] [stderr]     Checking atomicow v1.0.0
[INFO] [stderr]     Checking ruzstd v0.7.3
[INFO] [stderr]     Checking bit-vec v0.6.3
[INFO] [stderr]     Checking unicode-ident v1.0.14
[INFO] [stderr]     Checking const-fnv1a-hash v1.1.0
[INFO] [stderr]     Checking flate2 v1.0.35
[INFO] [stderr]     Checking offset-allocator v0.2.0
[INFO] [stderr]    Compiling rustix v0.38.42
[INFO] [stderr]     Checking bit-set v0.5.3
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]    Compiling slotmap v1.0.7
[INFO] [stderr]     Checking async-executor v1.13.1
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]     Checking blocking v1.6.1
[INFO] [stderr]     Checking x11rb-protocol v0.13.1
[INFO] [stderr]     Checking png v0.17.15
[INFO] [stderr]    Compiling uuid v1.11.0
[INFO] [stderr]     Checking dlib v0.5.2
[INFO] [stderr]    Compiling const-random-macro v0.1.16
[INFO] [stderr]     Checking bevy_tasks v0.15.0
[INFO] [stderr]    Compiling winit v0.30.5
[INFO] [stderr]     Checking euclid v0.22.11
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]     Checking async-fs v2.1.2
[INFO] [stderr]     Checking const-random v0.1.18
[INFO] [stderr]     Checking dpi v0.1.1
[INFO] [stderr]     Checking roxmltree v0.20.0
[INFO] [stderr]     Checking unicode-properties v0.1.3
[INFO] [stderr]     Checking ttf-parser v0.21.1
[INFO] [stderr]     Checking unicode-bidi-mirroring v0.2.0
[INFO] [stderr]     Checking unicode-script v0.5.7
[INFO] [stderr]     Checking yazi v0.1.6
[INFO] [stderr]     Checking ttf-parser v0.20.0
[INFO] [stderr]     Checking zeno v0.2.3
[INFO] [stderr]     Checking unicode-ccc v0.2.0
[INFO] [stderr]     Checking rayon v1.10.0
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking khronos-egl v6.0.0
[INFO] [stderr]     Checking sysinfo v0.32.1
[INFO] [stderr]     Checking guillotiere v0.6.2
[INFO] [stderr]     Checking fontconfig-parser v0.5.7
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling blake3 v1.5.5
[INFO] [stderr]     Checking memmap2 v0.9.5
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking unicode-linebreak v0.1.5
[INFO] [stderr]     Checking self_cell v1.1.0
[INFO] [stderr]     Checking sys-locale v0.3.2
[INFO] [stderr]     Checking unicode-bidi v0.3.17
[INFO] [stderr]     Checking rangemap v1.5.1
[INFO] [stderr]    Compiling gilrs v0.11.0
[INFO] [stderr]     Checking grid v0.14.0
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]     Checking epaint_default_fonts v0.29.1
[INFO] [stderr]    Compiling thiserror v2.0.9
[INFO] [stderr]     Checking home v0.5.11
[INFO] [stderr]    Compiling bevy_egui v0.31.1
[INFO] [stderr]     Checking taffy v0.5.2
[INFO] [stderr]     Checking winnow v0.6.20
[INFO] [stderr]    Compiling anyhow v1.0.95
[INFO] [stderr]     Checking ringbuf v0.3.3
[INFO] [stderr]     Checking triple_buffer v8.0.0
[INFO] [stderr]     Checking result v1.0.0
[INFO] [stderr]     Checking dirs-sys v0.4.1
[INFO] [stderr]     Checking fuzzy-matcher v0.3.7
[INFO] [stderr]     Checking dirs v5.0.1
[INFO] [stderr]     Checking fontdb v0.16.2
[INFO] [stderr]    Compiling bevy_macro_utils v0.15.0
[INFO] [stderr]    Compiling encase_derive_impl v0.10.0
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling serde_derive v1.0.217
[INFO] [stderr]    Compiling bytemuck_derive v1.8.0
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling tracing-attributes v0.1.28
[INFO] [stderr]    Compiling derive_more-impl v1.0.0
[INFO] [stderr]    Compiling bevy_utils_proc_macros v0.15.0
[INFO] [stderr]    Compiling bevy_reflect_derive v0.15.0
[INFO] [stderr]    Compiling assert_type_match v0.1.1
[INFO] [stderr]    Compiling bevy_ecs_macros v0.15.0
[INFO] [stderr]    Compiling bevy_derive v0.15.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling encase_derive v0.10.0
[INFO] [stderr]    Compiling bevy_asset_macros v0.15.0
[INFO] [stderr]    Compiling bevy_render_macros v0.15.0
[INFO] [stderr]    Compiling bevy_encase_derive v0.15.0
[INFO] [stderr]    Compiling zerofrom-derive v0.1.5
[INFO] [stderr]    Compiling yoke-derive v0.7.5
[INFO] [stderr]    Compiling zerovec-derive v0.10.3
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling gltf-derive v1.4.1
[INFO] [stderr]     Checking zerocopy v0.7.35
[INFO] [stderr]    Compiling bevy_state_macros v0.15.0
[INFO] [stderr]    Compiling bevy_gizmos_macros v0.15.0
[INFO] [stderr]    Compiling thiserror-impl v2.0.9
[INFO] [stderr]    Compiling async-trait v0.1.85
[INFO] [stderr]    Compiling bevy-inspector-egui-derive v0.28.0
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking ppv-lite86 v0.2.20
[INFO] [stderr]     Checking bytemuck v1.20.0
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking zerofrom v0.1.5
[INFO] [stderr]     Checking yoke v0.7.5
[INFO] [stderr]     Checking tracing-subscriber v0.3.19
[INFO] [stderr]     Checking image v0.25.5
[INFO] [stderr]     Checking font-types v0.7.3
[INFO] [stderr]     Checking symphonia-core v0.5.4
[INFO] [stderr]     Checking emath v0.29.1
[INFO] [stderr]     Checking zerovec v0.10.4
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking ecolor v0.29.1
[INFO] [stderr]     Checking read-fonts v0.22.5
[INFO] [stderr]     Checking epaint v0.29.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking symphonia-metadata v0.5.4
[INFO] [stderr]     Checking derive_more v1.0.0
[INFO] [stderr]     Checking tinystr v0.7.6
[INFO] [stderr]     Checking icu_collections v1.5.0
[INFO] [stderr]     Checking rand_distr v0.4.3
[INFO] [stderr]     Checking icu_locid v1.5.0
[INFO] [stderr]     Checking symphonia-utils-xiph v0.5.4
[INFO] [stderr]     Checking symphonia-bundle-mp3 v0.5.4
[INFO] [stderr]     Checking egui v0.29.1
[INFO] [stderr]     Checking symphonia-codec-vorbis v0.5.4
[INFO] [stderr]     Checking symphonia-format-ogg v0.5.4
[INFO] [stderr]     Checking symphonia v0.5.4
[INFO] [stderr]     Checking icu_provider v1.5.0
[INFO] [stderr]     Checking icu_locid_transform v1.5.0
[INFO] [stderr]     Checking icu_properties v1.5.1
[INFO] [stderr]     Checking bitflags v2.6.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking glam v0.29.2
[INFO] [stderr]     Checking smol_str v0.2.2
[INFO] [stderr]     Checking erased-serde v0.4.5
[INFO] [stderr]     Checking petgraph v0.6.5
[INFO] [stderr]     Checking serde_json v1.0.133
[INFO] [stderr]     Checking serde_spanned v0.6.8
[INFO] [stderr]     Checking toml_datetime v0.6.8
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking serde_ini v0.2.0
[INFO] [stderr]     Checking serde_yaml v0.9.34+deprecated
[INFO] [stderr]     Checking icu_normalizer v1.5.0
[INFO] [stderr]     Checking spirv v0.3.0+sdk-1.3.268.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.2.0
[INFO] [stderr]     Checking wgpu-types v23.0.0
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking ron v0.8.1
[INFO] [stderr]     Checking bevy_utils v0.15.0
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking gpu-descriptor v0.3.0
[INFO] [stderr]     Checking xkbcommon-dl v0.4.2
[INFO] [stderr]     Checking rustybuzz v0.14.1
[INFO] [stderr]     Checking inotify v0.11.0
[INFO] [stderr]     Checking idna_adapter v1.2.0
[INFO] [stderr]     Checking alsa v0.9.1
[INFO] [stderr]     Checking dashmap v6.1.0
[INFO] [stderr]     Checking idna v1.0.3
[INFO] [stderr]     Checking gltf-json v1.4.1
[INFO] [stderr]     Checking url v2.5.4
[INFO] [stderr]     Checking ctrlc v3.4.5
[INFO] [stderr]     Checking gilrs-core v0.6.0
[INFO] [stderr]     Checking cpal v0.15.3
[INFO] [stderr]     Checking webbrowser v1.0.3
[INFO] [stderr]     Checking toml v0.8.19
[INFO] [stderr]     Checking skrifa v0.22.3
[INFO] [stderr]     Checking gltf v1.4.1
[INFO] [stderr]     Checking swash v0.1.19
[INFO] [stderr]     Checking bevy_reflect v0.15.0
[INFO] [stderr]     Checking encase v0.10.0
[INFO] [stderr]     Checking hexasphere v15.0.0
[INFO] [stderr]     Checking bevy_mikktspace v0.15.0
[INFO] [stderr]     Checking kira v0.9.6
[INFO] [stderr]     Checking polling v3.7.4
[INFO] [stderr]     Checking x11rb v0.13.1
[INFO] [stderr]     Checking calloop v0.13.0
[INFO] [stderr]     Checking async-io v2.4.0
[INFO] [stderr]     Checking async-net v2.0.0
[INFO] [stderr]     Checking naga_oil v0.16.0
[INFO] [stderr]     Checking arboard v3.4.1
[INFO] [stderr]     Checking cosmic-text v0.12.1
[INFO] [stderr]     Checking accesskit_winit v0.23.1
[INFO] [stderr]     Checking bevy_ecs v0.15.0
[INFO] [stderr]     Checking bevy_math v0.15.0
[INFO] [stderr]     Checking bevy_color v0.15.1
[INFO] [stderr]     Checking bevy_app v0.15.0
[INFO] [stderr]     Checking bevy_core v0.15.0
[INFO] [stderr]     Checking bevy_asset v0.15.0
[INFO] [stderr]     Checking bevy_a11y v0.15.0
[INFO] [stderr]     Checking bevy_time v0.15.0
[INFO] [stderr]     Checking bevy_log v0.15.0
[INFO] [stderr]     Checking bevy_hierarchy v0.15.0
[INFO] [stderr]     Checking bevy_input v0.15.0
[INFO] [stderr]     Checking bevy_diagnostic v0.15.0
[INFO] [stderr]     Checking bevy_transform v0.15.0
[INFO] [stderr]     Checking bevy_state v0.15.0
[INFO] [stderr]     Checking bevy_window v0.15.0
[INFO] [stderr]     Checking bevy_gilrs v0.15.0
[INFO] [stderr]     Checking bevy_image v0.15.0
[INFO] [stderr]     Checking bevy_mesh v0.15.0
[INFO] [stderr]     Checking bevy_winit v0.15.0
[INFO] [stderr]     Checking bevy_render v0.15.0
[INFO] [stderr]     Checking bevy_core_pipeline v0.15.0
[INFO] [stderr]     Checking bevy_picking v0.15.0
[INFO] [stderr]     Checking bevy_animation v0.15.0
[INFO] [stderr]     Checking bevy_scene v0.15.0
[INFO] [stderr]     Checking bevy_sprite v0.15.0
[INFO] [stderr]     Checking bevy_pbr v0.15.0
[INFO] [stderr]     Checking bevy_text v0.15.0
[INFO] [stderr]     Checking bevy_ui v0.15.0
[INFO] [stderr]     Checking bevy_gltf v0.15.0
[INFO] [stderr]     Checking bevy_gizmos v0.15.0
[INFO] [stderr]     Checking bevy-inspector-egui v0.28.0
[INFO] [stderr]     Checking bevy_internal v0.15.0
[INFO] [stderr]     Checking bevy v0.15.0
[INFO] [stderr]     Checking bevy-persistent v0.7.0
[INFO] [stderr]     Checking bevy_kira_audio v0.22.0
[INFO] [stderr]     Checking bevy_simple_text_input v0.10.1
[INFO] [stderr]     Checking bevy_eventwork v0.10.0
[INFO] [stderr]     Checking tcg_2d v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `bevy::prelude::*`
[INFO] [stdout]   --> src/core/mod.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use bevy::prelude::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/desk/desks.rs:59:21
[INFO] [stdout]    |
[INFO] [stdout] 59 |                     (Node {
[INFO] [stdout]    |                     ^
[INFO] [stdout] ...
[INFO] [stdout] 64 |                     }),
[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] 59 ~                     Node {
[INFO] [stdout] 60 |                         width: Val::Percent(100.0),
[INFO] [stdout] ...
[INFO] [stdout] 63 |                         ..Default::default()
[INFO] [stdout] 64 ~                     },
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/desk/desks.rs:124:12
[INFO] [stdout]     |
[INFO] [stdout] 124 |         if (*interaction == Interaction::Pressed) {
[INFO] [stdout]     |            ^                                    ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 124 -         if (*interaction == Interaction::Pressed) {
[INFO] [stdout] 124 +         if *interaction == Interaction::Pressed {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ALL_CARD`
[INFO] [stdout]  --> src/desk/detail.rs:3:32
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::common::test_data::{ALL_CARD, ALL_CARD_ONCE};
[INFO] [stdout]   |                                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::text::cosmic_text::Motion::Next`
[INFO] [stdout]   --> src/desk/detail.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use bevy::text::cosmic_text::Motion::Next;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/desk/list.rs:21:21
[INFO] [stdout]    |
[INFO] [stdout] 21 |                     (Node {
[INFO] [stdout]    |                     ^
[INFO] [stdout] ...
[INFO] [stdout] 26 |                     }),
[INFO] [stdout]    |                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 21 ~                     Node {
[INFO] [stdout] 22 |                         width: Val::Percent(100.0),
[INFO] [stdout] ...
[INFO] [stdout] 25 |                         ..Default::default()
[INFO] [stdout] 26 ~                     } ,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/desk/scroll_list.rs:61:51
[INFO] [stdout]    |
[INFO] [stdout] 61 |     let row_num = list.len() / items_per_row + if (last_item != 0) { 1 } else { 0 };
[INFO] [stdout]    |                                                   ^              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 61 -     let row_num = list.len() / items_per_row + if (last_item != 0) { 1 } else { 0 };
[INFO] [stdout] 61 +     let row_num = list.len() / items_per_row + if last_item != 0  { 1 } else { 0 };
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::prelude::*`
[INFO] [stdout]   --> src/core/mod.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use bevy::prelude::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/desk/scroll_list.rs:66:17
[INFO] [stdout]    |
[INFO] [stdout] 66 |                 (Node {
[INFO] [stdout]    |                 ^
[INFO] [stdout] ...
[INFO] [stdout] 69 |                 }),
[INFO] [stdout]    |                  ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 66 ~                 Node {
[INFO] [stdout] 67 |                     flex_direction: FlexDirection::Row,
[INFO] [stdout] 68 |                     ..default()
[INFO] [stdout] 69 ~                 } ,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/desk/scroll_list.rs:76:34
[INFO] [stdout]    |
[INFO] [stdout] 76 |                 let col_num = if (oi == row_num - 1 && last_item != 0) {
[INFO] [stdout]    |                                  ^                                   ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 76 -                 let col_num = if (oi == row_num - 1 && last_item != 0) {
[INFO] [stdout] 76 +                 let col_num = if oi == row_num - 1 && last_item != 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MenuState`
[INFO] [stdout]  --> src/desk/mod.rs:8:55
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::common::game_state::{DeskState, GameState, MenuState};
[INFO] [stdout]   |                                                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/desk/desks.rs:59:21
[INFO] [stdout]    |
[INFO] [stdout] 59 |                     (Node {
[INFO] [stdout]    |                     ^
[INFO] [stdout] ...
[INFO] [stdout] 64 |                     }),
[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] 59 ~                     Node {
[INFO] [stdout] 60 |                         width: Val::Percent(100.0),
[INFO] [stdout] ...
[INFO] [stdout] 63 |                         ..Default::default()
[INFO] [stdout] 64 ~                     },
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::menu::menu_button_action::MenuButtonActions`
[INFO] [stdout]   --> src/desk/mod.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::menu::menu_button_action::MenuButtonActions;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/desk/desks.rs:124:12
[INFO] [stdout]     |
[INFO] [stdout] 124 |         if (*interaction == Interaction::Pressed) {
[INFO] [stdout]     |            ^                                    ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 124 -         if (*interaction == Interaction::Pressed) {
[INFO] [stdout] 124 +         if *interaction == Interaction::Pressed {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ALL_CARD`
[INFO] [stdout]  --> src/desk/detail.rs:3:32
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::common::test_data::{ALL_CARD, ALL_CARD_ONCE};
[INFO] [stdout]   |                                ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/duel/common.rs:26:13
[INFO] [stdout]    |
[INFO] [stdout] 26 |             (Node {
[INFO] [stdout]    |             ^
[INFO] [stdout] ...
[INFO] [stdout] 34 |             }),
[INFO] [stdout]    |              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 ~             Node {
[INFO] [stdout] 27 |                 width: Val::Percent(100.),
[INFO] [stdout] ...
[INFO] [stdout] 33 |                 ..Default::default()
[INFO] [stdout] 34 ~             } ,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::text::cosmic_text::Motion::Next`
[INFO] [stdout]   --> src/desk/detail.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use bevy::text::cosmic_text::Motion::Next;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `GameState`
[INFO] [stdout]  --> src/duel/connected_page.rs:2:44
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::common::game_state::{DuelState, GameState};
[INFO] [stdout]   |                                            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::common::settings::Settings`
[INFO] [stdout]  --> src/duel/connected_page.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::common::settings::Settings;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::desk::detail::DeskSelect`
[INFO] [stdout]  --> src/duel/connected_page.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::desk::detail::DeskSelect;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::tasks::TaskPool`
[INFO] [stdout]   --> src/duel/connected_page.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use bevy::tasks::TaskPool;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/desk/list.rs:21:21
[INFO] [stdout]    |
[INFO] [stdout] 21 |                     (Node {
[INFO] [stdout]    |                     ^
[INFO] [stdout] ...
[INFO] [stdout] 26 |                     }),
[INFO] [stdout]    |                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 21 ~                     Node {
[INFO] [stdout] 22 |                         width: Val::Percent(100.0),
[INFO] [stdout] ...
[INFO] [stdout] 25 |                         ..Default::default()
[INFO] [stdout] 26 ~                     } ,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `NetworkSettings`
[INFO] [stdout]   --> src/duel/connected_page.rs:18:27
[INFO] [stdout]    |
[INFO] [stdout] 18 | use bevy_eventwork::tcp::{NetworkSettings, TcpProvider};
[INFO] [stdout]    |                           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/desk/scroll_list.rs:61:51
[INFO] [stdout]    |
[INFO] [stdout] 61 |     let row_num = list.len() / items_per_row + if (last_item != 0) { 1 } else { 0 };
[INFO] [stdout]    |                                                   ^              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 61 -     let row_num = list.len() / items_per_row + if (last_item != 0) { 1 } else { 0 };
[INFO] [stdout] 61 +     let row_num = list.len() / items_per_row + if last_item != 0  { 1 } else { 0 };
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/desk/scroll_list.rs:66:17
[INFO] [stdout]    |
[INFO] [stdout] 66 |                 (Node {
[INFO] [stdout]    |                 ^
[INFO] [stdout] ...
[INFO] [stdout] 69 |                 }),
[INFO] [stdout]    |                  ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 66 ~                 Node {
[INFO] [stdout] 67 |                     flex_direction: FlexDirection::Row,
[INFO] [stdout] 68 |                     ..default()
[INFO] [stdout] 69 ~                 } ,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/desk/scroll_list.rs:76:34
[INFO] [stdout]    |
[INFO] [stdout] 76 |                 let col_num = if (oi == row_num - 1 && last_item != 0) {
[INFO] [stdout]    |                                  ^                                   ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 76 -                 let col_num = if (oi == row_num - 1 && last_item != 0) {
[INFO] [stdout] 76 +                 let col_num = if oi == row_num - 1 && last_item != 0  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EventworkRuntime`
[INFO] [stdout]   --> src/duel/connected_page.rs:19:22
[INFO] [stdout]    |
[INFO] [stdout] 19 | use bevy_eventwork::{EventworkRuntime, Network};
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BACKGROUND_COLOR` and `BORDER_COLOR_ACTIVE`
[INFO] [stdout]  --> src/duel/main_duel.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::utils::{BACKGROUND_COLOR, BORDER_COLOR_ACTIVE, COLOR_BUTTON, get_socket};
[INFO] [stdout]   |                    ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::ui::FocusPolicy`
[INFO] [stdout]  --> src/duel/main_duel.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use bevy::ui::FocusPolicy;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TextInputInactive`, `TextInputSettings`, `TextInputTextColor`, `TextInputTextFont`, `TextInputValue`, and `TextInput`
[INFO] [stdout]   --> src/duel/main_duel.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     TextInput, TextInputInactive, TextInputSettings, TextInputTextColor, TextInputTextFont,
[INFO] [stdout]    |     ^^^^^^^^^  ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 13 |     TextInputValue,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `IpAddr`, `Ipv4Addr`, and `SocketAddr`
[INFO] [stdout]   --> src/duel/main_duel.rs:15:16
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::net::{IpAddr, Ipv4Addr, SocketAddr};
[INFO] [stdout]    |                ^^^^^^  ^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::common::desks_datas::DesksDataList`
[INFO] [stdout]  --> src/duel/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::common::desks_datas::DesksDataList;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::desk::detail::DeskSelect`
[INFO] [stdout]  --> src/duel/mod.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::desk::detail::DeskSelect;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy_persistent::Persistent`
[INFO] [stdout]   --> src/duel/mod.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use bevy_persistent::Persistent;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TextInputPlaceholder` and `TextInputPlugin`
[INFO] [stdout]   --> src/menu/mod.rs:14:35
[INFO] [stdout]    |
[INFO] [stdout] 14 |     TextInput, TextInputInactive, TextInputPlaceholder, TextInputPlugin, TextInputSettings,
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MenuState`
[INFO] [stdout]  --> src/desk/mod.rs:8:55
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::common::game_state::{DeskState, GameState, MenuState};
[INFO] [stdout]   |                                                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::menu::menu_button_action::MenuButtonActions`
[INFO] [stdout]   --> src/desk/mod.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::menu::menu_button_action::MenuButtonActions;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/duel/common.rs:26:13
[INFO] [stdout]    |
[INFO] [stdout] 26 |             (Node {
[INFO] [stdout]    |             ^
[INFO] [stdout] ...
[INFO] [stdout] 34 |             }),
[INFO] [stdout]    |              ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 ~             Node {
[INFO] [stdout] 27 |                 width: Val::Percent(100.),
[INFO] [stdout] ...
[INFO] [stdout] 33 |                 ..Default::default()
[INFO] [stdout] 34 ~             } ,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `GameState`
[INFO] [stdout]  --> src/duel/connected_page.rs:2:44
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::common::game_state::{DuelState, GameState};
[INFO] [stdout]   |                                            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::common::settings::Settings`
[INFO] [stdout]  --> src/duel/connected_page.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::common::settings::Settings;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::desk::detail::DeskSelect`
[INFO] [stdout]  --> src/duel/connected_page.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::desk::detail::DeskSelect;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::tasks::TaskPool`
[INFO] [stdout]   --> src/duel/connected_page.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use bevy::tasks::TaskPool;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `NetworkSettings`
[INFO] [stdout]   --> src/duel/connected_page.rs:18:27
[INFO] [stdout]    |
[INFO] [stdout] 18 | use bevy_eventwork::tcp::{NetworkSettings, TcpProvider};
[INFO] [stdout]    |                           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EventworkRuntime`
[INFO] [stdout]   --> src/duel/connected_page.rs:19:22
[INFO] [stdout]    |
[INFO] [stdout] 19 | use bevy_eventwork::{EventworkRuntime, Network};
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BACKGROUND_COLOR` and `BORDER_COLOR_ACTIVE`
[INFO] [stdout]  --> src/duel/main_duel.rs:4:20
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::utils::{BACKGROUND_COLOR, BORDER_COLOR_ACTIVE, COLOR_BUTTON, get_socket};
[INFO] [stdout]   |                    ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::ui::FocusPolicy`
[INFO] [stdout]  --> src/duel/main_duel.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use bevy::ui::FocusPolicy;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TextInputInactive`, `TextInputSettings`, `TextInputTextColor`, `TextInputTextFont`, `TextInputValue`, and `TextInput`
[INFO] [stdout]   --> src/duel/main_duel.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     TextInput, TextInputInactive, TextInputSettings, TextInputTextColor, TextInputTextFont,
[INFO] [stdout]    |     ^^^^^^^^^  ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 13 |     TextInputValue,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `IpAddr`, `Ipv4Addr`, and `SocketAddr`
[INFO] [stdout]   --> src/duel/main_duel.rs:15:16
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::net::{IpAddr, Ipv4Addr, SocketAddr};
[INFO] [stdout]    |                ^^^^^^  ^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::common::desks_datas::DesksDataList`
[INFO] [stdout]  --> src/duel/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::common::desks_datas::DesksDataList;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::desk::detail::DeskSelect`
[INFO] [stdout]  --> src/duel/mod.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::desk::detail::DeskSelect;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy_persistent::Persistent`
[INFO] [stdout]   --> src/duel/mod.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use bevy_persistent::Persistent;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TextInputPlaceholder` and `TextInputPlugin`
[INFO] [stdout]   --> src/menu/mod.rs:14:35
[INFO] [stdout]    |
[INFO] [stdout] 14 |     TextInput, TextInputInactive, TextInputPlaceholder, TextInputPlugin, TextInputSettings,
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/menu/mod.rs:375:17
[INFO] [stdout]     |
[INFO] [stdout] 375 |                 (Node {
[INFO] [stdout]     |                 ^
[INFO] [stdout] ...
[INFO] [stdout] 387 |                 }),
[INFO] [stdout]     |                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 375 ~                 Node {
[INFO] [stdout] 376 |                     width: Val::Percent(100.),
[INFO] [stdout] ...
[INFO] [stdout] 386 |                     ..default()
[INFO] [stdout] 387 ~                 } ,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Single` and `Window`
[INFO] [stdout]  --> src/splash/mod.rs:8:23
[INFO] [stdout]   |
[INFO] [stdout] 8 |     ResMut, Resource, Single, StateScoped, Text, TextLayout, Time, Timer, TimerMode, Update,
[INFO] [stdout]   |                       ^^^^^^
[INFO] [stdout] 9 |     Window, in_state,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::prelude::*`
[INFO] [stdout]  --> src/utils/drag_and_drop.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use bevy::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::input::mouse::MouseButtonInput`
[INFO] [stdout]  --> src/utils/preview_plugins.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use bevy::input::mouse::MouseButtonInput;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/menu/mod.rs:375:17
[INFO] [stdout]     |
[INFO] [stdout] 375 |                 (Node {
[INFO] [stdout]     |                 ^
[INFO] [stdout] ...
[INFO] [stdout] 387 |                 }),
[INFO] [stdout]     |                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 375 ~                 Node {
[INFO] [stdout] 376 |                     width: Val::Percent(100.),
[INFO] [stdout] ...
[INFO] [stdout] 386 |                     ..default()
[INFO] [stdout] 387 ~                 } ,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Single` and `Window`
[INFO] [stdout]  --> src/splash/mod.rs:8:23
[INFO] [stdout]   |
[INFO] [stdout] 8 |     ResMut, Resource, Single, StateScoped, Text, TextLayout, Time, Timer, TimerMode, Update,
[INFO] [stdout]   |                       ^^^^^^
[INFO] [stdout] 9 |     Window, in_state,
[INFO] [stdout]   |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::prelude::*`
[INFO] [stdout]  --> src/utils/drag_and_drop.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use bevy::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::input::mouse::MouseButtonInput`
[INFO] [stdout]  --> src/utils/preview_plugins.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use bevy::input::mouse::MouseButtonInput;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated enum `core::action_event::ActionType`
[INFO] [stdout]   --> src/core/action_event.rs:13:17
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub action: ActionType,
[INFO] [stdout]    |                 ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `core::action_event::ActionEvent`
[INFO] [stdout]   --> src/core/action_event.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct ActionEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated enum `core::action_event::ActionType`
[INFO] [stdout]   --> src/core/action_event.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ActionType {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::None`
[INFO] [stdout]   --> src/core/action_event.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     None,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated variant `core::action_event::ActionType::Draw`
[INFO] [stdout]   --> src/core/action_event.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     Draw {
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::Set`
[INFO] [stdout]   --> src/core/action_event.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     Set,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::Cost`
[INFO] [stdout]   --> src/core/action_event.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     Cost,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::Move`
[INFO] [stdout]   --> src/core/action_event.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     Move,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::Q`
[INFO] [stdout]   --> src/core/action_event.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     Q,
[INFO] [stdout]    |     ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::A`
[INFO] [stdout]   --> src/core/action_event.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     A,
[INFO] [stdout]    |     ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated variant `core::action_event::ActionType::Process`
[INFO] [stdout]   --> src/core/action_event.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     Process {
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated enum `core::action_event::ActionType`
[INFO] [stdout]   --> src/core/action_event.rs:13:17
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub action: ActionType,
[INFO] [stdout]    |                 ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `core::action_event::ActionEvent`
[INFO] [stdout]   --> src/core/action_event.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct ActionEvent {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated enum `core::action_event::ActionType`
[INFO] [stdout]   --> src/core/action_event.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ActionType {
[INFO] [stdout]    |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::None`
[INFO] [stdout]   --> src/core/action_event.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     None,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated variant `core::action_event::ActionType::Draw`
[INFO] [stdout]   --> src/core/action_event.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     Draw {
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::Set`
[INFO] [stdout]   --> src/core/action_event.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     Set,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::Cost`
[INFO] [stdout]   --> src/core/action_event.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     Cost,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::Move`
[INFO] [stdout]   --> src/core/action_event.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     Move,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::Q`
[INFO] [stdout]   --> src/core/action_event.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     Q,
[INFO] [stdout]    |     ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated unit variant `core::action_event::ActionType::A`
[INFO] [stdout]   --> src/core/action_event.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     A,
[INFO] [stdout]    |     ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated variant `core::action_event::ActionType::Process`
[INFO] [stdout]   --> src/core/action_event.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     Process {
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::tasks::futures_lite::StreamExt`
[INFO] [stdout]   --> src/duel/mod.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use bevy::tasks::futures_lite::StreamExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> src/core/duel_impls.rs:105:17
[INFO] [stdout]     |
[INFO] [stdout] 105 |             for i in 0..num {
[INFO] [stdout]     |                 ^ help: if this is intentional, prefix it with an underscore: `_i`
[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/desk/desks.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 |     mut commands: Commands,
[INFO] [stdout]    |     ----^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/desk/desks.rs:123:46
[INFO] [stdout]     |
[INFO] [stdout] 123 |     query.iter_mut().for_each(|(interaction, mut index)| {
[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/desk/detail.rs:211:5
[INFO] [stdout]     |
[INFO] [stdout] 211 |     mut content_plane: &mut ChildBuilder,
[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/desk/detail.rs:253:15
[INFO] [stdout]     |
[INFO] [stdout] 253 |     if let Ok(mut card_index) = query.get_mut(click.entity()) {
[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/desk/detail.rs:271:15
[INFO] [stdout]     |
[INFO] [stdout] 271 |     if let Ok(mut card_code) = query.get_mut(click.entity()) {
[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/desk/detail.rs:301:25
[INFO] [stdout]     |
[INFO] [stdout] 301 |             if let Some(mut desk) = current_data.0.clone() {
[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/desk/list.rs:9:18
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub fn list_page(mut commands: Commands, asset_server: Res<AssetServer>) {
[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/desk/scroll_list.rs:40:14
[INFO] [stdout]    |
[INFO] [stdout] 40 |         let (mut dx, mut dy) = match mouse_wheel_event.unit {
[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/desk/scroll_list.rs:40:22
[INFO] [stdout]    |
[INFO] [stdout] 40 |         let (mut dx, mut dy) = match mouse_wheel_event.unit {
[INFO] [stdout]    |                      ----^^
[INFO] [stdout]    |                      |
[INFO] [stdout]    |                      help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `asset_server`
[INFO] [stdout]   --> src/desk/mod.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     asset_server: Res<AssetServer>,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_asset_server`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]    --> src/desk/mod.rs:187:39
[INFO] [stdout]     |
[INFO] [stdout] 187 | ...                   if let Ok(a) = desks_data_list.update(|desk_list| {
[INFO] [stdout]     |                                 ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/duel/connected_page.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     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/duel/connected_page.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     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/duel/mod.rs:71:10
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn setup(mut commands: Commands, mut next_state: ResMut<NextState<DuelState>>) {
[INFO] [stdout]    |          ----^^^^^^^^
[INFO] [stdout]    |          |
[INFO] [stdout]    |          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]   --> src/duel/mod.rs:71:10
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn setup(mut commands: Commands, mut next_state: ResMut<NextState<DuelState>>) {
[INFO] [stdout]    |          ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::tasks::futures_lite::StreamExt`
[INFO] [stdout]   --> src/duel/mod.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use bevy::tasks::futures_lite::StreamExt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/utils/preview_plugins.rs:56:41
[INFO] [stdout]    |
[INFO] [stdout] 56 | fn show_preview(mut commands: Commands, mut image_stage: ResMut<ImageStage>) {
[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/utils/preview_plugins.rs:119:27
[INFO] [stdout]     |
[INFO] [stdout] 119 |         for (interaction, mut preview) in query.iter_mut() {
[INFO] [stdout]     |                           ----^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `BackToList` is never constructed
[INFO] [stdout]  --> src/desk/desk_button_action.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub enum DeskButtonActionState {
[INFO] [stdout]   |          --------------------- variant in this enum
[INFO] [stdout] 5 |     BackToMenu,
[INFO] [stdout] 6 |     BackToList,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `DeskButtonActionState` 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: constant `FPS` is never used
[INFO] [stdout]   --> src/duel/mod.rs:22:7
[INFO] [stdout]    |
[INFO] [stdout] 22 | const FPS: usize = 60;
[INFO] [stdout]    |       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load_S001_A_001` should have a snake case name
[INFO] [stdout]   --> src/core/card_info_manager.rs:15:4
[INFO] [stdout]    |
[INFO] [stdout] 15 | fn load_S001_A_001() {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `load_s001_a_001`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> src/core/duel_impls.rs:105:17
[INFO] [stdout]     |
[INFO] [stdout] 105 |             for i in 0..num {
[INFO] [stdout]     |                 ^ help: if this is intentional, prefix it with an underscore: `_i`
[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/desk/desks.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 |     mut commands: Commands,
[INFO] [stdout]    |     ----^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/desk/desks.rs:123:46
[INFO] [stdout]     |
[INFO] [stdout] 123 |     query.iter_mut().for_each(|(interaction, mut index)| {
[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/desk/detail.rs:211:5
[INFO] [stdout]     |
[INFO] [stdout] 211 |     mut content_plane: &mut ChildBuilder,
[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/desk/detail.rs:253:15
[INFO] [stdout]     |
[INFO] [stdout] 253 |     if let Ok(mut card_index) = query.get_mut(click.entity()) {
[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/desk/detail.rs:271:15
[INFO] [stdout]     |
[INFO] [stdout] 271 |     if let Ok(mut card_code) = query.get_mut(click.entity()) {
[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/desk/detail.rs:301:25
[INFO] [stdout]     |
[INFO] [stdout] 301 |             if let Some(mut desk) = current_data.0.clone() {
[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/desk/list.rs:9:18
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub fn list_page(mut commands: Commands, asset_server: Res<AssetServer>) {
[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/desk/scroll_list.rs:40:14
[INFO] [stdout]    |
[INFO] [stdout] 40 |         let (mut dx, mut dy) = match mouse_wheel_event.unit {
[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/desk/scroll_list.rs:40:22
[INFO] [stdout]    |
[INFO] [stdout] 40 |         let (mut dx, mut dy) = match mouse_wheel_event.unit {
[INFO] [stdout]    |                      ----^^
[INFO] [stdout]    |                      |
[INFO] [stdout]    |                      help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `asset_server`
[INFO] [stdout]   --> src/desk/mod.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     asset_server: Res<AssetServer>,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_asset_server`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]    --> src/desk/mod.rs:187:39
[INFO] [stdout]     |
[INFO] [stdout] 187 | ...                   if let Ok(a) = desks_data_list.update(|desk_list| {
[INFO] [stdout]     |                                 ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/duel/connected_page.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     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/duel/connected_page.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 68 |     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/duel/mod.rs:71:10
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn setup(mut commands: Commands, mut next_state: ResMut<NextState<DuelState>>) {
[INFO] [stdout]    |          ----^^^^^^^^
[INFO] [stdout]    |          |
[INFO] [stdout]    |          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]   --> src/duel/mod.rs:71:10
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn setup(mut commands: Commands, mut next_state: ResMut<NextState<DuelState>>) {
[INFO] [stdout]    |          ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy_inspector_egui::quick::WorldInspectorPlugin`
[INFO] [stdout]  --> src/bin/client.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy_inspector_egui::quick::WorldInspectorPlugin;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/utils/preview_plugins.rs:56:41
[INFO] [stdout]    |
[INFO] [stdout] 56 | fn show_preview(mut commands: Commands, mut image_stage: ResMut<ImageStage>) {
[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/utils/preview_plugins.rs:119:27
[INFO] [stdout]     |
[INFO] [stdout] 119 |         for (interaction, mut preview) in query.iter_mut() {
[INFO] [stdout]     |                           ----^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `BackToList` is never constructed
[INFO] [stdout]  --> src/desk/desk_button_action.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub enum DeskButtonActionState {
[INFO] [stdout]   |          --------------------- variant in this enum
[INFO] [stdout] 5 |     BackToMenu,
[INFO] [stdout] 6 |     BackToList,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `DeskButtonActionState` 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: constant `FPS` is never used
[INFO] [stdout]   --> src/duel/mod.rs:22:7
[INFO] [stdout]    |
[INFO] [stdout] 22 | const FPS: usize = 60;
[INFO] [stdout]    |       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load_S001_A_001` should have a snake case name
[INFO] [stdout]   --> src/core/card_info_manager.rs:15:4
[INFO] [stdout]    |
[INFO] [stdout] 15 | fn load_S001_A_001() {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `load_s001_a_001`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy_inspector_egui::quick::WorldInspectorPlugin`
[INFO] [stdout]  --> src/bin/client.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use bevy_inspector_egui::quick::WorldInspectorPlugin;
[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 variable: `duel`
[INFO] [stdout]   --> src/bin/server.rs:85:41
[INFO] [stdout]    |
[INFO] [stdout] 85 | ...                   if let Some(duel) = room_manager.0.remove(&room_name) {
[INFO] [stdout]    |                                   ^^^^ help: if this is intentional, prefix it with an underscore: `_duel`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `duel`
[INFO] [stdout]   --> src/bin/server.rs:85:41
[INFO] [stdout]    |
[INFO] [stdout] 85 | ...                   if let Some(duel) = room_manager.0.remove(&room_name) {
[INFO] [stdout]    |                                   ^^^^ help: if this is intentional, prefix it with an underscore: `_duel`
[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/bin/server.rs:153:29
[INFO] [stdout]     |
[INFO] [stdout] 153 |                 if let Some(mut player) = players_manager.0.get_mut(&message.source().id) {
[INFO] [stdout]     |                             ----^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/bin/server.rs:153:29
[INFO] [stdout]     |
[INFO] [stdout] 153 |                 if let Some(mut player) = players_manager.0.get_mut(&message.source().id) {
[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] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 27s
[INFO] running `Command { std: "docker" "inspect" "cbcc5afb0e13f977351612a935dd85b3de3dbaabbaa9741fa385cc675ac85622", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cbcc5afb0e13f977351612a935dd85b3de3dbaabbaa9741fa385cc675ac85622", kill_on_drop: false }`
[INFO] [stdout] cbcc5afb0e13f977351612a935dd85b3de3dbaabbaa9741fa385cc675ac85622
