[INFO] cloning repository https://github.com/AlkimiaStudios/alkahest-rs
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/AlkimiaStudios/alkahest-rs" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAlkimiaStudios%2Falkahest-rs", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAlkimiaStudios%2Falkahest-rs'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 5300df9b8e6e593189751634f00b09d96e4e809a
[INFO] documenting AlkimiaStudios/alkahest-rs against beta-2025-09-21 for beta-rustdoc-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAlkimiaStudios%2Falkahest-rs" "/workspace/builds/worker-0-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/AlkimiaStudios/alkahest-rs
[INFO] finished tweaking git repo https://github.com/AlkimiaStudios/alkahest-rs
[INFO] tweaked toml for git repo https://github.com/AlkimiaStudios/alkahest-rs written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/AlkimiaStudios/alkahest-rs on toolchain beta-2025-09-21
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/AlkimiaStudios/alkahest-rs already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 85efb3574a6b4bbded54114c61160048a787783d0d4bd1fc745640b04111d774
[INFO] running `Command { std: "docker" "start" "-a" "85efb3574a6b4bbded54114c61160048a787783d0d4bd1fc745640b04111d774", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "85efb3574a6b4bbded54114c61160048a787783d0d4bd1fc745640b04111d774", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "85efb3574a6b4bbded54114c61160048a787783d0d4bd1fc745640b04111d774", kill_on_drop: false }`
[INFO] [stdout] 85efb3574a6b4bbded54114c61160048a787783d0d4bd1fc745640b04111d774
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "doc" "--frozen" "--no-deps" "--document-private-items" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cdc1dfafe53be6c0069f1f7349dc9ad1c3fb556a050c3d43e7ee9aa52e41f254
[INFO] running `Command { std: "docker" "start" "-a" "cdc1dfafe53be6c0069f1f7349dc9ad1c3fb556a050c3d43e7ee9aa52e41f254", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.134
[INFO] [stderr]    Compiling proc-macro2 v1.0.46
[INFO] [stderr]    Compiling syn v1.0.101
[INFO] [stderr]    Compiling crossbeam-utils v0.8.14
[INFO] [stderr]    Compiling memoffset v0.7.1
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.13
[INFO] [stderr]    Compiling rayon-core v1.10.1
[INFO] [stderr]     Checking miniz_oxide v0.6.2
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]    Compiling futures-core v0.3.24
[INFO] [stderr]     Checking either v1.8.0
[INFO] [stderr]     Checking bytemuck v1.12.3
[INFO] [stderr]    Compiling serde v1.0.147
[INFO] [stderr]    Compiling glfw-sys v4.0.0+3.3.5
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]     Checking spin v0.9.4
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]     Checking once_cell v1.15.0
[INFO] [stderr]     Checking futures-sink v0.3.24
[INFO] [stderr]     Checking weezl v0.1.7
[INFO] [stderr]     Checking lebe v0.5.2
[INFO] [stderr]     Checking safe_arch v0.6.0
[INFO] [stderr]     Checking cty v0.2.2
[INFO] [stderr]     Checking smallvec v1.10.0
[INFO] [stderr]     Checking bit_field v0.10.1
[INFO] [stderr]    Compiling serde_derive v1.0.147
[INFO] [stderr]     Checking half v2.1.0
[INFO] [stderr]     Checking raw-window-handle v0.4.3
[INFO] [stderr]     Checking gif v0.11.4
[INFO] [stderr]     Checking iana-time-zone v0.1.50
[INFO] [stderr]     Checking crossbeam-channel v0.5.6
[INFO] [stderr]     Checking scoped_threadpool v0.1.9
[INFO] [stderr]     Checking crossbeam-deque v0.8.2
[INFO] [stderr]     Checking flate2 v1.0.25
[INFO] [stderr]    Compiling gl v0.14.0
[INFO] [stderr]     Checking getrandom v0.2.7
[INFO] [stderr]     Checking num_cpus v1.14.0
[INFO] [stderr]     Checking time v0.1.44
[INFO] [stderr]     Checking nanorand v0.7.0
[INFO] [stderr]     Checking ahash v0.7.6
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking threadpool v1.8.1
[INFO] [stderr]     Checking wide v0.7.5
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking chrono v0.4.22
[INFO] [stderr]     Checking png v0.17.7
[INFO] [stderr]    Compiling quote v1.0.21
[INFO] [stderr]     Checking hashbrown v0.11.2
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking rayon v1.6.0
[INFO] [stderr]     Checking ultraviolet v0.9.0
[INFO] [stderr]     Checking jpeg-decoder v0.3.0
[INFO] [stderr]     Checking toml v0.5.9
[INFO] [stderr]     Checking string-interner v0.14.0
[INFO] [stderr]     Checking glfw v0.45.0
[INFO] [stderr]     Checking tiff v0.8.0
[INFO] [stderr]    Compiling pin-project-internal v1.0.12
[INFO] [stderr]    Compiling modular-bitfield-impl v0.11.2
[INFO] [stderr]     Checking pin-project v1.0.12
[INFO] [stderr]     Checking flume v0.10.14
[INFO] [stderr]     Checking exr v1.5.2
[INFO] [stderr]     Checking modular-bitfield v0.11.2
[INFO] [stderr]     Checking image v0.24.5
[INFO] [stderr]     Checking alkahest v0.1.0 (/opt/rustwide/workdir/alkahest)
[INFO] [stdout] warning: unused import: `crate::trace`
[INFO] [stdout]  --> alkahest/src/render/primitives/texture.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::trace;
[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: `transform::*`
[INFO] [stdout]   --> alkahest/src/render/primitives/mod.rs:16:16
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub(crate) use transform::*;
[INFO] [stdout]    |                ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `trace`
[INFO] [stdout]  --> alkahest/src/render/command.rs:4:13
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::{trace, error};
[INFO] [stdout]   |             ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::Rng`
[INFO] [stdout]  --> alkahest/src/render/mod.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use rand::Rng;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::trace`
[INFO] [stdout]  --> alkahest/src/render/mod.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::trace;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `command::*`
[INFO] [stdout]   --> alkahest/src/render/mod.rs:12:16
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) use command::*;
[INFO] [stdout]    |                ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: glob import doesn't reexport anything with visibility `pub` because no imported item is public enough
[INFO] [stdout]  --> alkahest/src/util/asynchronous/mod.rs:2:9
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub use job_system::*;
[INFO] [stdout]   |         ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout] note: the most public imported item is `pub(crate)`
[INFO] [stdout]  --> alkahest/src/util/asynchronous/mod.rs:2:9
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub use job_system::*;
[INFO] [stdout]   |         ^^^^^^^^^^^^^
[INFO] [stdout]   = help: reduce the glob import's visibility or increase visibility of imported items
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]  --> alkahest/src/util/containers/handle_map.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 |     index: B32,
[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] 8 -     index: B32,
[INFO] [stdout] 8 +     nde: B32,
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]  --> alkahest/src/util/containers/handle_map.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     generation: B16,
[INFO] [stdout]   |     ^        ^
[INFO] [stdout]   |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]   |
[INFO] [stdout] 9 -     generation: B16,
[INFO] [stdout] 9 +     eneratio: B16,
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> alkahest/src/util/containers/handle_map.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     item_type: B15,
[INFO] [stdout]    |     ^       ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 10 -     item_type: B15,
[INFO] [stdout] 10 +     tem_typ: B15,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> alkahest/src/util/containers/handle_map.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     free: B1,
[INFO] [stdout]    |     ^  ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 11 -     free: B1,
[INFO] [stdout] 11 +     re: B1,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: glob import doesn't reexport anything with visibility `pub` because no imported item is public enough
[INFO] [stdout]  --> alkahest/src/util/resources/mod.rs:2:9
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub use config_manager::*;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout] note: the most public imported item is `pub(crate)`
[INFO] [stdout]  --> alkahest/src/util/resources/mod.rs:2:9
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub use config_manager::*;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   = help: reduce the glob import's visibility or increase visibility of imported items
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]  --> alkahest/src/util/resources/tex.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::fs::File;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `image::io::Reader`
[INFO] [stdout]  --> alkahest/src/util/resources/tex.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use image::io::Reader;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Cursor`
[INFO] [stdout]  --> alkahest/src/util/resources/tex.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::io::Cursor;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::prelude`
[INFO] [stdout]  --> alkahest/src/util/resources/tex.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::io::prelude::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `root`
[INFO] [stdout]    --> alkahest/src/render/ui_renderer/mod.rs:113:22
[INFO] [stdout]     |
[INFO] [stdout] 113 |     pub fn draw_tree(root: &UIRoot) {
[INFO] [stdout]     |                      ^^^^ help: if this is intentional, prefix it with an underscore: `_root`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `cleanup` is never used
[INFO] [stdout]   --> alkahest/src/render/mod.rs:91:12
[INFO] [stdout]    |
[INFO] [stdout] 36 | impl RenderContext {
[INFO] [stdout]    | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 91 |     pub fn cleanup(&self) {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `new_from_arr`, and `destroy` are never used
[INFO] [stdout]   --> alkahest/src/render/primitives/index_buffer.rs:9:19
[INFO] [stdout]    |
[INFO] [stdout]  8 | impl IndexBuffer {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout]  9 |     pub unsafe fn new(indices: Vec<u32>) -> Self {
[INFO] [stdout]    |                   ^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub unsafe fn new_from_arr(indices: &[u32]) -> Self {
[INFO] [stdout]    |                   ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 68 |     pub unsafe fn destroy(&self) {
[INFO] [stdout]    |                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `new_from_arr`, and `destroy` are never used
[INFO] [stdout]   --> alkahest/src/render/primitives/vertex_buffer.rs:11:19
[INFO] [stdout]    |
[INFO] [stdout] 10 | impl<T> VertexBuffer<T> {
[INFO] [stdout]    | ----------------------- associated items in this implementation
[INFO] [stdout] 11 |     pub unsafe fn new(vertices: Vec<T>) -> Self {
[INFO] [stdout]    |                   ^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     pub unsafe fn new_from_arr(vertices: &[T]) -> Self {
[INFO] [stdout]    |                   ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 |     pub unsafe fn destroy(&self) {
[INFO] [stdout]    |                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `destroy` is never used
[INFO] [stdout]   --> alkahest/src/render/primitives/vertex_array.rs:45:19
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl VertexArray {
[INFO] [stdout]    | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub unsafe fn destroy(&self) {
[INFO] [stdout]    |                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_uniform_vec4` and `destroy` are never used
[INFO] [stdout]    --> alkahest/src/render/primitives/shader_program.rs:161:19
[INFO] [stdout]     |
[INFO] [stdout]  14 | impl ShaderProgram {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub unsafe fn set_uniform_vec4(&self, name: &str, value: &Vec4) {
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 180 |     pub unsafe fn destroy(&self) {
[INFO] [stdout]     |                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_position`, `set_position`, `get_rotation`, `set_rotation`, and `get_view_matrix` are never used
[INFO] [stdout]   --> alkahest/src/render/primitives/camera.rs:6:8
[INFO] [stdout]    |
[INFO] [stdout]  3 | pub trait Camera {
[INFO] [stdout]    |           ------ methods in this trait
[INFO] [stdout] ...
[INFO] [stdout]  6 |     fn get_position(&self) -> &Vec3;
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout]  7 |     fn set_position(&mut self, position: Vec3);
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout]  8 |     fn get_rotation(&self) -> &Vec3;
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout]  9 |     fn set_rotation(&mut self, rotation: Vec3);
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 10 |
[INFO] [stdout] 11 |     fn get_view_matrix(&self) -> &Mat4;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Camera3D` is never constructed
[INFO] [stdout]   --> alkahest/src/render/primitives/camera.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct Camera3D {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> alkahest/src/render/primitives/camera.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | impl Camera3D {
[INFO] [stdout]    | ------------- associated function in this implementation
[INFO] [stdout] 49 |     pub fn new(fov: f32, aspect_ratio: f32, near_plane: f32, far_plane: f32) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Transform` is never constructed
[INFO] [stdout]  --> alkahest/src/render/primitives/transform.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub struct Transform {
[INFO] [stdout]   |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> alkahest/src/render/primitives/transform.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl Transform {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 10 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub fn get_matrix(&self) -> Mat4 {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33 |     pub fn get_position(&self) -> &Vec3 {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn set_position(&mut self, position: Vec3) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn get_rotation(&self) -> &Vec3 {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn set_rotation(&mut self, rotation: Vec3) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn get_scale(&self) -> &Vec3 {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn set_scale(&mut self, scale: Vec3) {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `QUAD_VERTICES` is never used
[INFO] [stdout]   --> alkahest/src/render/renderer_2d/mod.rs:44:7
[INFO] [stdout]    |
[INFO] [stdout] 44 | const QUAD_VERTICES: [Vec4; 4] = [
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `cleanup` is never used
[INFO] [stdout]    --> alkahest/src/render/renderer_2d/mod.rs:263:19
[INFO] [stdout]     |
[INFO] [stdout]  67 | impl Renderer2D {
[INFO] [stdout]     | --------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 263 |     pub unsafe fn cleanup() {
[INFO] [stdout]     |                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `cleanup`, `clear_buffers`, and `draw_tree` are never used
[INFO] [stdout]    --> alkahest/src/render/ui_renderer/mod.rs:103:12
[INFO] [stdout]     |
[INFO] [stdout]  36 | impl UIRenderer {
[INFO] [stdout]     | --------------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 103 |     pub fn cleanup() {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     fn clear_buffers() {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 113 |     pub fn draw_tree(root: &UIRoot) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `enable` is never used
[INFO] [stdout]  --> alkahest/src/render/command.rs:7:22
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub(crate) unsafe fn enable(cap: GLenum) {
[INFO] [stdout]   |                      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `set_blend_func` is never used
[INFO] [stdout]   --> alkahest/src/render/command.rs:11:22
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub(crate) unsafe fn set_blend_func(s_factor: GLenum, d_factor: GLenum) {
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `transform` is never read
[INFO] [stdout]   --> alkahest/src/render/ui/mod.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct BaseChild {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 40 |     transform: Mat4,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `CURRENT_LABEL` is never used
[INFO] [stdout]  --> alkahest/src/util/asynchronous/job_system.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | static mut CURRENT_LABEL: u64 = 0;
[INFO] [stdout]   |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `GroupJob` is never constructed
[INFO] [stdout]   --> alkahest/src/util/asynchronous/job_system.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | struct GroupJob {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `sender` is never read
[INFO] [stdout]   --> alkahest/src/util/asynchronous/job_system.rs:52:5
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub(crate) struct AsyncContext {
[INFO] [stdout]    |                   ------------ field in this struct
[INFO] [stdout] 52 |     sender: flume::Sender<Box<dyn Job>>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `poll`, `dispatch`, `dispatch_many`, `is_busy`, and `wait` are never used
[INFO] [stdout]    --> alkahest/src/util/asynchronous/job_system.rs:99:19
[INFO] [stdout]     |
[INFO] [stdout]  98 | impl AsyncContext {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout]  99 |     pub(super) fn poll(&self) {
[INFO] [stdout]     |                   ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub(crate) fn dispatch(&self, job: Box<dyn Job>) {
[INFO] [stdout]     |                   ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 118 |     pub(crate) fn dispatch_many(&self, job_count: u32, group_size: u32, job: Box<dyn Job>) {
[INFO] [stdout]     |                   ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 131 |     pub(crate) fn is_busy(&self) -> bool {
[INFO] [stdout]     |                   ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub(crate) fn wait(&self) {
[INFO] [stdout]     |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `free` is never used
[INFO] [stdout]   --> alkahest/src/util/containers/handle_map.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout]  4 | /// Handle used to access items in a HandleMap
[INFO] [stdout]    | ---------------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 11 |     free: B1,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config_context` is never read
[INFO] [stdout]   --> alkahest/src/util/context.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub(crate) struct Context {
[INFO] [stdout]    |                   ------- field in this struct
[INFO] [stdout] 10 |     pub config_context: ConfigContext,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `init`, `load_to_cache`, `load_from_cache`, and `purge_from_cache` are never used
[INFO] [stdout]   --> alkahest/src/util/resources/mod.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) trait AssetManager<T> where T: Asset + Clone {
[INFO] [stdout]    |                  ------------ associated items in this trait
[INFO] [stdout] 13 |     fn init(cache_size: usize) -> Self;
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 14 |     fn load_to_cache(&mut self, path: String) -> AssetHandle;
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 15 |     fn load_direct(path: String) -> T;
[INFO] [stdout] 16 |     fn load_from_cache(&self, handle: AssetHandle) -> Result<T, ContainerError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 17 |     fn purge_from_cache(&mut self, handle: AssetHandle) -> Result<(), ContainerError>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `cache` and `file_map` are never read
[INFO] [stdout]   --> alkahest/src/util/resources/config_manager.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub(crate) struct ConfigManager {
[INFO] [stdout]    |                   ------------- fields in this struct
[INFO] [stdout] 36 |     cache: HandleMap<ConfigContext>,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 37 |     file_map: HashMap<DefaultSymbol, AssetHandle>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `cache` and `file_map` are never read
[INFO] [stdout]   --> alkahest/src/util/resources/tex.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct TextureManager {
[INFO] [stdout]    |            -------------- fields in this struct
[INFO] [stdout] 21 |     cache: HandleMap<TextureData>,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 22 |     file_map: HashMap<DefaultSymbol, AssetHandle>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `cache` and `file_map` are never read
[INFO] [stdout]   --> alkahest/src/util/resources/shader_manager.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct ShaderManager {
[INFO] [stdout]    |            ------------- fields in this struct
[INFO] [stdout] 16 |     cache: HandleMap<Shader>,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 17 |     file_map: HashMap<DefaultSymbol, AssetHandle>,    
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> alkahest/src/game/timestep.rs:7:1
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct Time {}
[INFO] [stdout]   | ^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout] note: the lint level is defined here
[INFO] [stdout]  --> alkahest/src/lib.rs:1:9
[INFO] [stdout]   |
[INFO] [stdout] 1 | #![warn(missing_docs)]
[INFO] [stdout]   |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> alkahest/src/game/timestep.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub fn now() -> f64 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> alkahest/src/game/timestep.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub fn update() {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> alkahest/src/game/timestep.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     pub fn delta() -> f64 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> alkahest/src/render/mod.rs:5:1
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub mod ui;
[INFO] [stdout]   | ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> alkahest/src/render/mod.rs:17:1
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct Vertex {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/mod.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     pub x: f32,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/mod.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     pub y: f32,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/mod.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     pub z: f32,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> alkahest/src/render/mod.rs:24:1
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct Color {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/mod.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     pub r: f32,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     pub g: f32,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/mod.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     pub b: f32,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]    --> alkahest/src/render/renderer_2d/mod.rs:112:32
[INFO] [stdout]     |
[INFO] [stdout] 112 |         if let Some(context) = &RENDER_CONTEXT {
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stdout] help: use `&raw const` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 112 |         if let Some(context) = &raw const RENDER_CONTEXT {
[INFO] [stdout]     |                                 +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static
[INFO] [stdout]    --> alkahest/src/render/renderer_2d/mod.rs:135:32
[INFO] [stdout]     |
[INFO] [stdout] 135 |         if let Some(context) = &mut RENDER_CONTEXT {
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: mutable references to mutable statics are dangerous; it's undefined behavior if any other pointer to the static is used or if any other reference is created for the static while the mutable reference lives
[INFO] [stdout] help: use `&raw mut` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 135 |         if let Some(context) = &raw mut RENDER_CONTEXT {
[INFO] [stdout]     |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]    --> alkahest/src/render/renderer_2d/mod.rs:136:40
[INFO] [stdout]     |
[INFO] [stdout] 136 |             if let Some(_scene_data) = &SCENE_DATA {
[INFO] [stdout]     |                                        ^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] help: use `&raw const` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 136 |             if let Some(_scene_data) = &raw const SCENE_DATA {
[INFO] [stdout]     |                                         +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static
[INFO] [stdout]    --> alkahest/src/render/renderer_2d/mod.rs:222:32
[INFO] [stdout]     |
[INFO] [stdout] 222 |         if let Some(context) = &mut RENDER_CONTEXT {
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: mutable references to mutable statics are dangerous; it's undefined behavior if any other pointer to the static is used or if any other reference is created for the static while the mutable reference lives
[INFO] [stdout] help: use `&raw mut` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 222 |         if let Some(context) = &raw mut RENDER_CONTEXT {
[INFO] [stdout]     |                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]    --> alkahest/src/render/renderer_2d/mod.rs:239:32
[INFO] [stdout]     |
[INFO] [stdout] 239 |         if let Some(context) = &RENDER_CONTEXT {
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] help: use `&raw const` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 239 |         if let Some(context) = &raw const RENDER_CONTEXT {
[INFO] [stdout]     |                                 +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> alkahest/src/render/ui_renderer/mod.rs:81:36
[INFO] [stdout]    |
[INFO] [stdout] 81 |             if let Some(context) = &RENDER_CONTEXT {
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] help: use `&raw const` instead to create a raw pointer
[INFO] [stdout]    |
[INFO] [stdout] 81 |             if let Some(context) = &raw const RENDER_CONTEXT {
[INFO] [stdout]    |                                     +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a mutable reference to mutable static
[INFO] [stdout]    --> alkahest/src/render/ui_renderer/mod.rs:121:36
[INFO] [stdout]     |
[INFO] [stdout] 121 |             if let Some(context) = &mut RENDER_CONTEXT {
[INFO] [stdout]     |                                    ^^^^^^^^^^^^^^^^^^^ mutable reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: mutable references to mutable statics are dangerous; it's undefined behavior if any other pointer to the static is used or if any other reference is created for the static while the mutable reference lives
[INFO] [stdout] help: use `&raw mut` instead to create a raw pointer
[INFO] [stdout]     |
[INFO] [stdout] 121 |             if let Some(context) = &raw mut RENDER_CONTEXT {
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a trait
[INFO] [stdout]  --> alkahest/src/render/ui/mod.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub trait UIElement {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> alkahest/src/render/ui/mod.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     fn get_data_for_buffer(&self) -> Batch;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> alkahest/src/render/ui/mod.rs:10:28
[INFO] [stdout]    |
[INFO] [stdout] 10 |     fn get_data_for_buffer(&self) -> Batch;
[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] 10 |     fn get_data_for_buffer(&self) -> Batch<'_>;
[INFO] [stdout]    |                                           ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> alkahest/src/render/ui/mod.rs:32:1
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct BaseChild {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/ui/mod.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub position: Vec2,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/ui/mod.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub size: Vec2,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/ui/mod.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub rotation: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> alkahest/src/render/ui/mod.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 44 |     pub fn new(position: Vec2, size: Vec2, rotation: f32) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> alkahest/src/render/ui/mod.rs:65:28
[INFO] [stdout]    |
[INFO] [stdout] 65 |     fn get_data_for_buffer(&self) -> Batch {
[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] 65 |     fn get_data_for_buffer(&self) -> Batch<'_> {
[INFO] [stdout]    |                                           ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> alkahest/src/render/ui/root.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct UIRoot {}
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> alkahest/src/render/ui/panel.rs:31:1
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub struct UIPanel<'a> {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/ui/panel.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub position: Vec2,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/ui/panel.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub size: Vec2,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/ui/panel.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     pub rotation: f32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/ui/panel.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub color: Vec4,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/ui/panel.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub texture: Option<&'a Texture>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/render/ui/panel.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub children: Vec<Box<dyn UIElement>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> alkahest/src/render/ui/panel.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub fn new(position: Vec2, size: Vec2, rotation: f32, color: Vec4, texture: Option<&'a Texture>) -> Self {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]   --> alkahest/src/render/ui/panel.rs:90:5
[INFO] [stdout]    |
[INFO] [stdout] 90 |     pub fn add_child(&mut self, child: Box<dyn UIElement>) -> usize {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> alkahest/src/render/ui/panel.rs:107:5
[INFO] [stdout]     |
[INFO] [stdout] 107 |     pub fn remove_child(&mut self, index: usize) {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a method
[INFO] [stdout]    --> alkahest/src/render/ui/panel.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 158 |     pub fn get_batch(&self) -> Batch {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> alkahest/src/render/ui/panel.rs:158:22
[INFO] [stdout]     |
[INFO] [stdout] 158 |     pub fn get_batch(&self) -> Batch {
[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] 158 |     pub fn get_batch(&self) -> Batch<'_> {
[INFO] [stdout]     |                                     ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> alkahest/src/util/input/mod.rs:19:26
[INFO] [stdout]    |
[INFO] [stdout] 19 |         if (k as u32) < (KEY_STATE.len() as u32) {
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> alkahest/src/util/input/mod.rs:33:26
[INFO] [stdout]    |
[INFO] [stdout] 33 |         if (k as u32) < (KEY_STATE.len() as u32) {
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> alkahest/src/util/input/mod.rs:47:28
[INFO] [stdout]    |
[INFO] [stdout] 47 |         if (mb as usize) < MOUSE_BUTTON_STATE.len() {
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> alkahest/src/util/input/mod.rs:61:28
[INFO] [stdout]    |
[INFO] [stdout] 61 |         if (mb as usize) < MOUSE_BUTTON_STATE.len() {
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> alkahest/src/util/input/mod.rs:73:16
[INFO] [stdout]    |
[INFO] [stdout] 73 |         return &MOUSE_POSITION;
[INFO] [stdout]    |                ^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] help: use `&raw const` instead to create a raw pointer
[INFO] [stdout]    |
[INFO] [stdout] 73 |         return &raw const MOUSE_POSITION;
[INFO] [stdout]    |                 +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> alkahest/src/util/input/mod.rs:82:16
[INFO] [stdout]    |
[INFO] [stdout] 82 |         return &MOUSE_SCROLL;
[INFO] [stdout]    |                ^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] help: use `&raw const` instead to create a raw pointer
[INFO] [stdout]    |
[INFO] [stdout] 82 |         return &raw const MOUSE_SCROLL;
[INFO] [stdout]    |                 +++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> alkahest/src/util/input/mod.rs:88:27
[INFO] [stdout]    |
[INFO] [stdout] 88 |         if (k as usize) < KEY_STATE.len() {
[INFO] [stdout]    |                           ^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> alkahest/src/util/input/mod.rs:96:28
[INFO] [stdout]    |
[INFO] [stdout] 96 |         if (mb as usize) < MOUSE_BUTTON_STATE.len() {
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> alkahest/src/util/resources/tex.rs:12:1
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct TextureData {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/util/resources/tex.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub bytes: Vec<u8>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/util/resources/tex.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub width: u32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/util/resources/tex.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub height: u32,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> alkahest/src/util/resources/tex.rs:20:1
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct TextureManager {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> alkahest/src/util/resources/shader_manager.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct Shader {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]  --> alkahest/src/util/resources/shader_manager.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     pub id: u32,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> alkahest/src/util/resources/shader_manager.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub code: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> alkahest/src/util/resources/shader_manager.rs:15:1
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct ShaderManager {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]  Documenting sandbox v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 19.82s
[INFO] [stderr]    Generated /opt/rustwide/target/doc/sandbox/index.html
[INFO] running `Command { std: "docker" "inspect" "cdc1dfafe53be6c0069f1f7349dc9ad1c3fb556a050c3d43e7ee9aa52e41f254", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cdc1dfafe53be6c0069f1f7349dc9ad1c3fb556a050c3d43e7ee9aa52e41f254", kill_on_drop: false }`
[INFO] [stdout] cdc1dfafe53be6c0069f1f7349dc9ad1c3fb556a050c3d43e7ee9aa52e41f254
