[INFO] cloning repository https://github.com/ShadowElf37/VoxelGame
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/ShadowElf37/VoxelGame" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FShadowElf37%2FVoxelGame", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FShadowElf37%2FVoxelGame'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 6a247dc2a3d439258c26a8ab25f9860bd6ad98de
[INFO] checking ShadowElf37/VoxelGame against master#f2c70877a7dbc51cd98e2d5d25209b24d4a586d5 for pr-150097
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FShadowElf37%2FVoxelGame" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/ShadowElf37/VoxelGame
[INFO] finished tweaking git repo https://github.com/ShadowElf37/VoxelGame
[INFO] tweaked toml for git repo https://github.com/ShadowElf37/VoxelGame written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/ShadowElf37/VoxelGame on toolchain f2c70877a7dbc51cd98e2d5d25209b24d4a586d5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+f2c70877a7dbc51cd98e2d5d25209b24d4a586d5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/ShadowElf37/VoxelGame 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" "+f2c70877a7dbc51cd98e2d5d25209b24d4a586d5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating git repository `https://github.com/grovesNL/glyphon.git`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded sys-locale v0.3.1
[INFO] [stderr]   Downloaded portable-atomic-util v0.2.2
[INFO] [stderr]   Downloaded self_cell v1.0.4
[INFO] [stderr]   Downloaded xcursor v0.3.6
[INFO] [stderr]   Downloaded serde v1.0.207
[INFO] [stderr]   Downloaded font-types v0.6.0
[INFO] [stderr]   Downloaded etagere v0.2.13
[INFO] [stderr]   Downloaded wayland-protocols-plasma v0.3.3
[INFO] [stderr]   Downloaded serde_derive v1.0.207
[INFO] [stderr]   Downloaded noise v0.9.0
[INFO] [stderr]   Downloaded rgb v0.8.47
[INFO] [stderr]   Downloaded portable-atomic v1.7.0
[INFO] [stderr]   Downloaded skrifa v0.20.0
[INFO] [stderr]   Downloaded read-fonts v0.20.0
[INFO] [stderr]   Downloaded ndarray v0.16.0
[INFO] [stderr]   Downloaded swash v0.1.18
[INFO] [stderr]   Downloaded winit v0.30.4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+f2c70877a7dbc51cd98e2d5d25209b24d4a586d5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2afd65b85f56a609b2a04c5c489103f120785ee79680d1d68c7d297ae2eab51c
[INFO] running `Command { std: "docker" "start" "-a" "2afd65b85f56a609b2a04c5c489103f120785ee79680d1d68c7d297ae2eab51c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2afd65b85f56a609b2a04c5c489103f120785ee79680d1d68c7d297ae2eab51c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2afd65b85f56a609b2a04c5c489103f120785ee79680d1d68c7d297ae2eab51c", kill_on_drop: false }`
[INFO] [stdout] 2afd65b85f56a609b2a04c5c489103f120785ee79680d1d68c7d297ae2eab51c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+f2c70877a7dbc51cd98e2d5d25209b24d4a586d5" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 8a6f00b19ca426159cc7c7980a5a22d22bc632d7869c54b5aa4e4ae4d433ea21
[INFO] running `Command { std: "docker" "start" "-a" "8a6f00b19ca426159cc7c7980a5a22d22bc632d7869c54b5aa4e4ae4d433ea21", kill_on_drop: false }`
[INFO] [stderr]     Checking cfg-if v1.0.0
[INFO] [stderr]    Compiling syn v2.0.72
[INFO] [stderr]     Checking once_cell v1.19.0
[INFO] [stderr]     Checking bitflags v2.6.0
[INFO] [stderr]     Checking log v0.4.22
[INFO] [stderr]     Checking smallvec v1.13.2
[INFO] [stderr]    Compiling libc v0.2.155
[INFO] [stderr]    Compiling cc v1.1.8
[INFO] [stderr]     Checking libloading v0.8.5
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]    Compiling rustix v0.38.34
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling thiserror v1.0.63
[INFO] [stderr]     Checking linux-raw-sys v0.4.14
[INFO] [stderr]     Checking arrayvec v0.7.4
[INFO] [stderr]     Checking dlib v0.5.2
[INFO] [stderr]    Compiling wayland-sys v0.31.4
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]    Compiling cfg_aliases v0.1.1
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]     Checking scopeguard v1.2.0
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]     Checking scoped-tls v1.0.1
[INFO] [stderr]     Checking downcast-rs v1.2.1
[INFO] [stderr]    Compiling crossbeam-utils v0.8.20
[INFO] [stderr]    Compiling quick-xml v0.34.0
[INFO] [stderr]     Checking memchr v2.7.4
[INFO] [stderr]     Checking allocator-api2 v0.2.18
[INFO] [stderr]    Compiling wayland-client v0.31.5
[INFO] [stderr]     Checking simd-adler32 v0.3.7
[INFO] [stderr]     Checking either v1.13.0
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking equivalent v1.0.1
[INFO] [stderr]    Compiling rayon-core v1.12.1
[INFO] [stderr]     Checking pin-project-lite v0.2.14
[INFO] [stderr]     Checking termcolor v1.4.1
[INFO] [stderr]     Checking adler v1.0.2
[INFO] [stderr]     Checking tracing-core v0.1.32
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking crossbeam-epoch v0.9.18
[INFO] [stderr]     Checking miniz_oxide v0.7.4
[INFO] [stderr]    Compiling wayland-scanner v0.31.4
[INFO] [stderr]    Compiling wayland-backend v0.3.6
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking crossbeam-deque v0.8.5
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling anyhow v1.0.86
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]     Checking memmap2 v0.9.4
[INFO] [stderr]    Compiling naga v22.1.0
[INFO] [stderr]    Compiling serde v1.0.207
[INFO] [stderr]     Checking bit-vec v0.7.0
[INFO] [stderr]    Compiling built v0.7.4
[INFO] [stderr]     Checking minimal-lexical v0.2.1
[INFO] [stderr]     Checking aligned-vec v0.5.0
[INFO] [stderr]    Compiling ash v0.38.0+1.3.281
[INFO] [stderr]     Checking rustc-hash v1.1.0
[INFO] [stderr]    Compiling khronos-egl v6.0.0
[INFO] [stderr]     Checking unicode-width v0.1.13
[INFO] [stderr]     Checking v_frame v0.3.8
[INFO] [stderr]    Compiling rav1e v0.7.1
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking bit-set v0.6.0
[INFO] [stderr]     Checking num-rational v0.4.2
[INFO] [stderr]    Compiling wgpu-hal v22.0.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.2.0
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking spirv v0.3.0+sdk-1.3.268.0
[INFO] [stderr]     Checking crc32fast v1.4.2
[INFO] [stderr]    Compiling slotmap v1.0.7
[INFO] [stderr]     Checking unicode-xid v0.2.4
[INFO] [stderr]     Checking raw-window-handle v0.6.2
[INFO] [stderr]     Checking hexf-parse v0.2.1
[INFO] [stderr]     Checking flate2 v1.0.31
[INFO] [stderr]    Compiling libm v0.2.8
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking rayon v1.10.0
[INFO] [stderr]     Checking itertools v0.12.1
[INFO] [stderr]     Checking spin v0.9.8
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling wgpu-core v22.1.0
[INFO] [stderr]     Checking wgpu-types v22.0.0
[INFO] [stderr]     Checking av1-grain v0.2.3
[INFO] [stderr]     Checking maybe-rayon v0.1.1
[INFO] [stderr]    Compiling simd_helpers v0.1.0
[INFO] [stderr]     Checking new_debug_unreachable v1.0.6
[INFO] [stderr]     Checking ttf-parser v0.24.1
[INFO] [stderr]     Checking glow v0.13.1
[INFO] [stderr]     Checking cursor-icon v1.1.0
[INFO] [stderr]    Compiling noop_proc_macro v0.3.0
[INFO] [stderr]     Checking roxmltree v0.20.0
[INFO] [stderr]    Compiling bytemuck_derive v1.7.0
[INFO] [stderr]    Compiling zerocopy-derive v0.7.35
[INFO] [stderr]    Compiling thiserror-impl v1.0.63
[INFO] [stderr]    Compiling profiling-procmacros v1.0.15
[INFO] [stderr]    Compiling serde_derive v1.0.207
[INFO] [stderr]     Checking profiling v1.0.15
[INFO] [stderr]     Checking polling v3.7.2
[INFO] [stderr]     Checking zerocopy v0.7.35
[INFO] [stderr]     Checking bytemuck v1.16.3
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]     Checking font-types v0.6.0
[INFO] [stderr]    Compiling arg_enum_proc_macro v0.3.4
[INFO] [stderr]     Checking calloop v0.13.0
[INFO] [stderr]     Checking read-fonts v0.20.0
[INFO] [stderr]     Checking strict-num v0.1.1
[INFO] [stderr]     Checking weezl v0.1.8
[INFO] [stderr]    Compiling litrs v0.4.1
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking xkeysym v0.2.1
[INFO] [stderr]     Checking renderdoc-sys v1.1.0
[INFO] [stderr]     Checking wayland-protocols v0.32.3
[INFO] [stderr]     Checking tinyvec_macros v0.1.1
[INFO] [stderr]    Compiling smithay-client-toolkit v0.19.2
[INFO] [stderr]     Checking imgref v1.10.1
[INFO] [stderr]     Checking bitstream-io v2.5.0
[INFO] [stderr]     Checking quick-error v2.0.1
[INFO] [stderr]     Checking arrayref v0.3.8
[INFO] [stderr]     Checking xcursor v0.3.6
[INFO] [stderr]     Checking indexmap v2.3.0
[INFO] [stderr]     Checking gpu-descriptor v0.3.0
[INFO] [stderr]     Checking wayland-cursor v0.31.5
[INFO] [stderr]     Checking tiny-skia-path v0.11.4
[INFO] [stderr]     Checking loop9 v0.1.5
[INFO] [stderr]    Compiling document-features v0.2.10
[INFO] [stderr]     Checking tinyvec v1.8.0
[INFO] [stderr]     Checking calloop-wayland-source v0.3.0
[INFO] [stderr]     Checking ppv-lite86 v0.2.20
[INFO] [stderr]     Checking rgb v0.8.47
[INFO] [stderr]     Checking owned_ttf_parser v0.24.0
[INFO] [stderr]     Checking wayland-csd-frame v0.3.0
[INFO] [stderr]     Checking fontconfig-parser v0.5.7
[INFO] [stderr]     Checking flume v0.11.0
[INFO] [stderr]    Compiling psm v0.1.21
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]     Checking zune-inflate v0.2.54
[INFO] [stderr]     Checking fdeflate v0.3.4
[INFO] [stderr]    Compiling wgpu v22.1.0
[INFO] [stderr]     Checking avif-serialize v0.8.1
[INFO] [stderr]     Checking half v2.4.1
[INFO] [stderr]    Compiling matrixmultiply v0.3.9
[INFO] [stderr]     Checking ttf-parser v0.21.1
[INFO] [stderr]     Checking jpeg-decoder v0.3.1
[INFO] [stderr]     Checking wayland-protocols-wlr v0.3.3
[INFO] [stderr]     Checking zeno v0.2.3
[INFO] [stderr]     Checking skrifa v0.20.0
[INFO] [stderr]     Checking unicode-properties v0.1.1
[INFO] [stderr]     Checking color_quant v1.1.0
[INFO] [stderr]     Checking bit_field v0.10.2
[INFO] [stderr]     Checking regex-syntax v0.8.4
[INFO] [stderr]     Checking unicode-ccc v0.2.0
[INFO] [stderr]     Checking unicode-bidi-mirroring v0.2.0
[INFO] [stderr]     Checking byteorder-lite v0.1.0
[INFO] [stderr]     Checking ab_glyph_rasterizer v0.1.8
[INFO] [stderr]     Checking yazi v0.1.6
[INFO] [stderr]     Checking lebe v0.5.2
[INFO] [stderr]     Checking unicode-script v0.5.6
[INFO] [stderr]     Checking zune-core v0.4.12
[INFO] [stderr]     Checking bitflags v1.3.2
[INFO] [stderr]     Checking ttf-parser v0.20.0
[INFO] [stderr]     Checking zune-jpeg v0.4.13
[INFO] [stderr]     Checking png v0.17.13
[INFO] [stderr]     Checking exr v1.72.0
[INFO] [stderr]     Checking rustybuzz v0.14.1
[INFO] [stderr]     Checking regex-automata v0.4.7
[INFO] [stderr]     Checking swash v0.1.18
[INFO] [stderr]     Checking ravif v0.11.9
[INFO] [stderr]     Checking image-webp v0.1.3
[INFO] [stderr]     Checking ab_glyph v0.2.28
[INFO] [stderr]     Checking gif v0.13.1
[INFO] [stderr]     Checking fontdb v0.16.2
[INFO] [stderr]     Checking serde_spanned v0.6.7
[INFO] [stderr]     Checking toml_datetime v0.6.8
[INFO] [stderr]     Checking tiff v0.9.1
[INFO] [stderr]    Compiling winit v0.30.4
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking tiny-skia v0.11.4
[INFO] [stderr]     Checking qoi v0.4.1
[INFO] [stderr]    Compiling stacker v0.1.15
[INFO] [stderr]     Checking euclid v0.22.10
[INFO] [stderr]     Checking as-raw-xcb-connection v1.0.1
[INFO] [stderr]     Checking rawpointer v0.2.1
[INFO] [stderr]     Checking winnow v0.6.18
[INFO] [stderr]     Checking unicode-linebreak v0.1.5
[INFO] [stderr]     Checking unicode-bidi v0.3.15
[INFO] [stderr]     Checking sys-locale v0.3.1
[INFO] [stderr]     Checking x11rb-protocol v0.13.1
[INFO] [stderr]     Checking self_cell v1.0.4
[INFO] [stderr]     Checking svg_fmt v0.4.3
[INFO] [stderr]     Checking static_assertions v1.1.0
[INFO] [stderr]     Checking rangemap v1.5.1
[INFO] [stderr]     Checking unicode-segmentation v1.11.0
[INFO] [stderr]     Checking image v0.25.2
[INFO] [stderr]     Checking etagere v0.2.13
[INFO] [stderr]     Checking cosmic-text v0.12.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking sctk-adwaita v0.10.1
[INFO] [stderr]     Checking regex v1.10.6
[INFO] [stderr]     Checking wayland-protocols-plasma v0.3.3
[INFO] [stderr]     Checking xkbcommon-dl v0.4.2
[INFO] [stderr]     Checking toml_edit v0.22.20
[INFO] [stderr]     Checking rand_xorshift v0.3.0
[INFO] [stderr]     Checking num-complex v0.4.6
[INFO] [stderr]     Checking is-terminal v0.4.12
[INFO] [stderr]     Checking lru v0.12.4
[INFO] [stderr]     Checking humantime v2.1.0
[INFO] [stderr]     Checking rustc-hash v2.0.0
[INFO] [stderr]     Checking smol_str v0.2.2
[INFO] [stderr]     Checking raw-window-handle v0.5.2
[INFO] [stderr]     Checking percent-encoding v2.3.1
[INFO] [stderr]     Checking dpi v0.1.1
[INFO] [stderr]     Checking ndarray v0.16.0
[INFO] [stderr]     Checking env_logger v0.10.2
[INFO] [stderr]     Checking pollster v0.3.0
[INFO] [stderr]     Checking glam v0.28.0
[INFO] [stderr]     Checking noise v0.9.0
[INFO] [stderr]     Checking toml v0.8.19
[INFO] [stderr]     Checking x11rb v0.13.1
[INFO] [stderr]     Checking glyphon v0.5.0 (https://github.com/grovesNL/glyphon.git#ce6ede95)
[INFO] [stderr]     Checking VoxelGame v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Event`
[INFO] [stdout]  --> src/main.rs:8:46
[INFO] [stdout]   |
[INFO] [stdout] 8 | use winit::event::{WindowEvent, DeviceEvent, Event};
[INFO] [stdout]   |                                              ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::block`
[INFO] [stdout]  --> src/renderer.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::block;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> src/renderer.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `wgpu::BufferDescriptor`
[INFO] [stdout]  --> src/renderer.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use wgpu::BufferDescriptor;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Mat4` and `Vec3A`
[INFO] [stdout]  --> src/renderer.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | use glam::{Vec3A, Mat4};
[INFO] [stdout]   |            ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::geometry::Vertex`
[INFO] [stdout]   --> src/renderer.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::geometry::Vertex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Mat3` and `Vec3`
[INFO] [stdout]    --> src/renderer.rs:541:24
[INFO] [stdout]     |
[INFO] [stdout] 541 |             use glam::{Vec3, Mat3};
[INFO] [stdout]     |                        ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `glam::f32::Vec3A`
[INFO] [stdout]  --> src/geometry.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use glam::f32::Vec3A;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::NdIndex`
[INFO] [stdout]  --> src/world.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use ndarray::NdIndex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::mem::MaybeUninit`
[INFO] [stdout]  --> src/world.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::mem::MaybeUninit;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/world.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::SystemTime`
[INFO] [stdout]  --> src/world.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::time::SystemTime;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::camera`
[INFO] [stdout]  --> src/world.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::camera;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::geometry`
[INFO] [stdout]   --> src/world.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::geometry;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CHUNK_SIZE_F`
[INFO] [stdout]   --> src/world.rs:15:27
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::chunk::{Chunk, CHUNK_SIZE_F};
[INFO] [stdout]    |                           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::prelude::*`
[INFO] [stdout]   --> src/world.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use ndarray::prelude::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Array3`
[INFO] [stdout]   --> src/world.rs:18:15
[INFO] [stdout]    |
[INFO] [stdout] 18 | use ndarray::{Array3};
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Vertex`
[INFO] [stdout]  --> src/block.rs:2:23
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::geometry::{Vertex, Facing};
[INFO] [stdout]   |                       ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::prelude::*`
[INFO] [stdout]  --> src/block.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use ndarray::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Array`, `Axis`, and `Ix3`
[INFO] [stdout]  --> src/block.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ndarray::{Array, Ix3, Axis};
[INFO] [stdout]   |               ^^^^^  ^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::RwLock`
[INFO] [stdout]  --> src/chunk.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::sync::RwLock;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/chunk.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]    --> src/chunk.rs:146:38
[INFO] [stdout]     |
[INFO] [stdout] 146 |                 .into_iter().map(|x| (x + (i as u32) * 4) )
[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] 146 -                 .into_iter().map(|x| (x + (i as u32) * 4) )
[INFO] [stdout] 146 +                 .into_iter().map(|x| x + (i as u32) * 4  )
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::PoisonError`
[INFO] [stdout]  --> src/memarena.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::sync::PoisonError;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Layout`, `alloc_zeroed`, `alloc`, `dealloc`, and `handle_alloc_error`
[INFO] [stdout]  --> src/memarena.rs:3:18
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::alloc::{alloc, dealloc, Layout, handle_alloc_error, alloc_zeroed};
[INFO] [stdout]   |                  ^^^^^  ^^^^^^^  ^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `align_of` and `size_of`
[INFO] [stdout]  --> src/memarena.rs:5:16
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::mem::{size_of, align_of};
[INFO] [stdout]   |                ^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::slice::Iter`
[INFO] [stdout]  --> src/chunkset.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::slice::Iter;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::prelude::*`
[INFO] [stdout]  --> src/chunkset.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ndarray::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Layout`, `alloc_zeroed`, `alloc`, `dealloc`, and `handle_alloc_error`
[INFO] [stdout]  --> src/chunkset.rs:6:18
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::alloc::{alloc, dealloc, Layout, handle_alloc_error, alloc_zeroed};
[INFO] [stdout]   |                  ^^^^^  ^^^^^^^  ^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `RwLockReadGuard` and `RwLockWriteGuard`
[INFO] [stdout]  --> src/chunkset.rs:7:25
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::sync::{RwLock, RwLockReadGuard, RwLockWriteGuard};
[INFO] [stdout]   |                         ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `align_of` and `size_of`
[INFO] [stdout]  --> src/chunkset.rs:8:16
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::mem::{size_of, align_of};
[INFO] [stdout]   |                ^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::iter::Map`
[INFO] [stdout]  --> src/memblock.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::iter::Map;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::slice::Iter`
[INFO] [stdout]  --> src/memblock.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::slice::Iter;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Event`
[INFO] [stdout]  --> src/main.rs:8:46
[INFO] [stdout]   |
[INFO] [stdout] 8 | use winit::event::{WindowEvent, DeviceEvent, Event};
[INFO] [stdout]   |                                              ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::block`
[INFO] [stdout]  --> src/renderer.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::block;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::PathBuf`
[INFO] [stdout]  --> src/renderer.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::PathBuf;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `wgpu::BufferDescriptor`
[INFO] [stdout]  --> src/renderer.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use wgpu::BufferDescriptor;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Mat4` and `Vec3A`
[INFO] [stdout]  --> src/renderer.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | use glam::{Vec3A, Mat4};
[INFO] [stdout]   |            ^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::geometry::Vertex`
[INFO] [stdout]   --> src/renderer.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::geometry::Vertex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Mat3` and `Vec3`
[INFO] [stdout]    --> src/renderer.rs:541:24
[INFO] [stdout]     |
[INFO] [stdout] 541 |             use glam::{Vec3, Mat3};
[INFO] [stdout]     |                        ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `glam::f32::Vec3A`
[INFO] [stdout]  --> src/geometry.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use glam::f32::Vec3A;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::NdIndex`
[INFO] [stdout]  --> src/world.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use ndarray::NdIndex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::mem::MaybeUninit`
[INFO] [stdout]  --> src/world.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::mem::MaybeUninit;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/world.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::SystemTime`
[INFO] [stdout]  --> src/world.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::time::SystemTime;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::camera`
[INFO] [stdout]  --> src/world.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::camera;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::geometry`
[INFO] [stdout]   --> src/world.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::geometry;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CHUNK_SIZE_F`
[INFO] [stdout]   --> src/world.rs:15:27
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::chunk::{Chunk, CHUNK_SIZE_F};
[INFO] [stdout]    |                           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::prelude::*`
[INFO] [stdout]   --> src/world.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use ndarray::prelude::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Array3`
[INFO] [stdout]   --> src/world.rs:18:15
[INFO] [stdout]    |
[INFO] [stdout] 18 | use ndarray::{Array3};
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Vertex`
[INFO] [stdout]  --> src/block.rs:2:23
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::geometry::{Vertex, Facing};
[INFO] [stdout]   |                       ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::prelude::*`
[INFO] [stdout]  --> src/block.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use ndarray::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Array`, `Axis`, and `Ix3`
[INFO] [stdout]  --> src/block.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ndarray::{Array, Ix3, Axis};
[INFO] [stdout]   |               ^^^^^  ^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::RwLock`
[INFO] [stdout]  --> src/chunk.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::sync::RwLock;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]  --> src/chunk.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::sync::Arc;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]    --> src/chunk.rs:146:38
[INFO] [stdout]     |
[INFO] [stdout] 146 |                 .into_iter().map(|x| (x + (i as u32) * 4) )
[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] 146 -                 .into_iter().map(|x| (x + (i as u32) * 4) )
[INFO] [stdout] 146 +                 .into_iter().map(|x| x + (i as u32) * 4  )
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::PoisonError`
[INFO] [stdout]  --> src/memarena.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::sync::PoisonError;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Layout`, `alloc_zeroed`, `alloc`, `dealloc`, and `handle_alloc_error`
[INFO] [stdout]  --> src/memarena.rs:3:18
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::alloc::{alloc, dealloc, Layout, handle_alloc_error, alloc_zeroed};
[INFO] [stdout]   |                  ^^^^^  ^^^^^^^  ^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `align_of` and `size_of`
[INFO] [stdout]  --> src/memarena.rs:5:16
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::mem::{size_of, align_of};
[INFO] [stdout]   |                ^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::slice::Iter`
[INFO] [stdout]  --> src/chunkset.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::slice::Iter;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::prelude::*`
[INFO] [stdout]  --> src/chunkset.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ndarray::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Layout`, `alloc_zeroed`, `alloc`, `dealloc`, and `handle_alloc_error`
[INFO] [stdout]  --> src/chunkset.rs:6:18
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::alloc::{alloc, dealloc, Layout, handle_alloc_error, alloc_zeroed};
[INFO] [stdout]   |                  ^^^^^  ^^^^^^^  ^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `RwLockReadGuard` and `RwLockWriteGuard`
[INFO] [stdout]  --> src/chunkset.rs:7:25
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::sync::{RwLock, RwLockReadGuard, RwLockWriteGuard};
[INFO] [stdout]   |                         ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `align_of` and `size_of`
[INFO] [stdout]  --> src/chunkset.rs:8:16
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::mem::{size_of, align_of};
[INFO] [stdout]   |                ^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::iter::Map`
[INFO] [stdout]  --> src/memblock.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::iter::Map;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::slice::Iter`
[INFO] [stdout]  --> src/memblock.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::slice::Iter;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]   --> src/texturing.rs:45:83
[INFO] [stdout]    |
[INFO] [stdout] 45 |         assert!(dimensions.iter().map(|(x,y)| y).min() == dimensions.iter().map(|(x,y)| y).max());
[INFO] [stdout]    |                                                                                   ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]   --> src/texturing.rs:45:41
[INFO] [stdout]    |
[INFO] [stdout] 45 |         assert!(dimensions.iter().map(|(x,y)| y).min() == dimensions.iter().map(|(x,y)| y).max());
[INFO] [stdout]    |                                         ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `y`
[INFO] [stdout]   --> src/texturing.rs:44:85
[INFO] [stdout]    |
[INFO] [stdout] 44 |         assert!(dimensions.iter().map(|(x,y)| x).min() == dimensions.iter().map(|(x,y)| x).max());
[INFO] [stdout]    |                                                                                     ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `y`
[INFO] [stdout]   --> src/texturing.rs:44:43
[INFO] [stdout]    |
[INFO] [stdout] 44 |         assert!(dimensions.iter().map(|(x,y)| x).min() == dimensions.iter().map(|(x,y)| x).max());
[INFO] [stdout]    |                                           ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]   --> src/texturing.rs:45:83
[INFO] [stdout]    |
[INFO] [stdout] 45 |         assert!(dimensions.iter().map(|(x,y)| y).min() == dimensions.iter().map(|(x,y)| y).max());
[INFO] [stdout]    |                                                                                   ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]   --> src/texturing.rs:45:41
[INFO] [stdout]    |
[INFO] [stdout] 45 |         assert!(dimensions.iter().map(|(x,y)| y).min() == dimensions.iter().map(|(x,y)| y).max());
[INFO] [stdout]    |                                         ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `y`
[INFO] [stdout]   --> src/texturing.rs:44:85
[INFO] [stdout]    |
[INFO] [stdout] 44 |         assert!(dimensions.iter().map(|(x,y)| x).min() == dimensions.iter().map(|(x,y)| x).max());
[INFO] [stdout]    |                                                                                     ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `y`
[INFO] [stdout]   --> src/texturing.rs:44:43
[INFO] [stdout]    |
[INFO] [stdout] 44 |         assert!(dimensions.iter().map(|(x,y)| x).min() == dimensions.iter().map(|(x,y)| x).max());
[INFO] [stdout]    |                                           ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tp`
[INFO] [stdout]   --> src/chunk.rs:99:66
[INFO] [stdout]    |
[INFO] [stdout] 99 |     pub fn make_mesh(&mut self, block_proto_set: &BlockProtoSet, tp: &rayon::ThreadPool) {
[INFO] [stdout]    |                                                                  ^^ help: if this is intentional, prefix it with an underscore: `_tp`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tp`
[INFO] [stdout]   --> src/chunk.rs:99:66
[INFO] [stdout]    |
[INFO] [stdout] 99 |     pub fn make_mesh(&mut self, block_proto_set: &BlockProtoSet, tp: &rayon::ThreadPool) {
[INFO] [stdout]    |                                                                  ^^ help: if this is intentional, prefix it with an underscore: `_tp`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event_loop`
[INFO] [stdout]   --> src/main.rs:46:22
[INFO] [stdout]    |
[INFO] [stdout] 46 |     pub async fn new(event_loop: &EventLoop<()>) -> Self {
[INFO] [stdout]    |                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_loop`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event_loop`
[INFO] [stdout]   --> src/main.rs:46:22
[INFO] [stdout]    |
[INFO] [stdout] 46 |     pub async fn new(event_loop: &EventLoop<()>) -> Self {
[INFO] [stdout]    |                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_loop`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event_loop`
[INFO] [stdout]    --> src/main.rs:120:32
[INFO] [stdout]     |
[INFO] [stdout] 120 |     fn device_event(&mut self, event_loop: &ActiveEventLoop, _: DeviceId, event: DeviceEvent) {
[INFO] [stdout]     |                                ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_loop`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `event_loop`
[INFO] [stdout]    --> src/main.rs:120:32
[INFO] [stdout]     |
[INFO] [stdout] 120 |     fn device_event(&mut self, event_loop: &ActiveEventLoop, _: DeviceId, event: DeviceEvent) {
[INFO] [stdout]     |                                ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_event_loop`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `last_air_pos`
[INFO] [stdout]    --> src/main.rs:240:50
[INFO] [stdout]     |
[INFO] [stdout] 240 | ...                   let (looking_at_pos, last_air_pos, looking_at_id) = player.get_block_looking_at(&self.world);
[INFO] [stdout]     |                                            ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_last_air_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `last_air_pos`
[INFO] [stdout]    --> src/main.rs:240:50
[INFO] [stdout]     |
[INFO] [stdout] 240 | ...                   let (looking_at_pos, last_air_pos, looking_at_id) = player.get_block_looking_at(&self.world);
[INFO] [stdout]     |                                            ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_last_air_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `cursor_moved_by` is never read
[INFO] [stdout]   --> src/main.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | struct Game<'a> {
[INFO] [stdout]    |        ---- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     cursor_moved_by: (f64, f64),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/renderer.rs:17:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | struct FrameData {
[INFO] [stdout]    |        ^^^^^^^^^ field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]   --> src/renderer.rs:15:1
[INFO] [stdout]    |
[INFO] [stdout] 15 | / #[repr(C)]
[INFO] [stdout] 16 | | #[derive(Debug, Copy, Clone, bytemuck::Pod, bytemuck::Zeroable)]
[INFO] [stdout] 17 | | struct FrameData {
[INFO] [stdout] 18 | |     projview: [[f32; 4]; 4]
[INFO] [stdout] 19 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `window`, `index_buffer`, `index_counts`, and `depth_texture_sampler` are never read
[INFO] [stdout]    --> src/renderer.rs:150:5
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub struct Renderer<'a> {
[INFO] [stdout]     |            -------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 150 |     window: Arc<winit::window::Window>,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 164 |     pub index_buffer: Option<wgpu::Buffer>,
[INFO] [stdout]     |         ^^^^^^^^^^^^
[INFO] [stdout] 165 |     index_counts: Vec<u32>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 166 |     depth_texture_view: wgpu::TextureView,
[INFO] [stdout] 167 |     depth_texture_sampler: wgpu::Sampler,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `push_indices` is never used
[INFO] [stdout]    --> src/renderer.rs:368:12
[INFO] [stdout]     |
[INFO] [stdout] 180 | impl<'a> Renderer<'a> {
[INFO] [stdout]     | --------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 368 |     pub fn push_indices(&mut self, indices: Vec<u32>, index_offsets: Vec<u32>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/geometry.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Vertex {
[INFO] [stdout]   |            ^^^^^^ field in this struct
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]  --> src/geometry.rs:3:1
[INFO] [stdout]   |
[INFO] [stdout] 3 | / #[repr(C)]
[INFO] [stdout] 4 | | #[derive(Copy, Clone, Debug, bytemuck::Pod, bytemuck::Zeroable)]
[INFO] [stdout] 5 | | pub struct Vertex {
[INFO] [stdout] 6 | |     pub pos: [f32; 3],
[INFO] [stdout] 7 | |     pub uv: [f32; 2],
[INFO] [stdout] 8 | |     pub tex_id: u32,
[INFO] [stdout] 9 | | }
[INFO] [stdout]   | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `UVS` is never used
[INFO] [stdout]   --> src/geometry.rs:47:7
[INFO] [stdout]    |
[INFO] [stdout] 47 | const UVS: [[f32; 2]; 4] = [
[INFO] [stdout]    |       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CUBE` is never used
[INFO] [stdout]   --> src/geometry.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub const CUBE: [Vertex; 24] = [
[INFO] [stdout]    |           ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `spawn_point`, `need_mesh_update`, and `need_generation_update` are never read
[INFO] [stdout]   --> src/world.rs:32:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct World {
[INFO] [stdout]    |            ----- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub spawn_point: Vec3,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub need_mesh_update: Mutex<VecDeque<ArenaHandle<Chunk>>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 38 |     pub need_generation_update: Mutex<VecDeque<ArenaHandle<Chunk>>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_moving_forward` and `clear_moving` are never used
[INFO] [stdout]    --> src/entity.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout]  53 | impl Entity {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn get_moving_forward(&self, fac: f32) -> Vec3 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn clear_moving(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEG_TO_RAD` is never used
[INFO] [stdout]   --> src/camera.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const DEG_TO_RAD: f32 = 0.0174532925;
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_fov` is never used
[INFO] [stdout]   --> src/camera.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl Camera {
[INFO] [stdout]    | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn set_fov(&mut self, fov_deg: f32) {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `texture`, `view`, and `sampler` are never read
[INFO] [stdout]  --> src/texturing.rs:2:9
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct TextureSet {
[INFO] [stdout]   |            ---------- fields in this struct
[INFO] [stdout] 2 |     pub texture: wgpu::Texture,
[INFO] [stdout]   |         ^^^^^^^
[INFO] [stdout] 3 |     pub view: wgpu::TextureView,
[INFO] [stdout]   |         ^^^^
[INFO] [stdout] 4 |     pub sampler: wgpu::Sampler,
[INFO] [stdout]   |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `transparent` is never read
[INFO] [stdout]   --> src/block.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct BlockProto {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub transparent: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BlockProto` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `visibility_array` is never read
[INFO] [stdout]   --> src/chunk.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct Chunk {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 22 |     visibility_array: ChunkArray<u8>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Chunk` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `check_inside_me` and `generate_flat` are never used
[INFO] [stdout]   --> src/chunk.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl<'a> Chunk {
[INFO] [stdout]    | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn check_inside_me(&self, x: f32, y: f32, z: f32) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 71 |     pub fn generate_flat(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `from_iter`, `overwrite`, and `destroy` are never used
[INFO] [stdout]    --> src/memarena.rs:84:12
[INFO] [stdout]     |
[INFO] [stdout]  61 | impl<T> Arena<T> {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  84 |     pub fn from_iter<I>(length: usize, iterator: I) -> Self where I: IntoIterator<Item=T> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     unsafe fn overwrite(&mut self, index: usize, obj: T) {
[INFO] [stdout]     |               ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn destroy(&mut self, handle: ArenaHandle<T>) -> Result<(), ArenaError> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `arr_vol` is never read
[INFO] [stdout]   --> src/chunkset.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct ChunkSet {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 20 |     arr_vol: usize,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `MemoryError` is never used
[INFO] [stdout]  --> src/memblock.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub enum MemoryError {
[INFO] [stdout]   |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `bounds_check`, `allocated_check`, `get_ptr`, and `get_ptr_unchecked` are never used
[INFO] [stdout]    --> src/memblock.rs:62:8
[INFO] [stdout]     |
[INFO] [stdout]  33 | impl<T> MemoryBlock<T> {
[INFO] [stdout]     | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  62 |     fn bounds_check(&self, index: usize) -> Result<(), MemoryError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  68 |     fn allocated_check(&self, index: usize) -> Result<(), MemoryError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn get_ptr(&self, index: usize) -> Result<*mut T, MemoryError> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub unsafe fn get_ptr_unchecked(&self, index: usize) -> *mut T {
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `cursor_moved_by` is never read
[INFO] [stdout]   --> src/main.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | struct Game<'a> {
[INFO] [stdout]    |        ---- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 39 |     cursor_moved_by: (f64, f64),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/renderer.rs:17:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | struct FrameData {
[INFO] [stdout]    |        ^^^^^^^^^ field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]   --> src/renderer.rs:15:1
[INFO] [stdout]    |
[INFO] [stdout] 15 | / #[repr(C)]
[INFO] [stdout] 16 | | #[derive(Debug, Copy, Clone, bytemuck::Pod, bytemuck::Zeroable)]
[INFO] [stdout] 17 | | struct FrameData {
[INFO] [stdout] 18 | |     projview: [[f32; 4]; 4]
[INFO] [stdout] 19 | | }
[INFO] [stdout]    | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `window`, `index_buffer`, `index_counts`, and `depth_texture_sampler` are never read
[INFO] [stdout]    --> src/renderer.rs:150:5
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub struct Renderer<'a> {
[INFO] [stdout]     |            -------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 150 |     window: Arc<winit::window::Window>,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 164 |     pub index_buffer: Option<wgpu::Buffer>,
[INFO] [stdout]     |         ^^^^^^^^^^^^
[INFO] [stdout] 165 |     index_counts: Vec<u32>,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 166 |     depth_texture_view: wgpu::TextureView,
[INFO] [stdout] 167 |     depth_texture_sampler: wgpu::Sampler,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `push_indices` is never used
[INFO] [stdout]    --> src/renderer.rs:368:12
[INFO] [stdout]     |
[INFO] [stdout] 180 | impl<'a> Renderer<'a> {
[INFO] [stdout]     | --------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 368 |     pub fn push_indices(&mut self, indices: Vec<u32>, index_offsets: Vec<u32>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/geometry.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Vertex {
[INFO] [stdout]   |            ^^^^^^ field in this struct
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check` is never used
[INFO] [stdout]  --> src/geometry.rs:3:1
[INFO] [stdout]   |
[INFO] [stdout] 3 | / #[repr(C)]
[INFO] [stdout] 4 | | #[derive(Copy, Clone, Debug, bytemuck::Pod, bytemuck::Zeroable)]
[INFO] [stdout] 5 | | pub struct Vertex {
[INFO] [stdout] 6 | |     pub pos: [f32; 3],
[INFO] [stdout] 7 | |     pub uv: [f32; 2],
[INFO] [stdout] 8 | |     pub tex_id: u32,
[INFO] [stdout] 9 | | }
[INFO] [stdout]   | |_^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `UVS` is never used
[INFO] [stdout]   --> src/geometry.rs:47:7
[INFO] [stdout]    |
[INFO] [stdout] 47 | const UVS: [[f32; 2]; 4] = [
[INFO] [stdout]    |       ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CUBE` is never used
[INFO] [stdout]   --> src/geometry.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub const CUBE: [Vertex; 24] = [
[INFO] [stdout]    |           ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `spawn_point`, `need_mesh_update`, and `need_generation_update` are never read
[INFO] [stdout]   --> src/world.rs:32:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct World {
[INFO] [stdout]    |            ----- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub spawn_point: Vec3,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub need_mesh_update: Mutex<VecDeque<ArenaHandle<Chunk>>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 38 |     pub need_generation_update: Mutex<VecDeque<ArenaHandle<Chunk>>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_moving_forward` and `clear_moving` are never used
[INFO] [stdout]    --> src/entity.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout]  53 | impl Entity {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 142 |     pub fn get_moving_forward(&self, fac: f32) -> Vec3 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 156 |     pub fn clear_moving(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEG_TO_RAD` is never used
[INFO] [stdout]   --> src/camera.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const DEG_TO_RAD: f32 = 0.0174532925;
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_fov` is never used
[INFO] [stdout]   --> src/camera.rs:31:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl Camera {
[INFO] [stdout]    | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn set_fov(&mut self, fov_deg: f32) {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `texture`, `view`, and `sampler` are never read
[INFO] [stdout]  --> src/texturing.rs:2:9
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct TextureSet {
[INFO] [stdout]   |            ---------- fields in this struct
[INFO] [stdout] 2 |     pub texture: wgpu::Texture,
[INFO] [stdout]   |         ^^^^^^^
[INFO] [stdout] 3 |     pub view: wgpu::TextureView,
[INFO] [stdout]   |         ^^^^
[INFO] [stdout] 4 |     pub sampler: wgpu::Sampler,
[INFO] [stdout]   |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `transparent` is never read
[INFO] [stdout]   --> src/block.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct BlockProto {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub transparent: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `BlockProto` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `visibility_array` is never read
[INFO] [stdout]   --> src/chunk.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct Chunk {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 22 |     visibility_array: ChunkArray<u8>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Chunk` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `check_inside_me` and `generate_flat` are never used
[INFO] [stdout]   --> src/chunk.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 30 | impl<'a> Chunk {
[INFO] [stdout]    | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn check_inside_me(&self, x: f32, y: f32, z: f32) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 71 |     pub fn generate_flat(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `from_iter`, `overwrite`, and `destroy` are never used
[INFO] [stdout]    --> src/memarena.rs:84:12
[INFO] [stdout]     |
[INFO] [stdout]  61 | impl<T> Arena<T> {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  84 |     pub fn from_iter<I>(length: usize, iterator: I) -> Self where I: IntoIterator<Item=T> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     unsafe fn overwrite(&mut self, index: usize, obj: T) {
[INFO] [stdout]     |               ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn destroy(&mut self, handle: ArenaHandle<T>) -> Result<(), ArenaError> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `arr_vol` is never read
[INFO] [stdout]   --> src/chunkset.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct ChunkSet {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 20 |     arr_vol: usize,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `MemoryError` is never used
[INFO] [stdout]  --> src/memblock.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub enum MemoryError {
[INFO] [stdout]   |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `bounds_check`, `allocated_check`, `get_ptr`, and `get_ptr_unchecked` are never used
[INFO] [stdout]    --> src/memblock.rs:62:8
[INFO] [stdout]     |
[INFO] [stdout]  33 | impl<T> MemoryBlock<T> {
[INFO] [stdout]     | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  62 |     fn bounds_check(&self, index: usize) -> Result<(), MemoryError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  68 |     fn allocated_check(&self, index: usize) -> Result<(), MemoryError> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn get_ptr(&self, index: usize) -> Result<*mut T, MemoryError> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub unsafe fn get_ptr_unchecked(&self, index: usize) -> *mut T {
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `std::result::Result` that must be used
[INFO] [stdout]   --> src/main.rs:77:13
[INFO] [stdout]    |
[INFO] [stdout] 77 |             window.set_cursor_grab(winit::window::CursorGrabMode::Locked);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 77 |             let _ = window.set_cursor_grab(winit::window::CursorGrabMode::Locked);
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `std::result::Result` that must be used
[INFO] [stdout]   --> src/main.rs:93:9
[INFO] [stdout]    |
[INFO] [stdout] 93 |         window.set_cursor_grab(winit::window::CursorGrabMode::None);
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 93 |         let _ = window.set_cursor_grab(winit::window::CursorGrabMode::None);
[INFO] [stdout]    |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer.rs:43:26
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub fn get_text_area(&self, tm: &TextManager) -> glyphon::TextArea {
[INFO] [stdout]    |                          ^^^^^                       ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                          |
[INFO] [stdout]    |                          the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub fn get_text_area(&self, tm: &TextManager) -> glyphon::TextArea<'_> {
[INFO] [stdout]    |                                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `FORWARD` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub FORWARD: bool,
[INFO] [stdout]    |         ^^^^^^^ help: convert the identifier to snake case: `forward`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `BACKWARD` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub BACKWARD: bool,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `backward`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `RIGHT` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub RIGHT: bool,
[INFO] [stdout]    |         ^^^^^ help: convert the identifier to snake case: `right`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `LEFT` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub LEFT: bool,
[INFO] [stdout]    |         ^^^^ help: convert the identifier to snake case: `left`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `UP` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub UP: bool,
[INFO] [stdout]    |         ^^ help: convert the identifier to snake case: `up`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `DOWN` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub DOWN: bool,
[INFO] [stdout]    |         ^^^^ help: convert the identifier to snake case: `down`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `SPRINT` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub SPRINT: bool,
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `sprint`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `BlockProtoDefaults` should have a snake case name
[INFO] [stdout]  --> src/block.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | mod BlockProtoDefaults {
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `block_proto_defaults`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `True` should have a snake case name
[INFO] [stdout]   --> src/block.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub fn True () -> bool {true}
[INFO] [stdout]    |            ^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: rename the identifier or convert it to a snake case raw identifier
[INFO] [stdout]    |
[INFO] [stdout] 10 -     pub fn True () -> bool {true}
[INFO] [stdout] 10 +     pub fn r#true () -> bool {true}
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `TexFaceMapZeros` should have a snake case name
[INFO] [stdout]   --> src/block.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub fn TexFaceMapZeros () -> [usize; 6] {[0, 0, 0, 0, 0, 0]}
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tex_face_map_zeros`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/memarena.rs:96:17
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn iter(&self) -> ArenaIterator<T> {
[INFO] [stdout]    |                 ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn iter(&self) -> ArenaIterator<'_, T> {
[INFO] [stdout]    |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/memarena.rs:139:22
[INFO] [stdout]     |
[INFO] [stdout] 139 |     pub fn read_lock(&self, handle: ArenaHandle<T>) -> Result<RwLockReadGuard<T>, ArenaError> {
[INFO] [stdout]     |                      ^^^^^ the lifetime is elided here        ^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 139 |     pub fn read_lock(&self, handle: ArenaHandle<T>) -> Result<RwLockReadGuard<'_, T>, ArenaError> {
[INFO] [stdout]     |                                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/memarena.rs:145:23
[INFO] [stdout]     |
[INFO] [stdout] 145 |     pub fn write_lock(&self, handle: ArenaHandle<T>) -> Result<RwLockWriteGuard<T>, ArenaError> {
[INFO] [stdout]     |                       ^^^^^ the lifetime is elided here        ^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 145 |     pub fn write_lock(&self, handle: ArenaHandle<T>) -> Result<RwLockWriteGuard<'_, T>, ArenaError> {
[INFO] [stdout]     |                                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `std::result::Result` that must be used
[INFO] [stdout]   --> src/main.rs:77:13
[INFO] [stdout]    |
[INFO] [stdout] 77 |             window.set_cursor_grab(winit::window::CursorGrabMode::Locked);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 77 |             let _ = window.set_cursor_grab(winit::window::CursorGrabMode::Locked);
[INFO] [stdout]    |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `std::result::Result` that must be used
[INFO] [stdout]   --> src/main.rs:93:9
[INFO] [stdout]    |
[INFO] [stdout] 93 |         window.set_cursor_grab(winit::window::CursorGrabMode::None);
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 93 |         let _ = window.set_cursor_grab(winit::window::CursorGrabMode::None);
[INFO] [stdout]    |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/renderer.rs:43:26
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub fn get_text_area(&self, tm: &TextManager) -> glyphon::TextArea {
[INFO] [stdout]    |                          ^^^^^                       ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                          |
[INFO] [stdout]    |                          the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub fn get_text_area(&self, tm: &TextManager) -> glyphon::TextArea<'_> {
[INFO] [stdout]    |                                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `FORWARD` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub FORWARD: bool,
[INFO] [stdout]    |         ^^^^^^^ help: convert the identifier to snake case: `forward`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `BACKWARD` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub BACKWARD: bool,
[INFO] [stdout]    |         ^^^^^^^^ help: convert the identifier to snake case: `backward`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `RIGHT` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub RIGHT: bool,
[INFO] [stdout]    |         ^^^^^ help: convert the identifier to snake case: `right`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `LEFT` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub LEFT: bool,
[INFO] [stdout]    |         ^^^^ help: convert the identifier to snake case: `left`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `UP` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub UP: bool,
[INFO] [stdout]    |         ^^ help: convert the identifier to snake case: `up`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `DOWN` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub DOWN: bool,
[INFO] [stdout]    |         ^^^^ help: convert the identifier to snake case: `down`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `SPRINT` should have a snake case name
[INFO] [stdout]   --> src/entity.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub SPRINT: bool,
[INFO] [stdout]    |         ^^^^^^ help: convert the identifier to snake case: `sprint`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `BlockProtoDefaults` should have a snake case name
[INFO] [stdout]  --> src/block.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | mod BlockProtoDefaults {
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `block_proto_defaults`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `True` should have a snake case name
[INFO] [stdout]   --> src/block.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub fn True () -> bool {true}
[INFO] [stdout]    |            ^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: rename the identifier or convert it to a snake case raw identifier
[INFO] [stdout]    |
[INFO] [stdout] 10 -     pub fn True () -> bool {true}
[INFO] [stdout] 10 +     pub fn r#true () -> bool {true}
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `TexFaceMapZeros` should have a snake case name
[INFO] [stdout]   --> src/block.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub fn TexFaceMapZeros () -> [usize; 6] {[0, 0, 0, 0, 0, 0]}
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `tex_face_map_zeros`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/memarena.rs:96:17
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn iter(&self) -> ArenaIterator<T> {
[INFO] [stdout]    |                 ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 96 |     pub fn iter(&self) -> ArenaIterator<'_, T> {
[INFO] [stdout]    |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/memarena.rs:139:22
[INFO] [stdout]     |
[INFO] [stdout] 139 |     pub fn read_lock(&self, handle: ArenaHandle<T>) -> Result<RwLockReadGuard<T>, ArenaError> {
[INFO] [stdout]     |                      ^^^^^ the lifetime is elided here        ^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 139 |     pub fn read_lock(&self, handle: ArenaHandle<T>) -> Result<RwLockReadGuard<'_, T>, ArenaError> {
[INFO] [stdout]     |                                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/memarena.rs:145:23
[INFO] [stdout]     |
[INFO] [stdout] 145 |     pub fn write_lock(&self, handle: ArenaHandle<T>) -> Result<RwLockWriteGuard<T>, ArenaError> {
[INFO] [stdout]     |                       ^^^^^ the lifetime is elided here        ^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 145 |     pub fn write_lock(&self, handle: ArenaHandle<T>) -> Result<RwLockWriteGuard<'_, T>, ArenaError> {
[INFO] [stdout]     |                                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [optimized + debuginfo] target(s) in 3m 04s
[INFO] running `Command { std: "docker" "inspect" "8a6f00b19ca426159cc7c7980a5a22d22bc632d7869c54b5aa4e4ae4d433ea21", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8a6f00b19ca426159cc7c7980a5a22d22bc632d7869c54b5aa4e4ae4d433ea21", kill_on_drop: false }`
[INFO] [stdout] 8a6f00b19ca426159cc7c7980a5a22d22bc632d7869c54b5aa4e4ae4d433ea21
