[INFO] fetching crate adi 0.13.0-pre2...
[INFO] checking adi-0.13.0-pre2 against master#b0696a5160711c068cb1f01b7437db7990d15750 for pr-121848
[INFO] extracting crate adi 0.13.0-pre2 into /workspace/builds/worker-1-tc1/source
[INFO] validating manifest of crates.io crate adi 0.13.0-pre2 on toolchain b0696a5160711c068cb1f01b7437db7990d15750
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b0696a5160711c068cb1f01b7437db7990d15750" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate adi 0.13.0-pre2
[INFO] finished tweaking crates.io crate adi 0.13.0-pre2
[INFO] tweaked toml for crates.io crate adi 0.13.0-pre2 written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b0696a5160711c068cb1f01b7437db7990d15750" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b0696a5160711c068cb1f01b7437db7990d15750" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded lazy_static v0.2.11
[INFO] [stderr]   Downloaded fuchsia-cprng v0.1.1
[INFO] [stderr]   Downloaded rdrand v0.4.0
[INFO] [stderr]   Downloaded adler32 v1.2.0
[INFO] [stderr]   Downloaded approx v0.1.1
[INFO] [stderr]   Downloaded num-traits v0.1.43
[INFO] [stderr]   Downloaded bitflags v0.9.1
[INFO] [stderr]   Downloaded inflate v0.3.4
[INFO] [stderr]   Downloaded rand_core v0.4.2
[INFO] [stderr]   Downloaded rand_core v0.3.1
[INFO] [stderr]   Downloaded ami v0.13.1
[INFO] [stderr]   Downloaded png v0.10.0
[INFO] [stderr]   Downloaded cgmath v0.16.1
[INFO] [stderr]   Downloaded afi v0.8.0-pre0
[INFO] [stderr]   Downloaded rand v0.4.6
[INFO] [stderr]   Downloaded deflate v0.7.20
[INFO] [stderr]   Downloaded dl_api v0.2.0
[INFO] [stderr]   Downloaded footile v0.2.0
[INFO] [stderr]   Downloaded barg v0.0.3
[INFO] [stderr]   Downloaded fonterator v0.3.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+b0696a5160711c068cb1f01b7437db7990d15750" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2f0522ba1dc01ae739a473f1d8d28f890855063d1a7b0ecbd984c0398d102aa6
[INFO] running `Command { std: "docker" "start" "-a" "2f0522ba1dc01ae739a473f1d8d28f890855063d1a7b0ecbd984c0398d102aa6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2f0522ba1dc01ae739a473f1d8d28f890855063d1a7b0ecbd984c0398d102aa6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2f0522ba1dc01ae739a473f1d8d28f890855063d1a7b0ecbd984c0398d102aa6", kill_on_drop: false }`
[INFO] [stdout] 2f0522ba1dc01ae739a473f1d8d28f890855063d1a7b0ecbd984c0398d102aa6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+b0696a5160711c068cb1f01b7437db7990d15750" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6e98403d72645395a5c3e5d234d490a28800ebad82de71d1d0085d53287cb902
[INFO] running `Command { std: "docker" "start" "-a" "6e98403d72645395a5c3e5d234d490a28800ebad82de71d1d0085d53287cb902", kill_on_drop: false }`
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling libc v0.2.153
[INFO] [stderr]     Checking adler32 v1.2.0
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]     Checking tinyvec_macros v0.1.1
[INFO] [stderr]     Checking bitflags v0.9.1
[INFO] [stderr]    Compiling cgmath v0.16.1
[INFO] [stderr]     Checking approx v0.1.1
[INFO] [stderr]     Checking unicode-width v0.1.11
[INFO] [stderr]     Checking lazy_static v0.2.11
[INFO] [stderr]     Checking afi v0.8.0-pre0
[INFO] [stderr]     Checking tinyvec v1.6.0
[INFO] [stderr]     Checking inflate v0.3.4
[INFO] [stderr]     Checking deflate v0.7.20
[INFO] [stderr]     Checking unicode-normalization v0.1.23
[INFO] [stderr]     Checking rand v0.4.6
[INFO] [stderr]     Checking dl_api v0.2.0
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking num-traits v0.1.43
[INFO] [stderr]     Checking num-iter v0.1.44
[INFO] [stderr]     Checking png v0.10.0
[INFO] [stderr]     Checking footile v0.2.0
[INFO] [stderr]     Checking fonterator v0.3.0
[INFO] [stderr]     Checking barg v0.0.3
[INFO] [stderr]     Checking ami v0.13.1
[INFO] [stderr]     Checking adi v0.13.0-pre2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]  --> src/screen/gpu_data.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::screen::ffi::render::*;
[INFO] [stdout]   |     ----------------------------- the item `Matrix` is already imported here
[INFO] [stdout] 7 | use crate::screen::Matrix;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]  --> src/screen/gpu_data.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::screen::ffi::render::*;
[INFO] [stdout]   |     ----------------------------- the item `Matrix` is already imported here
[INFO] [stdout] 7 | use crate::screen::Matrix;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]   --> src/screen/viewer.rs:24:35
[INFO] [stdout]    |
[INFO] [stdout] 24 |         let viewer_new = unsafe { (super::CONTEXT.viewer_new) };
[INFO] [stdout]    |                                   ^                         ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 24 -         let viewer_new = unsafe { (super::CONTEXT.viewer_new) };
[INFO] [stdout] 24 +         let viewer_new = unsafe { super::CONTEXT.viewer_new };
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/screen/viewer.rs:159:35
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let viewer_old = unsafe { (super::CONTEXT.viewer_old) };
[INFO] [stdout]     |                                   ^                         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 159 -         let viewer_old = unsafe { (super::CONTEXT.viewer_old) };
[INFO] [stdout] 159 +         let viewer_old = unsafe { super::CONTEXT.viewer_old };
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `std` is imported redundantly
[INFO] [stdout]  --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     std,
[INFO] [stdout]   |     ^^^ the item `std` is already defined here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::ffi::Vector`
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub use crate::screen::ffi::Vector;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `ShapeHandle` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `ShapeHandle` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::ShapeHandle;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/mod.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 28 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Gradient` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use self::base::Gradient;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Gradient` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Model` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub use self::base::Model;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Model` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Shape` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use self::base::Shape;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Shape` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `TexCoords` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use self::base::TexCoords;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `TexCoords` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Texture` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub use self::base::Texture;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Texture` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] 23 |
[INFO] [stdout] 24 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]   --> src/screen/viewer.rs:24:35
[INFO] [stdout]    |
[INFO] [stdout] 24 |         let viewer_new = unsafe { (super::CONTEXT.viewer_new) };
[INFO] [stdout]    |                                   ^                         ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 24 -         let viewer_new = unsafe { (super::CONTEXT.viewer_new) };
[INFO] [stdout] 24 +         let viewer_new = unsafe { super::CONTEXT.viewer_new };
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/screen/viewer.rs:159:35
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let viewer_old = unsafe { (super::CONTEXT.viewer_old) };
[INFO] [stdout]     |                                   ^                         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 159 -         let viewer_old = unsafe { (super::CONTEXT.viewer_old) };
[INFO] [stdout] 159 +         let viewer_old = unsafe { super::CONTEXT.viewer_old };
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Gradient` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use self::base::Gradient;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Gradient` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Model` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub use self::base::Model;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Model` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Shape` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use self::base::Shape;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Shape` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `TexCoords` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use self::base::TexCoords;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `TexCoords` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Texture` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub use self::base::Texture;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Texture` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `std` is imported redundantly
[INFO] [stdout]  --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     std,
[INFO] [stdout]   |     ^^^ the item `std` is already defined here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/hid/ffi/linux.rs:310:6
[INFO] [stdout]     |
[INFO] [stdout] 310 |     };
[INFO] [stdout]     |      ^ help: remove this semicolon
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(redundant_semicolons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::ffi::Vector`
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub use crate::screen::ffi::Vector;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `ShapeHandle` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `ShapeHandle` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::ShapeHandle;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `libc` is imported redundantly
[INFO] [stdout]   --> src/shared/alsa/alsa.rs:3:5
[INFO] [stdout]    |
[INFO] [stdout] 3  | use libc;
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:37:1
[INFO] [stdout]    |
[INFO] [stdout] 37 | extern crate libc;
[INFO] [stdout]    | ------------------ the item `libc` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/mod.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 28 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Gradient` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use self::base::Gradient;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Gradient` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Model` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub use self::base::Model;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Model` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Shape` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use self::base::Shape;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Shape` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `TexCoords` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use self::base::TexCoords;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `TexCoords` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Texture` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub use self::base::Texture;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Texture` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] 23 |
[INFO] [stdout] 24 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Gradient` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use self::base::Gradient;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Gradient` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Model` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub use self::base::Model;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Model` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Shape` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use self::base::Shape;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Shape` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `TexCoords` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use self::base::TexCoords;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `TexCoords` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Texture` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub use self::base::Texture;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Texture` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/hid/ffi/linux.rs:310:6
[INFO] [stdout]     |
[INFO] [stdout] 310 |     };
[INFO] [stdout]     |      ^ help: remove this semicolon
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(redundant_semicolons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `libc` is imported redundantly
[INFO] [stdout]   --> src/shared/alsa/alsa.rs:3:5
[INFO] [stdout]    |
[INFO] [stdout] 3  | use libc;
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:37:1
[INFO] [stdout]    |
[INFO] [stdout] 37 | extern crate libc;
[INFO] [stdout]    | ------------------ the item `libc` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:44:8
[INFO] [stdout]    |
[INFO] [stdout] 44 | #![doc(html_logo_url = "http://plopgrizzly.com/adi_screen/icon.png",
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout]    = note: `#[warn(invalid_doc_attributes)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     html_favicon_url = "http://plopgrizzly.com/adi_screen/icon.ico",
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     html_root_url = "http://plopgrizzly.com/adi_screen/")]
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:79:27
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let mut layout = mem::uninitialized();
[INFO] [stdout]    |                           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:101:27
[INFO] [stdout]     |
[INFO] [stdout] 101 |     let mut mapped = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:125:26
[INFO] [stdout]     |
[INFO] [stdout] 125 |     let mut props = mem::uninitialized();
[INFO] [stdout]     |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:217:30
[INFO] [stdout]     |
[INFO] [stdout] 217 |     let mut semaphore = mem::uninitialized();
[INFO] [stdout]     |                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:395:29
[INFO] [stdout]     |
[INFO] [stdout] 395 |     let mut image_id = mem::uninitialized();
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:421:33
[INFO] [stdout]     |
[INFO] [stdout] 421 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:478:33
[INFO] [stdout]     |
[INFO] [stdout] 478 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:537:31
[INFO] [stdout]     |
[INFO] [stdout] 537 |     let mut image_view = mem::uninitialized();
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:790:32
[INFO] [stdout]     |
[INFO] [stdout] 790 |     let mut render_pass = mem::uninitialized();
[INFO] [stdout]     |                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:956:40
[INFO] [stdout]     |
[INFO] [stdout] 956 |         let mut shader = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:44:8
[INFO] [stdout]    |
[INFO] [stdout] 44 | #![doc(html_logo_url = "http://plopgrizzly.com/adi_screen/icon.png",
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout]    = note: `#[warn(invalid_doc_attributes)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     html_favicon_url = "http://plopgrizzly.com/adi_screen/icon.ico",
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     html_root_url = "http://plopgrizzly.com/adi_screen/")]
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:36:40
[INFO] [stdout]    |
[INFO] [stdout] 36 |         let mut buffer = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:37:40
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut memory = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:38:42
[INFO] [stdout]    |
[INFO] [stdout] 38 |         let mut mem_reqs = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:108:48
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mut mapped: *mut T = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/fence.rs:40:26
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let mut fence = mem::uninitialized();
[INFO] [stdout]    |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:99:29
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let mut instance = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/command_pool.rs:53:35
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let mut command_buffer = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:42:30
[INFO] [stdout]    |
[INFO] [stdout] 42 |     let mut gpus = vec![mem::uninitialized(); num_gpus as usize];
[INFO] [stdout]    |                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:92:39
[INFO] [stdout]    |
[INFO] [stdout] 92 |                 let mut format = mem::uninitialized();
[INFO] [stdout]    |                                       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:97:38
[INFO] [stdout]    |
[INFO] [stdout] 97 |                 let mut props = mem::uninitialized();
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:122:27
[INFO] [stdout]     |
[INFO] [stdout] 122 |     let mut device = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/queue.rs:29:26
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let mut queue = mem::uninitialized();
[INFO] [stdout]    |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/sampler.rs:27:28
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut sampler = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/surface.rs:37:41
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut surface = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:42:34
[INFO] [stdout]    |
[INFO] [stdout] 42 |             let mut image = mem::uninitialized();
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:43:35
[INFO] [stdout]    |
[INFO] [stdout] 43 |             let mut memory = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:44:40
[INFO] [stdout]    |
[INFO] [stdout] 44 |             let mut memory_reqs = mem::uninitialized();
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:48:34
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let mut desc_pool = mem::uninitialized();
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:49:33
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let mut desc_set = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:123:25
[INFO] [stdout]     |
[INFO] [stdout] 123 |             ::std::mem::uninitialized()
[INFO] [stdout]     |                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:209:33
[INFO] [stdout]     |
[INFO] [stdout] 209 |             sets: unsafe { mem::uninitialized() },
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:244:77
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut buffer_infos: [VkDescriptorBufferInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:245:75
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let mut image_infos: [VkDescriptorImageInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:246:69
[INFO] [stdout]     |
[INFO] [stdout] 246 |         let mut writes: [VkWriteDescriptorSet; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:68:33
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let mut pipeline = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:69:40
[INFO] [stdout]    |
[INFO] [stdout] 69 |         let mut pipeline_layout = mem::uninitialized();
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:70:38
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut descsetlayout = mem::uninitialized();
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:256:68
[INFO] [stdout]     |
[INFO] [stdout] 256 |         let mut frame_buffers: [VkFramebuffer; 2] = [unsafe { mem::uninitialized() }; 2];
[INFO] [stdout]     |                                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:564:29
[INFO] [stdout]     |
[INFO] [stdout] 564 |                 ::std::mem::uninitialized(),
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:575:22
[INFO] [stdout]     |
[INFO] [stdout] 575 |                 mem::uninitialized()
[INFO] [stdout]     |                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:578:45
[INFO] [stdout]     |
[INFO] [stdout] 578 |             transform: unsafe { ::std::mem::uninitialized() },
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:910:31
[INFO] [stdout]     |
[INFO] [stdout] 910 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:967:31
[INFO] [stdout]     |
[INFO] [stdout] 967 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:968:31
[INFO] [stdout]     |
[INFO] [stdout] 968 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1027:31
[INFO] [stdout]      |
[INFO] [stdout] 1027 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1092:31
[INFO] [stdout]      |
[INFO] [stdout] 1092 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1151:31
[INFO] [stdout]      |
[INFO] [stdout] 1151 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:118:42
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let mut nconfigs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:169:43
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut visual_id = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/buffer.rs:19:42
[INFO] [stdout]    |
[INFO] [stdout] 19 |         let mut buffers = [unsafe { mem::uninitialized() }];
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:111:46
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:119:50
[INFO] [stdout]     |
[INFO] [stdout] 119 |             let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:124:65
[INFO] [stdout]     |
[INFO] [stdout] 124 |             let mut buffer: Vec<u8> = vec![unsafe { ::std::mem::uninitialized() }; value as usize];
[INFO] [stdout]     |                                                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/texture.rs:20:50
[INFO] [stdout]    |
[INFO] [stdout] 20 |                 let mut a = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/hid/ffi/linux.rs:414:28
[INFO] [stdout]     |
[INFO] [stdout] 414 |     let mut a = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/hid/ffi/linux.rs:456:29
[INFO] [stdout]     |
[INFO] [stdout] 456 |     let mut js = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/mod.rs:96:26
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub fn draw(writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub fn draw(writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]    |                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/screen/mod.rs:29:29
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub(crate) display: Box<Display>,
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub(crate) display: Box<dyn Display>,
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:79:27
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let mut layout = mem::uninitialized();
[INFO] [stdout]    |                           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:101:27
[INFO] [stdout]     |
[INFO] [stdout] 101 |     let mut mapped = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:125:26
[INFO] [stdout]     |
[INFO] [stdout] 125 |     let mut props = mem::uninitialized();
[INFO] [stdout]     |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:217:30
[INFO] [stdout]     |
[INFO] [stdout] 217 |     let mut semaphore = mem::uninitialized();
[INFO] [stdout]     |                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:395:29
[INFO] [stdout]     |
[INFO] [stdout] 395 |     let mut image_id = mem::uninitialized();
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:421:33
[INFO] [stdout]     |
[INFO] [stdout] 421 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:478:33
[INFO] [stdout]     |
[INFO] [stdout] 478 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:537:31
[INFO] [stdout]     |
[INFO] [stdout] 537 |     let mut image_view = mem::uninitialized();
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:790:32
[INFO] [stdout]     |
[INFO] [stdout] 790 |     let mut render_pass = mem::uninitialized();
[INFO] [stdout]     |                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:956:40
[INFO] [stdout]     |
[INFO] [stdout] 956 |         let mut shader = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:36:40
[INFO] [stdout]    |
[INFO] [stdout] 36 |         let mut buffer = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:37:40
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut memory = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:38:42
[INFO] [stdout]    |
[INFO] [stdout] 38 |         let mut mem_reqs = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:108:48
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mut mapped: *mut T = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/fence.rs:40:26
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let mut fence = mem::uninitialized();
[INFO] [stdout]    |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:99:29
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let mut instance = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/screen/mod.rs:100:41
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/command_pool.rs:53:35
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let mut command_buffer = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/ffi/render/mod.rs:29:43
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub(crate) fn new_display() -> Result<Box<Display>, String> {
[INFO] [stdout]    |                                           ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub(crate) fn new_display() -> Result<Box<dyn Display>, String> {
[INFO] [stdout]    |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:42:30
[INFO] [stdout]    |
[INFO] [stdout] 42 |     let mut gpus = vec![mem::uninitialized(); num_gpus as usize];
[INFO] [stdout]    |                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:92:39
[INFO] [stdout]    |
[INFO] [stdout] 92 |                 let mut format = mem::uninitialized();
[INFO] [stdout]    |                                       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:97:38
[INFO] [stdout]    |
[INFO] [stdout] 97 |                 let mut props = mem::uninitialized();
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:122:27
[INFO] [stdout]     |
[INFO] [stdout] 122 |     let mut device = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/base.rs:130:37
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) -> ();
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) -> ();
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/queue.rs:29:26
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let mut queue = mem::uninitialized();
[INFO] [stdout]    |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/sampler.rs:27:28
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut sampler = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/surface.rs:37:41
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut surface = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:42:34
[INFO] [stdout]    |
[INFO] [stdout] 42 |             let mut image = mem::uninitialized();
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:43:35
[INFO] [stdout]    |
[INFO] [stdout] 43 |             let mut memory = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:44:40
[INFO] [stdout]    |
[INFO] [stdout] 44 |             let mut memory_reqs = mem::uninitialized();
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:48:34
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let mut desc_pool = mem::uninitialized();
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/mod.rs:217:37
[INFO] [stdout]     |
[INFO] [stdout] 217 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 217 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:49:33
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let mut desc_set = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:123:25
[INFO] [stdout]     |
[INFO] [stdout] 123 |             ::std::mem::uninitialized()
[INFO] [stdout]     |                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:209:33
[INFO] [stdout]     |
[INFO] [stdout] 209 |             sets: unsafe { mem::uninitialized() },
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:244:77
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut buffer_infos: [VkDescriptorBufferInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:245:75
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let mut image_infos: [VkDescriptorImageInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:246:69
[INFO] [stdout]     |
[INFO] [stdout] 246 |         let mut writes: [VkWriteDescriptorSet; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:68:33
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let mut pipeline = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:69:40
[INFO] [stdout]    |
[INFO] [stdout] 69 |         let mut pipeline_layout = mem::uninitialized();
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:70:38
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut descsetlayout = mem::uninitialized();
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:256:68
[INFO] [stdout]     |
[INFO] [stdout] 256 |         let mut frame_buffers: [VkFramebuffer; 2] = [unsafe { mem::uninitialized() }; 2];
[INFO] [stdout]     |                                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:564:29
[INFO] [stdout]     |
[INFO] [stdout] 564 |                 ::std::mem::uninitialized(),
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:575:22
[INFO] [stdout]     |
[INFO] [stdout] 575 |                 mem::uninitialized()
[INFO] [stdout]     |                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:578:45
[INFO] [stdout]     |
[INFO] [stdout] 578 |             transform: unsafe { ::std::mem::uninitialized() },
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:910:31
[INFO] [stdout]     |
[INFO] [stdout] 910 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:967:31
[INFO] [stdout]     |
[INFO] [stdout] 967 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:968:31
[INFO] [stdout]     |
[INFO] [stdout] 968 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1027:31
[INFO] [stdout]      |
[INFO] [stdout] 1027 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1092:31
[INFO] [stdout]      |
[INFO] [stdout] 1092 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1151:31
[INFO] [stdout]      |
[INFO] [stdout] 1151 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:118:42
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let mut nconfigs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:169:43
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut visual_id = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/buffer.rs:19:42
[INFO] [stdout]    |
[INFO] [stdout] 19 |         let mut buffers = [unsafe { mem::uninitialized() }];
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:111:46
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:119:50
[INFO] [stdout]     |
[INFO] [stdout] 119 |             let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:124:65
[INFO] [stdout]     |
[INFO] [stdout] 124 |             let mut buffer: Vec<u8> = vec![unsafe { ::std::mem::uninitialized() }; value as usize];
[INFO] [stdout]     |                                                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/texture.rs:20:50
[INFO] [stdout]    |
[INFO] [stdout] 20 |                 let mut a = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/hid/ffi/linux.rs:414:28
[INFO] [stdout]     |
[INFO] [stdout] 414 |     let mut a = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/hid/ffi/linux.rs:456:29
[INFO] [stdout]     |
[INFO] [stdout] 456 |     let mut js = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/mod.rs:96:26
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub fn draw(writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub fn draw(writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]    |                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/screen/mod.rs:29:29
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub(crate) display: Box<Display>,
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub(crate) display: Box<dyn Display>,
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/screen/mod.rs:100:41
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/ffi/render/mod.rs:29:43
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub(crate) fn new_display() -> Result<Box<Display>, String> {
[INFO] [stdout]    |                                           ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub(crate) fn new_display() -> Result<Box<dyn Display>, String> {
[INFO] [stdout]    |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/base.rs:130:37
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) -> ();
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) -> ();
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/mod.rs:217:37
[INFO] [stdout]     |
[INFO] [stdout] 217 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 217 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:213:57
[INFO] [stdout]     |
[INFO] [stdout] 213 | fn set_texture(vw: &Vw, texture: &mut Texture, writer: &Fn(usize) -> [u8; 4]) {
[INFO] [stdout]     |                                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 213 | fn set_texture(vw: &Vw, texture: &mut Texture, writer: &dyn Fn(usize) -> [u8; 4]) {
[INFO] [stdout]     |                                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:332:61
[INFO] [stdout]     |
[INFO] [stdout] 332 |     pub(crate) fn draw(&self, _wh: (u16, u16), writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 332 |     pub(crate) fn draw(&self, _wh: (u16, u16), writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/ffi.rs:31:14
[INFO] [stdout]    |
[INFO] [stdout] 31 |     writer: &Fn(usize) -> [u8; 4],
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 31 |     writer: &dyn Fn(usize) -> [u8; 4],
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/opengl/mod.rs:673:37
[INFO] [stdout]     |
[INFO] [stdout] 673 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 673 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/speaker/mod.rs:70:46
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub fn update(&mut self, generator: &mut FnMut() -> i16) {
[INFO] [stdout]    |                                              ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub fn update(&mut self, generator: &mut dyn FnMut() -> i16) {
[INFO] [stdout]    |                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:213:57
[INFO] [stdout]     |
[INFO] [stdout] 213 | fn set_texture(vw: &Vw, texture: &mut Texture, writer: &Fn(usize) -> [u8; 4]) {
[INFO] [stdout]     |                                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 213 | fn set_texture(vw: &Vw, texture: &mut Texture, writer: &dyn Fn(usize) -> [u8; 4]) {
[INFO] [stdout]     |                                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:332:61
[INFO] [stdout]     |
[INFO] [stdout] 332 |     pub(crate) fn draw(&self, _wh: (u16, u16), writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 332 |     pub(crate) fn draw(&self, _wh: (u16, u16), writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/ffi.rs:31:14
[INFO] [stdout]    |
[INFO] [stdout] 31 |     writer: &Fn(usize) -> [u8; 4],
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 31 |     writer: &dyn Fn(usize) -> [u8; 4],
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/opengl/mod.rs:673:37
[INFO] [stdout]     |
[INFO] [stdout] 673 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 673 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/speaker/mod.rs:70:46
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub fn update(&mut self, generator: &mut FnMut() -> i16) {
[INFO] [stdout]    |                                              ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub fn update(&mut self, generator: &mut dyn FnMut() -> i16) {
[INFO] [stdout]    |                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FogUniform` is never constructed
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct FogUniform {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FogUniform` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]   --> src/screen/opengl/mod.rs:38:14
[INFO] [stdout]    |
[INFO] [stdout] 38 |     unsafe { OpenGLViewer::from_raw(viewer as *mut _) };
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 38 |     unsafe { let _ = OpenGLViewer::from_raw(viewer as *mut _); };
[INFO] [stdout]    |              +++++++                                         +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSubresourceLayout` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:79:22
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let mut layout = mem::uninitialized();
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                      |
[INFO] [stdout]    |                      this code causes undefined behavior when executed
[INFO] [stdout]    |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub offset: VkDeviceSize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut T` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:101:22
[INFO] [stdout]     |
[INFO] [stdout] 101 |     let mut mapped = mem::uninitialized();
[INFO] [stdout]     |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      this code causes undefined behavior when executed
[INFO] [stdout]     |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkPhysicalDeviceMemoryProperties` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:125:21
[INFO] [stdout]     |
[INFO] [stdout] 125 |     let mut props = mem::uninitialized();
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     this code causes undefined behavior when executed
[INFO] [stdout]     |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:563:5
[INFO] [stdout]     |
[INFO] [stdout] 563 |     pub memory_type_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:217:25
[INFO] [stdout]     |
[INFO] [stdout] 217 |     let mut semaphore = mem::uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         this code causes undefined behavior when executed
[INFO] [stdout]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:395:24
[INFO] [stdout]     |
[INFO] [stdout] 395 |     let mut image_id = mem::uninitialized();
[INFO] [stdout]     |                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                        |
[INFO] [stdout]     |                        this code causes undefined behavior when executed
[INFO] [stdout]     |                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceCapabilitiesKHR` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:421:28
[INFO] [stdout]     |
[INFO] [stdout] 421 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:704:5
[INFO] [stdout]     |
[INFO] [stdout] 704 |     pub min_image_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceCapabilitiesKHR` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:478:28
[INFO] [stdout]     |
[INFO] [stdout] 478 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:704:5
[INFO] [stdout]     |
[INFO] [stdout] 704 |     pub min_image_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:537:26
[INFO] [stdout]     |
[INFO] [stdout] 537 |     let mut image_view = mem::uninitialized();
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkRenderPass` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:790:27
[INFO] [stdout]     |
[INFO] [stdout] 790 |     let mut render_pass = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           this code causes undefined behavior when executed
[INFO] [stdout]     |                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:32:25
[INFO] [stdout]     |
[INFO] [stdout] 32  | pub struct VkRenderPass(pub(crate) u64);
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkShaderModule` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:956:35
[INFO] [stdout]     |
[INFO] [stdout] 956 |         let mut shader = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   this code causes undefined behavior when executed
[INFO] [stdout]     |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:38:34
[INFO] [stdout]     |
[INFO] [stdout] 38  | pub(crate) struct VkShaderModule(pub(crate) u64);
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:36:35
[INFO] [stdout]    |
[INFO] [stdout] 36 |         let mut buffer = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:37:35
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut memory = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkMemoryRequirements` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:38:37
[INFO] [stdout]     |
[INFO] [stdout] 38  |         let mut mem_reqs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:516:5
[INFO] [stdout]     |
[INFO] [stdout] 516 |     pub size: VkDeviceSize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut T` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:108:43
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mut mapped: *mut T = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                           |
[INFO] [stdout]     |                                           this code causes undefined behavior when executed
[INFO] [stdout]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/fence.rs:40:21
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let mut fence = mem::uninitialized();
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     this code causes undefined behavior when executed
[INFO] [stdout]    |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkInstance` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:99:24
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let mut instance = mem::uninitialized();
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                        |
[INFO] [stdout]    |                        this code causes undefined behavior when executed
[INFO] [stdout]    |                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:53:30
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub(crate) struct VkInstance(*mut c_void);
[INFO] [stdout]    |                              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut c_void` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/command_pool.rs:53:30
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let mut command_buffer = mem::uninitialized();
[INFO] [stdout]    |                              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              this code causes undefined behavior when executed
[INFO] [stdout]    |                              help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkPhysicalDevice` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:42:25
[INFO] [stdout]    |
[INFO] [stdout] 42 |     let mut gpus = vec![mem::uninitialized(); num_gpus as usize];
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                         |
[INFO] [stdout]    |                         this code causes undefined behavior when executed
[INFO] [stdout]    |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:50:36
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub(crate) struct VkPhysicalDevice(*mut c_void);
[INFO] [stdout]    |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceFormatKHR` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:92:34
[INFO] [stdout]      |
[INFO] [stdout] 92   |                 let mut format = mem::uninitialized();
[INFO] [stdout]      |                                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                                  |
[INFO] [stdout]      |                                  this code causes undefined behavior when executed
[INFO] [stdout]      |                                  help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: `screen::ffi::render::vulkan::asi::types::VkSurfaceFormatKHR` must be initialized inside its custom valid range
[INFO] [stdout] note: in this struct field
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:718:5
[INFO] [stdout]      |
[INFO] [stdout] 718  |     pub format: VkFormat,
[INFO] [stdout]      |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:1247:1
[INFO] [stdout]      |
[INFO] [stdout] 1247 | pub enum VkFormat {
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkFormatProperties` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:97:33
[INFO] [stdout]     |
[INFO] [stdout] 97  |                 let mut props = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub linear_tiling_features: VkFlags,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkDevice` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:122:22
[INFO] [stdout]     |
[INFO] [stdout] 122 |     let mut device = mem::uninitialized();
[INFO] [stdout]     |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      this code causes undefined behavior when executed
[INFO] [stdout]     |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:47:28
[INFO] [stdout]     |
[INFO] [stdout] 47  | pub(crate) struct VkDevice(*mut c_void);
[INFO] [stdout]     |                            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkQueue` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/queue.rs:29:21
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let mut queue = mem::uninitialized();
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     this code causes undefined behavior when executed
[INFO] [stdout]    |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:56:20
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub struct VkQueue(*mut c_void);
[INFO] [stdout]    |                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/sampler.rs:27:23
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut sampler = mem::uninitialized();
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                       |
[INFO] [stdout]    |                       this code causes undefined behavior when executed
[INFO] [stdout]    |                       help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/surface.rs:37:36
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut surface = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                    |
[INFO] [stdout]    |                                    this code causes undefined behavior when executed
[INFO] [stdout]    |                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:42:29
[INFO] [stdout]    |
[INFO] [stdout] 42 |             let mut image = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                             |
[INFO] [stdout]    |                             this code causes undefined behavior when executed
[INFO] [stdout]    |                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:43:30
[INFO] [stdout]    |
[INFO] [stdout] 43 |             let mut memory = mem::uninitialized();
[INFO] [stdout]    |                              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              this code causes undefined behavior when executed
[INFO] [stdout]    |                              help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkMemoryRequirements` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/image.rs:44:35
[INFO] [stdout]     |
[INFO] [stdout] 44  |             let mut memory_reqs = mem::uninitialized();
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   this code causes undefined behavior when executed
[INFO] [stdout]     |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:516:5
[INFO] [stdout]     |
[INFO] [stdout] 516 |     pub size: VkDeviceSize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:48:29
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let mut desc_pool = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                             |
[INFO] [stdout]    |                             this code causes undefined behavior when executed
[INFO] [stdout]    |                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:49:28
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let mut desc_set = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            this code causes undefined behavior when executed
[INFO] [stdout]    |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::buffer::Buffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:123:13
[INFO] [stdout]     |
[INFO] [stdout] 123 |             ::std::mem::uninitialized()
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             this code causes undefined behavior when executed
[INFO] [stdout]     |             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: `screen::ffi::render::vulkan::asi::buffer::Buffer` must be non-null
[INFO] [stdout] note: because `std::rc::Rc<screen::ffi::render::vulkan::asi::buffer::BufferContext>` must be non-null (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:23:19
[INFO] [stdout]     |
[INFO] [stdout] 23  | pub struct Buffer(Rc<BufferContext>);
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: because `std::ptr::NonNull<std::rc::RcBox<screen::ffi::render::vulkan::asi::buffer::BufferContext>>` must be non-null
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[Set; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:209:28
[INFO] [stdout]     |
[INFO] [stdout] 209 |             sets: unsafe { mem::uninitialized() },
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:297:1
[INFO] [stdout]     |
[INFO] [stdout] 297 | enum Set {
[INFO] [stdout]     | ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkDescriptorBufferInfo; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:244:72
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut buffer_infos: [VkDescriptorBufferInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                                        |
[INFO] [stdout]     |                                                                        this code causes undefined behavior when executed
[INFO] [stdout]     |                                                                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:429:5
[INFO] [stdout]     |
[INFO] [stdout] 429 |     pub buffer: VkBuffer,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkDescriptorImageInfo; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:245:70
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let mut image_infos: [VkDescriptorImageInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                                      |
[INFO] [stdout]     |                                                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:450:5
[INFO] [stdout]     |
[INFO] [stdout] 450 |     pub sampler: VkSampler,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkWriteDescriptorSet; 255]` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/sprite.rs:246:64
[INFO] [stdout]      |
[INFO] [stdout] 246  |         let mut writes: [VkWriteDescriptorSet; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]      |                                                                ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                                                                |
[INFO] [stdout]      |                                                                this code causes undefined behavior when executed
[INFO] [stdout]      |                                                                help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:436:5
[INFO] [stdout]      |
[INFO] [stdout] 436  |     pub s_type: VkStructureType,
[INFO] [stdout]      |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:1438:1
[INFO] [stdout]      |
[INFO] [stdout] 1438 | pub(crate) enum VkStructureType {
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:68:28
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let mut pipeline = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            this code causes undefined behavior when executed
[INFO] [stdout]    |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:69:35
[INFO] [stdout]    |
[INFO] [stdout] 69 |         let mut pipeline_layout = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:70:33
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut descsetlayout = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                 |
[INFO] [stdout]    |                                 this code causes undefined behavior when executed
[INFO] [stdout]    |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkFramebuffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:256:63
[INFO] [stdout]     |
[INFO] [stdout] 256 |         let mut frame_buffers: [VkFramebuffer; 2] = [unsafe { mem::uninitialized() }; 2];
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                               |
[INFO] [stdout]     |                                                               this code causes undefined behavior when executed
[INFO] [stdout]     |                                                               help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:35:26
[INFO] [stdout]     |
[INFO] [stdout] 35  | pub struct VkFramebuffer(pub(crate) u64);
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `&render::vulkan::asi::buffer::Buffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:564:17
[INFO] [stdout]     |
[INFO] [stdout] 564 |                 ::std::mem::uninitialized(),
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 this code causes undefined behavior when executed
[INFO] [stdout]     |                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: references must be non-null
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:575:17
[INFO] [stdout]     |
[INFO] [stdout] 575 |                 mem::uninitialized()
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 this code causes undefined behavior when executed
[INFO] [stdout]     |                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `ami::Matrix` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:578:33
[INFO] [stdout]     |
[INFO] [stdout] 578 |             transform: unsafe { ::std::mem::uninitialized() },
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: floats must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:910:26
[INFO] [stdout]     |
[INFO] [stdout] 910 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:967:26
[INFO] [stdout]     |
[INFO] [stdout] 967 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:968:26
[INFO] [stdout]     |
[INFO] [stdout] 968 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1027:26
[INFO] [stdout]      |
[INFO] [stdout] 1027 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1092:26
[INFO] [stdout]      |
[INFO] [stdout] 1092 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1151:26
[INFO] [stdout]      |
[INFO] [stdout] 1151 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:118:37
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let mut nconfigs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:169:38
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut visual_id = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                      |
[INFO] [stdout]     |                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/buffer.rs:19:37
[INFO] [stdout]    |
[INFO] [stdout] 19 |         let mut buffers = [unsafe { mem::uninitialized() }];
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                     |
[INFO] [stdout]    |                                     this code causes undefined behavior when executed
[INFO] [stdout]    |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:111:34
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  this code causes undefined behavior when executed
[INFO] [stdout]     |                                  help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:119:38
[INFO] [stdout]     |
[INFO] [stdout] 119 |             let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                      |
[INFO] [stdout]     |                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u8` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:124:53
[INFO] [stdout]     |
[INFO] [stdout] 124 |             let mut buffer: Vec<u8> = vec![unsafe { ::std::mem::uninitialized() }; value as usize];
[INFO] [stdout]     |                                                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                     |
[INFO] [stdout]     |                                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/texture.rs:20:38
[INFO] [stdout]    |
[INFO] [stdout] 20 |                 let mut a = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                      |
[INFO] [stdout]    |                                      this code causes undefined behavior when executed
[INFO] [stdout]    |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FogUniform` is never constructed
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct FogUniform {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FogUniform` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `AbsInfo` does not permit being left uninitialized
[INFO] [stdout]    --> src/hid/ffi/linux.rs:414:23
[INFO] [stdout]     |
[INFO] [stdout] 414 |     let mut a = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/hid/ffi/linux.rs:406:3
[INFO] [stdout]     |
[INFO] [stdout] 406 |         value: i32,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Event` does not permit being left uninitialized
[INFO] [stdout]    --> src/hid/ffi/linux.rs:456:24
[INFO] [stdout]     |
[INFO] [stdout] 456 |     let mut js = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           this code causes undefined behavior when executed
[INFO] [stdout]     |                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]    --> src/hid/ffi/linux.rs:15:2
[INFO] [stdout]     |
[INFO] [stdout] 15  |     ev_time: TimeVal,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/hid/ffi/linux.rs:9:2
[INFO] [stdout]     |
[INFO] [stdout] 9   |     tv_sec: isize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `free` redeclared with a different signature
[INFO] [stdout]    --> src/screen/ffi/linux.rs:359:9
[INFO] [stdout]     |
[INFO] [stdout] 304 |             fn free(this: *mut XcbInternAtomReply) -> ();
[INFO] [stdout]     |             -------------------------------------------- `free` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 359 |         fn free(event: *mut XcbGenericEvent) -> ();
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(*mut XcbInternAtomReply)`
[INFO] [stdout]                found `unsafe extern "C" fn(*mut XcbGenericEvent)`
[INFO] [stdout]     = note: `#[warn(clashing_extern_declarations)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `ioctl` redeclared with a different signature
[INFO] [stdout]    --> src/hid/ffi/linux.rs:393:3
[INFO] [stdout]     |
[INFO] [stdout] 364 |         fn ioctl(fd: i32, request: usize, v: *mut FfEffect) -> i32;
[INFO] [stdout]     |         ---------------------------------------------------------- `ioctl` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 393 |         fn ioctl(fd: i32, request: usize, v: *mut i16) -> i32;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(i32, usize, *mut FfEffect) -> i32`
[INFO] [stdout]                found `unsafe extern "C" fn(i32, usize, *mut i16) -> i32`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `ioctl` redeclared with a different signature
[INFO] [stdout]    --> src/hid/ffi/linux.rs:417:3
[INFO] [stdout]     |
[INFO] [stdout] 364 |         fn ioctl(fd: i32, request: usize, v: *mut FfEffect) -> i32;
[INFO] [stdout]     |         ---------------------------------------------------------- `ioctl` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 417 |         fn ioctl(fd: i32, request: usize, v: *mut AbsInfo) -> i32;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(i32, usize, *mut FfEffect) -> i32`
[INFO] [stdout]                found `unsafe extern "C" fn(i32, usize, *mut AbsInfo) -> i32`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]   --> src/screen/opengl/mod.rs:38:14
[INFO] [stdout]    |
[INFO] [stdout] 38 |     unsafe { OpenGLViewer::from_raw(viewer as *mut _) };
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 38 |     unsafe { let _ = OpenGLViewer::from_raw(viewer as *mut _); };
[INFO] [stdout]    |              +++++++                                         +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSubresourceLayout` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:79:22
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let mut layout = mem::uninitialized();
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                      |
[INFO] [stdout]    |                      this code causes undefined behavior when executed
[INFO] [stdout]    |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub offset: VkDeviceSize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut T` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:101:22
[INFO] [stdout]     |
[INFO] [stdout] 101 |     let mut mapped = mem::uninitialized();
[INFO] [stdout]     |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      this code causes undefined behavior when executed
[INFO] [stdout]     |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkPhysicalDeviceMemoryProperties` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:125:21
[INFO] [stdout]     |
[INFO] [stdout] 125 |     let mut props = mem::uninitialized();
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     this code causes undefined behavior when executed
[INFO] [stdout]     |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:563:5
[INFO] [stdout]     |
[INFO] [stdout] 563 |     pub memory_type_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:217:25
[INFO] [stdout]     |
[INFO] [stdout] 217 |     let mut semaphore = mem::uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         this code causes undefined behavior when executed
[INFO] [stdout]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:395:24
[INFO] [stdout]     |
[INFO] [stdout] 395 |     let mut image_id = mem::uninitialized();
[INFO] [stdout]     |                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                        |
[INFO] [stdout]     |                        this code causes undefined behavior when executed
[INFO] [stdout]     |                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceCapabilitiesKHR` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:421:28
[INFO] [stdout]     |
[INFO] [stdout] 421 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:704:5
[INFO] [stdout]     |
[INFO] [stdout] 704 |     pub min_image_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceCapabilitiesKHR` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:478:28
[INFO] [stdout]     |
[INFO] [stdout] 478 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:704:5
[INFO] [stdout]     |
[INFO] [stdout] 704 |     pub min_image_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:537:26
[INFO] [stdout]     |
[INFO] [stdout] 537 |     let mut image_view = mem::uninitialized();
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkRenderPass` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:790:27
[INFO] [stdout]     |
[INFO] [stdout] 790 |     let mut render_pass = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           this code causes undefined behavior when executed
[INFO] [stdout]     |                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:32:25
[INFO] [stdout]     |
[INFO] [stdout] 32  | pub struct VkRenderPass(pub(crate) u64);
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkShaderModule` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:956:35
[INFO] [stdout]     |
[INFO] [stdout] 956 |         let mut shader = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   this code causes undefined behavior when executed
[INFO] [stdout]     |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:38:34
[INFO] [stdout]     |
[INFO] [stdout] 38  | pub(crate) struct VkShaderModule(pub(crate) u64);
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:36:35
[INFO] [stdout]    |
[INFO] [stdout] 36 |         let mut buffer = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:37:35
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut memory = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkMemoryRequirements` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:38:37
[INFO] [stdout]     |
[INFO] [stdout] 38  |         let mut mem_reqs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:516:5
[INFO] [stdout]     |
[INFO] [stdout] 516 |     pub size: VkDeviceSize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut T` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:108:43
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mut mapped: *mut T = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                           |
[INFO] [stdout]     |                                           this code causes undefined behavior when executed
[INFO] [stdout]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/fence.rs:40:21
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let mut fence = mem::uninitialized();
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     this code causes undefined behavior when executed
[INFO] [stdout]    |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkInstance` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:99:24
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let mut instance = mem::uninitialized();
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                        |
[INFO] [stdout]    |                        this code causes undefined behavior when executed
[INFO] [stdout]    |                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:53:30
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub(crate) struct VkInstance(*mut c_void);
[INFO] [stdout]    |                              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut c_void` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/command_pool.rs:53:30
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let mut command_buffer = mem::uninitialized();
[INFO] [stdout]    |                              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              this code causes undefined behavior when executed
[INFO] [stdout]    |                              help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkPhysicalDevice` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:42:25
[INFO] [stdout]    |
[INFO] [stdout] 42 |     let mut gpus = vec![mem::uninitialized(); num_gpus as usize];
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                         |
[INFO] [stdout]    |                         this code causes undefined behavior when executed
[INFO] [stdout]    |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:50:36
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub(crate) struct VkPhysicalDevice(*mut c_void);
[INFO] [stdout]    |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceFormatKHR` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:92:34
[INFO] [stdout]      |
[INFO] [stdout] 92   |                 let mut format = mem::uninitialized();
[INFO] [stdout]      |                                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                                  |
[INFO] [stdout]      |                                  this code causes undefined behavior when executed
[INFO] [stdout]      |                                  help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: `screen::ffi::render::vulkan::asi::types::VkSurfaceFormatKHR` must be initialized inside its custom valid range
[INFO] [stdout] note: in this struct field
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:718:5
[INFO] [stdout]      |
[INFO] [stdout] 718  |     pub format: VkFormat,
[INFO] [stdout]      |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:1247:1
[INFO] [stdout]      |
[INFO] [stdout] 1247 | pub enum VkFormat {
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkFormatProperties` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:97:33
[INFO] [stdout]     |
[INFO] [stdout] 97  |                 let mut props = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub linear_tiling_features: VkFlags,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkDevice` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:122:22
[INFO] [stdout]     |
[INFO] [stdout] 122 |     let mut device = mem::uninitialized();
[INFO] [stdout]     |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      this code causes undefined behavior when executed
[INFO] [stdout]     |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:47:28
[INFO] [stdout]     |
[INFO] [stdout] 47  | pub(crate) struct VkDevice(*mut c_void);
[INFO] [stdout]     |                            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkQueue` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/queue.rs:29:21
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let mut queue = mem::uninitialized();
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     this code causes undefined behavior when executed
[INFO] [stdout]    |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:56:20
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub struct VkQueue(*mut c_void);
[INFO] [stdout]    |                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/sampler.rs:27:23
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut sampler = mem::uninitialized();
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                       |
[INFO] [stdout]    |                       this code causes undefined behavior when executed
[INFO] [stdout]    |                       help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/surface.rs:37:36
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut surface = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                    |
[INFO] [stdout]    |                                    this code causes undefined behavior when executed
[INFO] [stdout]    |                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:42:29
[INFO] [stdout]    |
[INFO] [stdout] 42 |             let mut image = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                             |
[INFO] [stdout]    |                             this code causes undefined behavior when executed
[INFO] [stdout]    |                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:43:30
[INFO] [stdout]    |
[INFO] [stdout] 43 |             let mut memory = mem::uninitialized();
[INFO] [stdout]    |                              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              this code causes undefined behavior when executed
[INFO] [stdout]    |                              help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkMemoryRequirements` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/image.rs:44:35
[INFO] [stdout]     |
[INFO] [stdout] 44  |             let mut memory_reqs = mem::uninitialized();
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   this code causes undefined behavior when executed
[INFO] [stdout]     |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:516:5
[INFO] [stdout]     |
[INFO] [stdout] 516 |     pub size: VkDeviceSize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:48:29
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let mut desc_pool = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                             |
[INFO] [stdout]    |                             this code causes undefined behavior when executed
[INFO] [stdout]    |                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:49:28
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let mut desc_set = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            this code causes undefined behavior when executed
[INFO] [stdout]    |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::buffer::Buffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:123:13
[INFO] [stdout]     |
[INFO] [stdout] 123 |             ::std::mem::uninitialized()
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             this code causes undefined behavior when executed
[INFO] [stdout]     |             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: `screen::ffi::render::vulkan::asi::buffer::Buffer` must be non-null
[INFO] [stdout] note: because `std::rc::Rc<screen::ffi::render::vulkan::asi::buffer::BufferContext>` must be non-null (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:23:19
[INFO] [stdout]     |
[INFO] [stdout] 23  | pub struct Buffer(Rc<BufferContext>);
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: because `std::ptr::NonNull<std::rc::RcBox<screen::ffi::render::vulkan::asi::buffer::BufferContext>>` must be non-null
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[Set; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:209:28
[INFO] [stdout]     |
[INFO] [stdout] 209 |             sets: unsafe { mem::uninitialized() },
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:297:1
[INFO] [stdout]     |
[INFO] [stdout] 297 | enum Set {
[INFO] [stdout]     | ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkDescriptorBufferInfo; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:244:72
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut buffer_infos: [VkDescriptorBufferInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                                        |
[INFO] [stdout]     |                                                                        this code causes undefined behavior when executed
[INFO] [stdout]     |                                                                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:429:5
[INFO] [stdout]     |
[INFO] [stdout] 429 |     pub buffer: VkBuffer,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkDescriptorImageInfo; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:245:70
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let mut image_infos: [VkDescriptorImageInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                                      |
[INFO] [stdout]     |                                                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:450:5
[INFO] [stdout]     |
[INFO] [stdout] 450 |     pub sampler: VkSampler,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkWriteDescriptorSet; 255]` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/sprite.rs:246:64
[INFO] [stdout]      |
[INFO] [stdout] 246  |         let mut writes: [VkWriteDescriptorSet; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]      |                                                                ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                                                                |
[INFO] [stdout]      |                                                                this code causes undefined behavior when executed
[INFO] [stdout]      |                                                                help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:436:5
[INFO] [stdout]      |
[INFO] [stdout] 436  |     pub s_type: VkStructureType,
[INFO] [stdout]      |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:1438:1
[INFO] [stdout]      |
[INFO] [stdout] 1438 | pub(crate) enum VkStructureType {
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:68:28
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let mut pipeline = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            this code causes undefined behavior when executed
[INFO] [stdout]    |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:69:35
[INFO] [stdout]    |
[INFO] [stdout] 69 |         let mut pipeline_layout = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:70:33
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut descsetlayout = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                 |
[INFO] [stdout]    |                                 this code causes undefined behavior when executed
[INFO] [stdout]    |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkFramebuffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:256:63
[INFO] [stdout]     |
[INFO] [stdout] 256 |         let mut frame_buffers: [VkFramebuffer; 2] = [unsafe { mem::uninitialized() }; 2];
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                               |
[INFO] [stdout]     |                                                               this code causes undefined behavior when executed
[INFO] [stdout]     |                                                               help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:35:26
[INFO] [stdout]     |
[INFO] [stdout] 35  | pub struct VkFramebuffer(pub(crate) u64);
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `&render::vulkan::asi::buffer::Buffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:564:17
[INFO] [stdout]     |
[INFO] [stdout] 564 |                 ::std::mem::uninitialized(),
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 this code causes undefined behavior when executed
[INFO] [stdout]     |                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: references must be non-null
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:575:17
[INFO] [stdout]     |
[INFO] [stdout] 575 |                 mem::uninitialized()
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 this code causes undefined behavior when executed
[INFO] [stdout]     |                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `ami::Matrix` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:578:33
[INFO] [stdout]     |
[INFO] [stdout] 578 |             transform: unsafe { ::std::mem::uninitialized() },
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: floats must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:910:26
[INFO] [stdout]     |
[INFO] [stdout] 910 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:967:26
[INFO] [stdout]     |
[INFO] [stdout] 967 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:968:26
[INFO] [stdout]     |
[INFO] [stdout] 968 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1027:26
[INFO] [stdout]      |
[INFO] [stdout] 1027 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1092:26
[INFO] [stdout]      |
[INFO] [stdout] 1092 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1151:26
[INFO] [stdout]      |
[INFO] [stdout] 1151 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:118:37
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let mut nconfigs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:169:38
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut visual_id = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                      |
[INFO] [stdout]     |                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/buffer.rs:19:37
[INFO] [stdout]    |
[INFO] [stdout] 19 |         let mut buffers = [unsafe { mem::uninitialized() }];
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                     |
[INFO] [stdout]    |                                     this code causes undefined behavior when executed
[INFO] [stdout]    |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:111:34
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  this code causes undefined behavior when executed
[INFO] [stdout]     |                                  help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:119:38
[INFO] [stdout]     |
[INFO] [stdout] 119 |             let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                      |
[INFO] [stdout]     |                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u8` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:124:53
[INFO] [stdout]     |
[INFO] [stdout] 124 |             let mut buffer: Vec<u8> = vec![unsafe { ::std::mem::uninitialized() }; value as usize];
[INFO] [stdout]     |                                                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                     |
[INFO] [stdout]     |                                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/texture.rs:20:38
[INFO] [stdout]    |
[INFO] [stdout] 20 |                 let mut a = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                      |
[INFO] [stdout]    |                                      this code causes undefined behavior when executed
[INFO] [stdout]    |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `AbsInfo` does not permit being left uninitialized
[INFO] [stdout]    --> src/hid/ffi/linux.rs:414:23
[INFO] [stdout]     |
[INFO] [stdout] 414 |     let mut a = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/hid/ffi/linux.rs:406:3
[INFO] [stdout]     |
[INFO] [stdout] 406 |         value: i32,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Event` does not permit being left uninitialized
[INFO] [stdout]    --> src/hid/ffi/linux.rs:456:24
[INFO] [stdout]     |
[INFO] [stdout] 456 |     let mut js = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           this code causes undefined behavior when executed
[INFO] [stdout]     |                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]    --> src/hid/ffi/linux.rs:15:2
[INFO] [stdout]     |
[INFO] [stdout] 15  |     ev_time: TimeVal,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/hid/ffi/linux.rs:9:2
[INFO] [stdout]     |
[INFO] [stdout] 9   |     tv_sec: isize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `free` redeclared with a different signature
[INFO] [stdout]    --> src/screen/ffi/linux.rs:359:9
[INFO] [stdout]     |
[INFO] [stdout] 304 |             fn free(this: *mut XcbInternAtomReply) -> ();
[INFO] [stdout]     |             -------------------------------------------- `free` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 359 |         fn free(event: *mut XcbGenericEvent) -> ();
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(*mut XcbInternAtomReply)`
[INFO] [stdout]                found `unsafe extern "C" fn(*mut XcbGenericEvent)`
[INFO] [stdout]     = note: `#[warn(clashing_extern_declarations)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `ioctl` redeclared with a different signature
[INFO] [stdout]    --> src/hid/ffi/linux.rs:393:3
[INFO] [stdout]     |
[INFO] [stdout] 364 |         fn ioctl(fd: i32, request: usize, v: *mut FfEffect) -> i32;
[INFO] [stdout]     |         ---------------------------------------------------------- `ioctl` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 393 |         fn ioctl(fd: i32, request: usize, v: *mut i16) -> i32;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(i32, usize, *mut FfEffect) -> i32`
[INFO] [stdout]                found `unsafe extern "C" fn(i32, usize, *mut i16) -> i32`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `ioctl` redeclared with a different signature
[INFO] [stdout]    --> src/hid/ffi/linux.rs:417:3
[INFO] [stdout]     |
[INFO] [stdout] 364 |         fn ioctl(fd: i32, request: usize, v: *mut FfEffect) -> i32;
[INFO] [stdout]     |         ---------------------------------------------------------- `ioctl` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 417 |         fn ioctl(fd: i32, request: usize, v: *mut AbsInfo) -> i32;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(i32, usize, *mut FfEffect) -> i32`
[INFO] [stdout]                found `unsafe extern "C" fn(i32, usize, *mut AbsInfo) -> i32`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 152 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 152 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved imports `adi::screen::Event`, `adi::screen::Runner`
[INFO] [stdout]  --> examples/screen_fps.rs:6:24
[INFO] [stdout]   |
[INFO] [stdout] 6 | use adi::screen::{App, Event, Runner};
[INFO] [stdout]   |                        ^^^^^  ^^^^^^ no `Runner` in `screen`
[INFO] [stdout]   |                        |
[INFO] [stdout]   |                        no `Event` in `screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved imports `adi::screen::Event`, `adi::screen::Runner`
[INFO] [stdout]  --> examples/screen_blank.rs:8:24
[INFO] [stdout]   |
[INFO] [stdout] 8 | use adi::screen::{App, Event, Runner};
[INFO] [stdout]   |                        ^^^^^  ^^^^^^ no `Runner` in `screen`
[INFO] [stdout]   |                        |
[INFO] [stdout]   |                        no `Event` in `screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved imports `adi::screen::Event`, `adi::screen::Runner`
[INFO] [stdout]  --> examples/screen_texture.rs:6:24
[INFO] [stdout]   |
[INFO] [stdout] 6 | use adi::screen::{App, Event, Runner};
[INFO] [stdout]   |                        ^^^^^  ^^^^^^ no `Runner` in `screen`
[INFO] [stdout]   |                        |
[INFO] [stdout]   |                        no `Event` in `screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `main` in module `adi::screen`
[INFO] [stdout]   --> examples/screen_blank.rs:19:18
[INFO] [stdout]    |
[INFO] [stdout] 19 |     adi::screen::main(mode)
[INFO] [stdout]    |                  ^^^^ not found in `adi::screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Font` in this scope
[INFO] [stdout]   --> examples/input.rs:18:15
[INFO] [stdout]    |
[INFO] [stdout] 18 |         font: Font<'static>,
[INFO] [stdout]    |               ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find value `FONT` in this scope
[INFO] [stdout]   --> examples/input.rs:31:29
[INFO] [stdout]    |
[INFO] [stdout] 31 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                             ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Font`
[INFO] [stdout]   --> examples/input.rs:31:19
[INFO] [stdout]    |
[INFO] [stdout] 31 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                   ^^^^ use of undeclared type `Font`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved imports `adi::screen::Event`, `adi::screen::Runner`
[INFO] [stdout]  --> examples/screen_circle.rs:6:24
[INFO] [stdout]   |
[INFO] [stdout] 6 | use adi::screen::{App, Event, Runner};
[INFO] [stdout]   |                        ^^^^^  ^^^^^^ no `Runner` in `screen`
[INFO] [stdout]   |                        |
[INFO] [stdout]   |                        no `Event` in `screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0412, E0425, E0433.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0412`.
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `SurfaceInfo` in this scope
[INFO] [stdout]   --> examples/screen_texture.rs:15:18
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub surface: SurfaceInfo,
[INFO] [stdout]    |                  ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Font` in this scope
[INFO] [stdout]   --> examples/screen_texture.rs:17:15
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub font: Font<'static>,
[INFO] [stdout]    |               ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `SurfaceInfo` in this scope
[INFO] [stdout]   --> examples/screen_fps.rs:15:18
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub surface: SurfaceInfo,
[INFO] [stdout]    |                  ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find value `FONT` in this scope
[INFO] [stdout]   --> examples/screen_texture.rs:29:29
[INFO] [stdout]    |
[INFO] [stdout] 29 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                             ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `main` in module `adi::screen`
[INFO] [stdout]   --> examples/screen_texture.rs:97:18
[INFO] [stdout]    |
[INFO] [stdout] 97 |     adi::screen::main(mode)
[INFO] [stdout]    |                  ^^^^ not found in `adi::screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Font` in this scope
[INFO] [stdout]   --> examples/screen_fps.rs:17:15
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub font: Font<'static>,
[INFO] [stdout]    |               ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find value `FONT` in this scope
[INFO] [stdout]   --> examples/screen_fps.rs:26:29
[INFO] [stdout]    |
[INFO] [stdout] 26 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                             ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `main` in module `adi::screen`
[INFO] [stdout]   --> examples/screen_fps.rs:70:18
[INFO] [stdout]    |
[INFO] [stdout] 70 |     adi::screen::main(mode)
[INFO] [stdout]    |                  ^^^^ not found in `adi::screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `adi` (example "input") due to 4 previous errors
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_fps.rs:25:22
[INFO] [stdout]    |
[INFO] [stdout] 25 |             surface: SurfaceInfo::new(Size(0, 0), None),
[INFO] [stdout]    |                      ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Font`
[INFO] [stdout]   --> examples/screen_fps.rs:26:19
[INFO] [stdout]    |
[INFO] [stdout] 26 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                   ^^^^ use of undeclared type `Font`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_texture.rs:28:22
[INFO] [stdout]    |
[INFO] [stdout] 28 |             surface: SurfaceInfo::new(Size(0, 0), None),
[INFO] [stdout]    |                      ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Font`
[INFO] [stdout]   --> examples/screen_texture.rs:29:19
[INFO] [stdout]    |
[INFO] [stdout] 29 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                   ^^^^ use of undeclared type `Font`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `SurfaceInfo` in this scope
[INFO] [stdout]   --> examples/screen_circle.rs:15:18
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub surface: SurfaceInfo,
[INFO] [stdout]    |                  ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Font` in this scope
[INFO] [stdout]   --> examples/screen_circle.rs:17:15
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub font: Font<'static>,
[INFO] [stdout]    |               ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find value `FONT` in this scope
[INFO] [stdout]   --> examples/screen_circle.rs:29:29
[INFO] [stdout]    |
[INFO] [stdout] 29 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                             ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `main` in module `adi::screen`
[INFO] [stdout]   --> examples/screen_circle.rs:88:18
[INFO] [stdout]    |
[INFO] [stdout] 88 |     adi::screen::main(mode)
[INFO] [stdout]    |                  ^^^^ not found in `adi::screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_circle.rs:28:22
[INFO] [stdout]    |
[INFO] [stdout] 28 |             surface: SurfaceInfo::new(Size(0, 0), None),
[INFO] [stdout]    |                      ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Font`
[INFO] [stdout]   --> examples/screen_circle.rs:29:19
[INFO] [stdout]    |
[INFO] [stdout] 29 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                   ^^^^ use of undeclared type `Font`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `stop` found for mutable reference `&mut adi::screen::App` in the current scope
[INFO] [stdout]   --> examples/screen_blank.rs:13:28
[INFO] [stdout]    |
[INFO] [stdout] 13 |         Event::Exit => app.stop(),
[INFO] [stdout]    |                            ^^^^ method not found in `&mut App`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0425, E0432, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0425`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `adi` (example "screen_blank") due to 4 previous errors
[INFO] [stdout] error[E0599]: no method named `stop` found for mutable reference `&mut adi::screen::App` in the current scope
[INFO] [stdout]   --> examples/screen_fps.rs:34:28
[INFO] [stdout]    |
[INFO] [stdout] 34 |         Event::Exit => app.stop(),
[INFO] [stdout]    |                            ^^^^ method not found in `&mut App`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `stop` found for mutable reference `&mut adi::screen::App` in the current scope
[INFO] [stdout]   --> examples/screen_texture.rs:38:28
[INFO] [stdout]    |
[INFO] [stdout] 38 |         Event::Exit => app.stop(),
[INFO] [stdout]    |                            ^^^^ method not found in `&mut App`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_fps.rs:41:35
[INFO] [stdout]    |
[INFO] [stdout] 41 |                     ctx.surface = SurfaceInfo::new(Size(w, h), Some(app.pitch()));
[INFO] [stdout]    |                                   ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_texture.rs:43:31
[INFO] [stdout]    |
[INFO] [stdout] 43 |                 ctx.surface = SurfaceInfo::new(Size(w, h), Some(app.pitch()));
[INFO] [stdout]    |                               ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `LinkSurface`
[INFO] [stdout]   --> examples/screen_fps.rs:52:39
[INFO] [stdout]    |
[INFO] [stdout] 52 |                     let mut surface = LinkSurface::new(&mut ctx.surface, pixel_buffer);
[INFO] [stdout]    |                                       ^^^^^^^^^^^ use of undeclared type `LinkSurface`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `LinkSurface`
[INFO] [stdout]   --> examples/screen_texture.rs:62:35
[INFO] [stdout]    |
[INFO] [stdout] 62 |                 let mut surface = LinkSurface::new(&mut ctx.surface, pixel_buffer);
[INFO] [stdout]    |                                   ^^^^^^^^^^^ use of undeclared type `LinkSurface`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_texture.rs:77:25
[INFO] [stdout]    |
[INFO] [stdout] 77 |                         Move(0.75, 0.75, 0.0),
[INFO] [stdout]    |                         ^^^^           -----
[INFO] [stdout]    |                                        | |
[INFO] [stdout]    |                                        | unexpected argument of type `{float}`
[INFO] [stdout]    |                                        help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     Move(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_texture.rs:78:25
[INFO] [stdout]    |
[INFO] [stdout] 78 |                         Line(0.25, 0.75, 0.0),
[INFO] [stdout]    |                         ^^^^           -----
[INFO] [stdout]    |                                        | |
[INFO] [stdout]    |                                        | unexpected argument of type `{float}`
[INFO] [stdout]    |                                        help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     Line(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_texture.rs:79:25
[INFO] [stdout]    |
[INFO] [stdout] 79 |                         Line(0.25, 0.25, 0.0),
[INFO] [stdout]    |                         ^^^^           -----
[INFO] [stdout]    |                                        | |
[INFO] [stdout]    |                                        | unexpected argument of type `{float}`
[INFO] [stdout]    |                                        help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     Line(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_texture.rs:80:25
[INFO] [stdout]    |
[INFO] [stdout] 80 |                         Line(0.75, 0.25, 0.0),
[INFO] [stdout]    |                         ^^^^           -----
[INFO] [stdout]    |                                        | |
[INFO] [stdout]    |                                        | unexpected argument of type `{float}`
[INFO] [stdout]    |                                        help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     Line(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_texture.rs:81:25
[INFO] [stdout]    |
[INFO] [stdout] 81 |                         Line(0.75, 0.75, 0.0),
[INFO] [stdout]    |                         ^^^^           -----
[INFO] [stdout]    |                                        | |
[INFO] [stdout]    |                                        | unexpected argument of type `{float}`
[INFO] [stdout]    |                                        help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     Line(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 10 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0412, E0425, E0432, E0433, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0412`.
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 15 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0061, E0412, E0425, E0432, E0433, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0061`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `adi` (example "screen_fps") due to 11 previous errors
[INFO] [stderr] error: could not compile `adi` (example "screen_texture") due to 16 previous errors
[INFO] [stdout] error[E0599]: no method named `stop` found for mutable reference `&mut adi::screen::App` in the current scope
[INFO] [stdout]   --> examples/screen_circle.rs:38:28
[INFO] [stdout]    |
[INFO] [stdout] 38 |         Event::Exit => app.stop(),
[INFO] [stdout]    |                            ^^^^ method not found in `&mut App`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_circle.rs:43:31
[INFO] [stdout]    |
[INFO] [stdout] 43 |                 ctx.surface = SurfaceInfo::new(Size(w, h), Some(app.pitch()));
[INFO] [stdout]    |                               ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `LinkSurface`
[INFO] [stdout]   --> examples/screen_circle.rs:62:35
[INFO] [stdout]    |
[INFO] [stdout] 62 |                 let mut surface = LinkSurface::new(&mut ctx.surface, pixel_buffer);
[INFO] [stdout]    |                                   ^^^^^^^^^^^ use of undeclared type `LinkSurface`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_circle.rs:68:25
[INFO] [stdout]    |
[INFO] [stdout] 68 |                         Move(0.25, 0.5, 0.0),
[INFO] [stdout]    |                         ^^^^          -----
[INFO] [stdout]    |                                       | |
[INFO] [stdout]    |                                       | unexpected argument of type `{float}`
[INFO] [stdout]    |                                       help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     Move(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 4 arguments but 6 arguments were supplied
[INFO] [stdout]   --> examples/screen_circle.rs:69:25
[INFO] [stdout]    |
[INFO] [stdout] 69 |                         Quad(0.25, 0.75, 0.0, 0.5, 0.75, 0.0),
[INFO] [stdout]    |                         ^^^^                       ----  --- unexpected argument of type `{float}`
[INFO] [stdout]    |                                                    |
[INFO] [stdout]    |                                                    unexpected argument of type `{float}`
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Quad(f32, f32, f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] help: remove the extra arguments
[INFO] [stdout]    |
[INFO] [stdout] 69 -                         Quad(0.25, 0.75, 0.0, 0.5, 0.75, 0.0),
[INFO] [stdout] 69 +                         Quad(0.25, 0.75, 0.0, 0.5),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 4 arguments but 6 arguments were supplied
[INFO] [stdout]   --> examples/screen_circle.rs:70:25
[INFO] [stdout]    |
[INFO] [stdout] 70 |                         Quad(0.75, 0.75, 0.0, 0.75, 0.5, 0.0),
[INFO] [stdout]    |                         ^^^^                        ---  --- unexpected argument of type `{float}`
[INFO] [stdout]    |                                                     |
[INFO] [stdout]    |                                                     unexpected argument of type `{float}`
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Quad(f32, f32, f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] help: remove the extra arguments
[INFO] [stdout]    |
[INFO] [stdout] 70 -                         Quad(0.75, 0.75, 0.0, 0.75, 0.5, 0.0),
[INFO] [stdout] 70 +                         Quad(0.75, 0.75, 0.0, 0.75),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 4 arguments but 6 arguments were supplied
[INFO] [stdout]   --> examples/screen_circle.rs:71:25
[INFO] [stdout]    |
[INFO] [stdout] 71 |                         Quad(0.75, 0.25, 0.0, 0.5, 0.25, 0.0),
[INFO] [stdout]    |                         ^^^^                       ----  --- unexpected argument of type `{float}`
[INFO] [stdout]    |                                                    |
[INFO] [stdout]    |                                                    unexpected argument of type `{float}`
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Quad(f32, f32, f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] help: remove the extra arguments
[INFO] [stdout]    |
[INFO] [stdout] 71 -                         Quad(0.75, 0.25, 0.0, 0.5, 0.25, 0.0),
[INFO] [stdout] 71 +                         Quad(0.75, 0.25, 0.0, 0.5),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 4 arguments but 6 arguments were supplied
[INFO] [stdout]   --> examples/screen_circle.rs:72:25
[INFO] [stdout]    |
[INFO] [stdout] 72 |                         Quad(0.25, 0.25, 0.0, 0.25, 0.5, 0.0),
[INFO] [stdout]    |                         ^^^^                        ---  --- unexpected argument of type `{float}`
[INFO] [stdout]    |                                                     |
[INFO] [stdout]    |                                                     unexpected argument of type `{float}`
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Quad(f32, f32, f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] help: remove the extra arguments
[INFO] [stdout]    |
[INFO] [stdout] 72 -                         Quad(0.25, 0.25, 0.0, 0.25, 0.5, 0.0),
[INFO] [stdout] 72 +                         Quad(0.25, 0.25, 0.0, 0.25),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 15 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0061, E0412, E0425, E0432, E0433, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0061`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `adi` (example "screen_circle") due to 16 previous errors
[INFO] running `Command { std: "docker" "inspect" "6e98403d72645395a5c3e5d234d490a28800ebad82de71d1d0085d53287cb902", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6e98403d72645395a5c3e5d234d490a28800ebad82de71d1d0085d53287cb902", kill_on_drop: false }`
[INFO] [stdout] 6e98403d72645395a5c3e5d234d490a28800ebad82de71d1d0085d53287cb902
[INFO] checking adi-0.13.0-pre2 against try#bfe97fcae016881ad333f0ff8cea2cadb9cf136c for pr-121848
[INFO] extracting crate adi 0.13.0-pre2 into /workspace/builds/worker-1-tc2/source
[INFO] validating manifest of crates.io crate adi 0.13.0-pre2 on toolchain bfe97fcae016881ad333f0ff8cea2cadb9cf136c
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bfe97fcae016881ad333f0ff8cea2cadb9cf136c" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate adi 0.13.0-pre2
[INFO] finished tweaking crates.io crate adi 0.13.0-pre2
[INFO] tweaked toml for crates.io crate adi 0.13.0-pre2 written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bfe97fcae016881ad333f0ff8cea2cadb9cf136c" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bfe97fcae016881ad333f0ff8cea2cadb9cf136c" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+bfe97fcae016881ad333f0ff8cea2cadb9cf136c" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 75f771c54b54ae5cbdb1ba4b0644feabf0214de1c4022ecb60932ed1b8c4622e
[INFO] running `Command { std: "docker" "start" "-a" "75f771c54b54ae5cbdb1ba4b0644feabf0214de1c4022ecb60932ed1b8c4622e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "75f771c54b54ae5cbdb1ba4b0644feabf0214de1c4022ecb60932ed1b8c4622e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "75f771c54b54ae5cbdb1ba4b0644feabf0214de1c4022ecb60932ed1b8c4622e", kill_on_drop: false }`
[INFO] [stdout] 75f771c54b54ae5cbdb1ba4b0644feabf0214de1c4022ecb60932ed1b8c4622e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+bfe97fcae016881ad333f0ff8cea2cadb9cf136c" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a96e63188e0acb8b8d15b13ee9e25924cf16eb5dca0fe478bee89003d6200294
[INFO] running `Command { std: "docker" "start" "-a" "a96e63188e0acb8b8d15b13ee9e25924cf16eb5dca0fe478bee89003d6200294", kill_on_drop: false }`
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]     Checking adler32 v1.2.0
[INFO] [stderr]    Compiling libc v0.2.153
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]     Checking bitflags v0.9.1
[INFO] [stderr]     Checking tinyvec_macros v0.1.1
[INFO] [stderr]    Compiling cgmath v0.16.1
[INFO] [stderr]     Checking unicode-width v0.1.11
[INFO] [stderr]     Checking approx v0.1.1
[INFO] [stderr]     Checking lazy_static v0.2.11
[INFO] [stderr]     Checking afi v0.8.0-pre0
[INFO] [stderr]     Checking tinyvec v1.6.0
[INFO] [stderr]     Checking inflate v0.3.4
[INFO] [stderr]     Checking deflate v0.7.20
[INFO] [stderr]     Checking unicode-normalization v0.1.23
[INFO] [stderr]     Checking rand v0.4.6
[INFO] [stderr]     Checking dl_api v0.2.0
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking num-traits v0.1.43
[INFO] [stderr]     Checking num-iter v0.1.44
[INFO] [stderr]     Checking png v0.10.0
[INFO] [stderr]     Checking footile v0.2.0
[INFO] [stderr]     Checking fonterator v0.3.0
[INFO] [stderr]     Checking barg v0.0.3
[INFO] [stderr]     Checking ami v0.13.1
[INFO] [stderr]     Checking adi v0.13.0-pre2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]  --> src/screen/gpu_data.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::screen::ffi::render::*;
[INFO] [stdout]   |     ----------------------------- the item `Matrix` is already imported here
[INFO] [stdout] 7 | use crate::screen::Matrix;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]   --> src/screen/viewer.rs:24:35
[INFO] [stdout]    |
[INFO] [stdout] 24 |         let viewer_new = unsafe { (super::CONTEXT.viewer_new) };
[INFO] [stdout]    |                                   ^                         ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 24 -         let viewer_new = unsafe { (super::CONTEXT.viewer_new) };
[INFO] [stdout] 24 +         let viewer_new = unsafe { super::CONTEXT.viewer_new };
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/screen/viewer.rs:159:35
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let viewer_old = unsafe { (super::CONTEXT.viewer_old) };
[INFO] [stdout]     |                                   ^                         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 159 -         let viewer_old = unsafe { (super::CONTEXT.viewer_old) };
[INFO] [stdout] 159 +         let viewer_old = unsafe { super::CONTEXT.viewer_old };
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `std` is imported redundantly
[INFO] [stdout]  --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     std,
[INFO] [stdout]   |     ^^^ the item `std` is already defined here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::ffi::Vector`
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub use crate::screen::ffi::Vector;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `ShapeHandle` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `ShapeHandle` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::ShapeHandle;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/mod.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 28 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Gradient` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use self::base::Gradient;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Gradient` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Model` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub use self::base::Model;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Model` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Shape` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use self::base::Shape;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Shape` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `TexCoords` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use self::base::TexCoords;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `TexCoords` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Texture` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub use self::base::Texture;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Texture` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] 23 |
[INFO] [stdout] 24 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Gradient` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use self::base::Gradient;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Gradient` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Model` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub use self::base::Model;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Model` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Shape` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use self::base::Shape;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Shape` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `TexCoords` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use self::base::TexCoords;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `TexCoords` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Texture` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub use self::base::Texture;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Texture` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/hid/ffi/linux.rs:310:6
[INFO] [stdout]     |
[INFO] [stdout] 310 |     };
[INFO] [stdout]     |      ^ help: remove this semicolon
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(redundant_semicolons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `libc` is imported redundantly
[INFO] [stdout]   --> src/shared/alsa/alsa.rs:3:5
[INFO] [stdout]    |
[INFO] [stdout] 3  | use libc;
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:37:1
[INFO] [stdout]    |
[INFO] [stdout] 37 | extern crate libc;
[INFO] [stdout]    | ------------------ the item `libc` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]  --> src/screen/gpu_data.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::screen::ffi::render::*;
[INFO] [stdout]   |     ----------------------------- the item `Matrix` is already imported here
[INFO] [stdout] 7 | use crate::screen::Matrix;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]   --> src/screen/viewer.rs:24:35
[INFO] [stdout]    |
[INFO] [stdout] 24 |         let viewer_new = unsafe { (super::CONTEXT.viewer_new) };
[INFO] [stdout]    |                                   ^                         ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 24 -         let viewer_new = unsafe { (super::CONTEXT.viewer_new) };
[INFO] [stdout] 24 +         let viewer_new = unsafe { super::CONTEXT.viewer_new };
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around block return value
[INFO] [stdout]    --> src/screen/viewer.rs:159:35
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let viewer_old = unsafe { (super::CONTEXT.viewer_old) };
[INFO] [stdout]     |                                   ^                         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 159 -         let viewer_old = unsafe { (super::CONTEXT.viewer_old) };
[INFO] [stdout] 159 +         let viewer_old = unsafe { super::CONTEXT.viewer_old };
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `std` is imported redundantly
[INFO] [stdout]  --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     std,
[INFO] [stdout]   |     ^^^ the item `std` is already defined here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::ffi::Vector`
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub use crate::screen::ffi::Vector;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `ShapeHandle` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `ShapeHandle` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::ShapeHandle;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/mod.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 28 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Gradient` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use self::base::Gradient;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Gradient` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Model` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub use self::base::Model;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Model` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Shape` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use self::base::Shape;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Shape` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `TexCoords` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use self::base::TexCoords;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `TexCoords` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Texture` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub use self::base::Texture;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Texture` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] 23 |
[INFO] [stdout] 24 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Matrix` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use crate::screen::ffi::Matrix;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Matrix` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Gradient` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use self::base::Gradient;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Gradient` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Model` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub use self::base::Model;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Model` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Shape` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use self::base::Shape;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Shape` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `TexCoords` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use self::base::TexCoords;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `TexCoords` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Texture` is imported redundantly
[INFO] [stdout]   --> src/screen/ffi/render/opengl/mod.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub use self::base::Texture;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 | use super::base::*;
[INFO] [stdout]    |     -------------- the item `Texture` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]    --> src/hid/ffi/linux.rs:310:6
[INFO] [stdout]     |
[INFO] [stdout] 310 |     };
[INFO] [stdout]     |      ^ help: remove this semicolon
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(redundant_semicolons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `libc` is imported redundantly
[INFO] [stdout]   --> src/shared/alsa/alsa.rs:3:5
[INFO] [stdout]    |
[INFO] [stdout] 3  | use libc;
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]   ::: src/lib.rs:37:1
[INFO] [stdout]    |
[INFO] [stdout] 37 | extern crate libc;
[INFO] [stdout]    | ------------------ the item `libc` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:44:8
[INFO] [stdout]    |
[INFO] [stdout] 44 | #![doc(html_logo_url = "http://plopgrizzly.com/adi_screen/icon.png",
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout]    = note: `#[warn(invalid_doc_attributes)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     html_favicon_url = "http://plopgrizzly.com/adi_screen/icon.ico",
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     html_root_url = "http://plopgrizzly.com/adi_screen/")]
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:79:27
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let mut layout = mem::uninitialized();
[INFO] [stdout]    |                           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:101:27
[INFO] [stdout]     |
[INFO] [stdout] 101 |     let mut mapped = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:125:26
[INFO] [stdout]     |
[INFO] [stdout] 125 |     let mut props = mem::uninitialized();
[INFO] [stdout]     |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:217:30
[INFO] [stdout]     |
[INFO] [stdout] 217 |     let mut semaphore = mem::uninitialized();
[INFO] [stdout]     |                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:395:29
[INFO] [stdout]     |
[INFO] [stdout] 395 |     let mut image_id = mem::uninitialized();
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:421:33
[INFO] [stdout]     |
[INFO] [stdout] 421 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:478:33
[INFO] [stdout]     |
[INFO] [stdout] 478 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:537:31
[INFO] [stdout]     |
[INFO] [stdout] 537 |     let mut image_view = mem::uninitialized();
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:790:32
[INFO] [stdout]     |
[INFO] [stdout] 790 |     let mut render_pass = mem::uninitialized();
[INFO] [stdout]     |                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:956:40
[INFO] [stdout]     |
[INFO] [stdout] 956 |         let mut shader = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:36:40
[INFO] [stdout]    |
[INFO] [stdout] 36 |         let mut buffer = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:37:40
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut memory = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:38:42
[INFO] [stdout]    |
[INFO] [stdout] 38 |         let mut mem_reqs = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:108:48
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mut mapped: *mut T = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/fence.rs:40:26
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let mut fence = mem::uninitialized();
[INFO] [stdout]    |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:99:29
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let mut instance = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/command_pool.rs:53:35
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let mut command_buffer = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:42:30
[INFO] [stdout]    |
[INFO] [stdout] 42 |     let mut gpus = vec![mem::uninitialized(); num_gpus as usize];
[INFO] [stdout]    |                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:92:39
[INFO] [stdout]    |
[INFO] [stdout] 92 |                 let mut format = mem::uninitialized();
[INFO] [stdout]    |                                       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:97:38
[INFO] [stdout]    |
[INFO] [stdout] 97 |                 let mut props = mem::uninitialized();
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:122:27
[INFO] [stdout]     |
[INFO] [stdout] 122 |     let mut device = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/queue.rs:29:26
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let mut queue = mem::uninitialized();
[INFO] [stdout]    |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/sampler.rs:27:28
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut sampler = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/surface.rs:37:41
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut surface = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:42:34
[INFO] [stdout]    |
[INFO] [stdout] 42 |             let mut image = mem::uninitialized();
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:43:35
[INFO] [stdout]    |
[INFO] [stdout] 43 |             let mut memory = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:44:40
[INFO] [stdout]    |
[INFO] [stdout] 44 |             let mut memory_reqs = mem::uninitialized();
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:48:34
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let mut desc_pool = mem::uninitialized();
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:49:33
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let mut desc_set = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:123:25
[INFO] [stdout]     |
[INFO] [stdout] 123 |             ::std::mem::uninitialized()
[INFO] [stdout]     |                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:209:33
[INFO] [stdout]     |
[INFO] [stdout] 209 |             sets: unsafe { mem::uninitialized() },
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:244:77
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut buffer_infos: [VkDescriptorBufferInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:245:75
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let mut image_infos: [VkDescriptorImageInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:246:69
[INFO] [stdout]     |
[INFO] [stdout] 246 |         let mut writes: [VkWriteDescriptorSet; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:68:33
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let mut pipeline = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:69:40
[INFO] [stdout]    |
[INFO] [stdout] 69 |         let mut pipeline_layout = mem::uninitialized();
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:70:38
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut descsetlayout = mem::uninitialized();
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:256:68
[INFO] [stdout]     |
[INFO] [stdout] 256 |         let mut frame_buffers: [VkFramebuffer; 2] = [unsafe { mem::uninitialized() }; 2];
[INFO] [stdout]     |                                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:564:29
[INFO] [stdout]     |
[INFO] [stdout] 564 |                 ::std::mem::uninitialized(),
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:575:22
[INFO] [stdout]     |
[INFO] [stdout] 575 |                 mem::uninitialized()
[INFO] [stdout]     |                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:578:45
[INFO] [stdout]     |
[INFO] [stdout] 578 |             transform: unsafe { ::std::mem::uninitialized() },
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:910:31
[INFO] [stdout]     |
[INFO] [stdout] 910 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:967:31
[INFO] [stdout]     |
[INFO] [stdout] 967 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:968:31
[INFO] [stdout]     |
[INFO] [stdout] 968 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1027:31
[INFO] [stdout]      |
[INFO] [stdout] 1027 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1092:31
[INFO] [stdout]      |
[INFO] [stdout] 1092 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1151:31
[INFO] [stdout]      |
[INFO] [stdout] 1151 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:118:42
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let mut nconfigs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:169:43
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut visual_id = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/buffer.rs:19:42
[INFO] [stdout]    |
[INFO] [stdout] 19 |         let mut buffers = [unsafe { mem::uninitialized() }];
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:111:46
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:119:50
[INFO] [stdout]     |
[INFO] [stdout] 119 |             let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:124:65
[INFO] [stdout]     |
[INFO] [stdout] 124 |             let mut buffer: Vec<u8> = vec![unsafe { ::std::mem::uninitialized() }; value as usize];
[INFO] [stdout]     |                                                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/texture.rs:20:50
[INFO] [stdout]    |
[INFO] [stdout] 20 |                 let mut a = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:44:8
[INFO] [stdout]    |
[INFO] [stdout] 44 | #![doc(html_logo_url = "http://plopgrizzly.com/adi_screen/icon.png",
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout]    = note: `#[warn(invalid_doc_attributes)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     html_favicon_url = "http://plopgrizzly.com/adi_screen/icon.ico",
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: this attribute can only be applied at the crate level
[INFO] [stdout]   --> src/screen/mod.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 46 |     html_root_url = "http://plopgrizzly.com/adi_screen/")]
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]    = note: for more information, see issue #82730 <https://github.com/rust-lang/rust/issues/82730>
[INFO] [stdout]    = note: read <https://doc.rust-lang.org/nightly/rustdoc/the-doc-attribute.html#at-the-crate-level> for more information
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/hid/ffi/linux.rs:414:28
[INFO] [stdout]     |
[INFO] [stdout] 414 |     let mut a = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/hid/ffi/linux.rs:456:29
[INFO] [stdout]     |
[INFO] [stdout] 456 |     let mut js = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/mod.rs:96:26
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub fn draw(writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub fn draw(writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]    |                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/screen/mod.rs:29:29
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub(crate) display: Box<Display>,
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub(crate) display: Box<dyn Display>,
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/screen/mod.rs:100:41
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/ffi/render/mod.rs:29:43
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub(crate) fn new_display() -> Result<Box<Display>, String> {
[INFO] [stdout]    |                                           ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub(crate) fn new_display() -> Result<Box<dyn Display>, String> {
[INFO] [stdout]    |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/base.rs:130:37
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) -> ();
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) -> ();
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/mod.rs:217:37
[INFO] [stdout]     |
[INFO] [stdout] 217 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 217 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:79:27
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let mut layout = mem::uninitialized();
[INFO] [stdout]    |                           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:101:27
[INFO] [stdout]     |
[INFO] [stdout] 101 |     let mut mapped = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:125:26
[INFO] [stdout]     |
[INFO] [stdout] 125 |     let mut props = mem::uninitialized();
[INFO] [stdout]     |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:217:30
[INFO] [stdout]     |
[INFO] [stdout] 217 |     let mut semaphore = mem::uninitialized();
[INFO] [stdout]     |                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:395:29
[INFO] [stdout]     |
[INFO] [stdout] 395 |     let mut image_id = mem::uninitialized();
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:421:33
[INFO] [stdout]     |
[INFO] [stdout] 421 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:478:33
[INFO] [stdout]     |
[INFO] [stdout] 478 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:537:31
[INFO] [stdout]     |
[INFO] [stdout] 537 |     let mut image_view = mem::uninitialized();
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:790:32
[INFO] [stdout]     |
[INFO] [stdout] 790 |     let mut render_pass = mem::uninitialized();
[INFO] [stdout]     |                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:956:40
[INFO] [stdout]     |
[INFO] [stdout] 956 |         let mut shader = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:36:40
[INFO] [stdout]    |
[INFO] [stdout] 36 |         let mut buffer = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:37:40
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut memory = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:38:42
[INFO] [stdout]    |
[INFO] [stdout] 38 |         let mut mem_reqs = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:108:48
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mut mapped: *mut T = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/fence.rs:40:26
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let mut fence = mem::uninitialized();
[INFO] [stdout]    |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:99:29
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let mut instance = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/command_pool.rs:53:35
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let mut command_buffer = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:42:30
[INFO] [stdout]    |
[INFO] [stdout] 42 |     let mut gpus = vec![mem::uninitialized(); num_gpus as usize];
[INFO] [stdout]    |                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:92:39
[INFO] [stdout]    |
[INFO] [stdout] 92 |                 let mut format = mem::uninitialized();
[INFO] [stdout]    |                                       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:97:38
[INFO] [stdout]    |
[INFO] [stdout] 97 |                 let mut props = mem::uninitialized();
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:122:27
[INFO] [stdout]     |
[INFO] [stdout] 122 |     let mut device = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/queue.rs:29:26
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let mut queue = mem::uninitialized();
[INFO] [stdout]    |                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/sampler.rs:27:28
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut sampler = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/surface.rs:37:41
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut surface = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:42:34
[INFO] [stdout]    |
[INFO] [stdout] 42 |             let mut image = mem::uninitialized();
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:43:35
[INFO] [stdout]    |
[INFO] [stdout] 43 |             let mut memory = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:44:40
[INFO] [stdout]    |
[INFO] [stdout] 44 |             let mut memory_reqs = mem::uninitialized();
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:48:34
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let mut desc_pool = mem::uninitialized();
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:49:33
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let mut desc_set = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:123:25
[INFO] [stdout]     |
[INFO] [stdout] 123 |             ::std::mem::uninitialized()
[INFO] [stdout]     |                         ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:209:33
[INFO] [stdout]     |
[INFO] [stdout] 209 |             sets: unsafe { mem::uninitialized() },
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:244:77
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut buffer_infos: [VkDescriptorBufferInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:245:75
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let mut image_infos: [VkDescriptorImageInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:246:69
[INFO] [stdout]     |
[INFO] [stdout] 246 |         let mut writes: [VkWriteDescriptorSet; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:68:33
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let mut pipeline = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:69:40
[INFO] [stdout]    |
[INFO] [stdout] 69 |         let mut pipeline_layout = mem::uninitialized();
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:70:38
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut descsetlayout = mem::uninitialized();
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:256:68
[INFO] [stdout]     |
[INFO] [stdout] 256 |         let mut frame_buffers: [VkFramebuffer; 2] = [unsafe { mem::uninitialized() }; 2];
[INFO] [stdout]     |                                                                    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:564:29
[INFO] [stdout]     |
[INFO] [stdout] 564 |                 ::std::mem::uninitialized(),
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:575:22
[INFO] [stdout]     |
[INFO] [stdout] 575 |                 mem::uninitialized()
[INFO] [stdout]     |                      ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:578:45
[INFO] [stdout]     |
[INFO] [stdout] 578 |             transform: unsafe { ::std::mem::uninitialized() },
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:910:31
[INFO] [stdout]     |
[INFO] [stdout] 910 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:967:31
[INFO] [stdout]     |
[INFO] [stdout] 967 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:968:31
[INFO] [stdout]     |
[INFO] [stdout] 968 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1027:31
[INFO] [stdout]      |
[INFO] [stdout] 1027 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1092:31
[INFO] [stdout]      |
[INFO] [stdout] 1092 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1151:31
[INFO] [stdout]      |
[INFO] [stdout] 1151 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:118:42
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let mut nconfigs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:169:43
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut visual_id = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/buffer.rs:19:42
[INFO] [stdout]    |
[INFO] [stdout] 19 |         let mut buffers = [unsafe { mem::uninitialized() }];
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:111:46
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:119:50
[INFO] [stdout]     |
[INFO] [stdout] 119 |             let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:124:65
[INFO] [stdout]     |
[INFO] [stdout] 124 |             let mut buffer: Vec<u8> = vec![unsafe { ::std::mem::uninitialized() }; value as usize];
[INFO] [stdout]     |                                                                 ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/texture.rs:20:50
[INFO] [stdout]    |
[INFO] [stdout] 20 |                 let mut a = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]    |                                                  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/hid/ffi/linux.rs:414:28
[INFO] [stdout]     |
[INFO] [stdout] 414 |     let mut a = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/hid/ffi/linux.rs:456:29
[INFO] [stdout]     |
[INFO] [stdout] 456 |     let mut js = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/mod.rs:96:26
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub fn draw(writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]    |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub fn draw(writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]    |                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/screen/mod.rs:29:29
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub(crate) display: Box<Display>,
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub(crate) display: Box<dyn Display>,
[INFO] [stdout]    |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/screen/mod.rs:100:41
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/ffi/render/mod.rs:29:43
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub(crate) fn new_display() -> Result<Box<Display>, String> {
[INFO] [stdout]    |                                           ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub(crate) fn new_display() -> Result<Box<dyn Display>, String> {
[INFO] [stdout]    |                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/base.rs:130:37
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) -> ();
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) -> ();
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/mod.rs:217:37
[INFO] [stdout]     |
[INFO] [stdout] 217 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 217 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:213:57
[INFO] [stdout]     |
[INFO] [stdout] 213 | fn set_texture(vw: &Vw, texture: &mut Texture, writer: &Fn(usize) -> [u8; 4]) {
[INFO] [stdout]     |                                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 213 | fn set_texture(vw: &Vw, texture: &mut Texture, writer: &dyn Fn(usize) -> [u8; 4]) {
[INFO] [stdout]     |                                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:332:61
[INFO] [stdout]     |
[INFO] [stdout] 332 |     pub(crate) fn draw(&self, _wh: (u16, u16), writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 332 |     pub(crate) fn draw(&self, _wh: (u16, u16), writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/ffi.rs:31:14
[INFO] [stdout]    |
[INFO] [stdout] 31 |     writer: &Fn(usize) -> [u8; 4],
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 31 |     writer: &dyn Fn(usize) -> [u8; 4],
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/opengl/mod.rs:673:37
[INFO] [stdout]     |
[INFO] [stdout] 673 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 673 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/speaker/mod.rs:70:46
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub fn update(&mut self, generator: &mut FnMut() -> i16) {
[INFO] [stdout]    |                                              ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub fn update(&mut self, generator: &mut dyn FnMut() -> i16) {
[INFO] [stdout]    |                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:213:57
[INFO] [stdout]     |
[INFO] [stdout] 213 | fn set_texture(vw: &Vw, texture: &mut Texture, writer: &Fn(usize) -> [u8; 4]) {
[INFO] [stdout]     |                                                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 213 | fn set_texture(vw: &Vw, texture: &mut Texture, writer: &dyn Fn(usize) -> [u8; 4]) {
[INFO] [stdout]     |                                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:332:61
[INFO] [stdout]     |
[INFO] [stdout] 332 |     pub(crate) fn draw(&self, _wh: (u16, u16), writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 332 |     pub(crate) fn draw(&self, _wh: (u16, u16), writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/renderer/ffi.rs:31:14
[INFO] [stdout]    |
[INFO] [stdout] 31 |     writer: &Fn(usize) -> [u8; 4],
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 31 |     writer: &dyn Fn(usize) -> [u8; 4],
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/screen/ffi/render/opengl/mod.rs:673:37
[INFO] [stdout]     |
[INFO] [stdout] 673 |     fn draw(&mut self, writer: &mut FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 673 |     fn draw(&mut self, writer: &mut dyn FnMut(*mut u8) -> ()) {
[INFO] [stdout]     |                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/speaker/mod.rs:70:46
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub fn update(&mut self, generator: &mut FnMut() -> i16) {
[INFO] [stdout]    |                                              ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub fn update(&mut self, generator: &mut dyn FnMut() -> i16) {
[INFO] [stdout]    |                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FogUniform` is never constructed
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct FogUniform {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FogUniform` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]   --> src/screen/opengl/mod.rs:38:14
[INFO] [stdout]    |
[INFO] [stdout] 38 |     unsafe { OpenGLViewer::from_raw(viewer as *mut _) };
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 38 |     unsafe { let _ = OpenGLViewer::from_raw(viewer as *mut _); };
[INFO] [stdout]    |              +++++++                                         +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSubresourceLayout` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:79:22
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let mut layout = mem::uninitialized();
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                      |
[INFO] [stdout]    |                      this code causes undefined behavior when executed
[INFO] [stdout]    |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub offset: VkDeviceSize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut T` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:101:22
[INFO] [stdout]     |
[INFO] [stdout] 101 |     let mut mapped = mem::uninitialized();
[INFO] [stdout]     |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      this code causes undefined behavior when executed
[INFO] [stdout]     |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkPhysicalDeviceMemoryProperties` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:125:21
[INFO] [stdout]     |
[INFO] [stdout] 125 |     let mut props = mem::uninitialized();
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     this code causes undefined behavior when executed
[INFO] [stdout]     |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:563:5
[INFO] [stdout]     |
[INFO] [stdout] 563 |     pub memory_type_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:217:25
[INFO] [stdout]     |
[INFO] [stdout] 217 |     let mut semaphore = mem::uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         this code causes undefined behavior when executed
[INFO] [stdout]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:395:24
[INFO] [stdout]     |
[INFO] [stdout] 395 |     let mut image_id = mem::uninitialized();
[INFO] [stdout]     |                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                        |
[INFO] [stdout]     |                        this code causes undefined behavior when executed
[INFO] [stdout]     |                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceCapabilitiesKHR` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:421:28
[INFO] [stdout]     |
[INFO] [stdout] 421 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:704:5
[INFO] [stdout]     |
[INFO] [stdout] 704 |     pub min_image_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceCapabilitiesKHR` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:478:28
[INFO] [stdout]     |
[INFO] [stdout] 478 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:704:5
[INFO] [stdout]     |
[INFO] [stdout] 704 |     pub min_image_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:537:26
[INFO] [stdout]     |
[INFO] [stdout] 537 |     let mut image_view = mem::uninitialized();
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkRenderPass` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:790:27
[INFO] [stdout]     |
[INFO] [stdout] 790 |     let mut render_pass = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           this code causes undefined behavior when executed
[INFO] [stdout]     |                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:32:25
[INFO] [stdout]     |
[INFO] [stdout] 32  | pub struct VkRenderPass(pub(crate) u64);
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkShaderModule` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:956:35
[INFO] [stdout]     |
[INFO] [stdout] 956 |         let mut shader = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   this code causes undefined behavior when executed
[INFO] [stdout]     |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:38:34
[INFO] [stdout]     |
[INFO] [stdout] 38  | pub(crate) struct VkShaderModule(pub(crate) u64);
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:36:35
[INFO] [stdout]    |
[INFO] [stdout] 36 |         let mut buffer = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:37:35
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut memory = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkMemoryRequirements` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:38:37
[INFO] [stdout]     |
[INFO] [stdout] 38  |         let mut mem_reqs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:516:5
[INFO] [stdout]     |
[INFO] [stdout] 516 |     pub size: VkDeviceSize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut T` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:108:43
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mut mapped: *mut T = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                           |
[INFO] [stdout]     |                                           this code causes undefined behavior when executed
[INFO] [stdout]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/fence.rs:40:21
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let mut fence = mem::uninitialized();
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     this code causes undefined behavior when executed
[INFO] [stdout]    |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkInstance` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:99:24
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let mut instance = mem::uninitialized();
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                        |
[INFO] [stdout]    |                        this code causes undefined behavior when executed
[INFO] [stdout]    |                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:53:30
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub(crate) struct VkInstance(*mut c_void);
[INFO] [stdout]    |                              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut c_void` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/command_pool.rs:53:30
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let mut command_buffer = mem::uninitialized();
[INFO] [stdout]    |                              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              this code causes undefined behavior when executed
[INFO] [stdout]    |                              help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkPhysicalDevice` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:42:25
[INFO] [stdout]    |
[INFO] [stdout] 42 |     let mut gpus = vec![mem::uninitialized(); num_gpus as usize];
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                         |
[INFO] [stdout]    |                         this code causes undefined behavior when executed
[INFO] [stdout]    |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:50:36
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub(crate) struct VkPhysicalDevice(*mut c_void);
[INFO] [stdout]    |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceFormatKHR` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:92:34
[INFO] [stdout]      |
[INFO] [stdout] 92   |                 let mut format = mem::uninitialized();
[INFO] [stdout]      |                                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                                  |
[INFO] [stdout]      |                                  this code causes undefined behavior when executed
[INFO] [stdout]      |                                  help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: `screen::ffi::render::vulkan::asi::types::VkSurfaceFormatKHR` must be initialized inside its custom valid range
[INFO] [stdout] note: in this struct field
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:718:5
[INFO] [stdout]      |
[INFO] [stdout] 718  |     pub format: VkFormat,
[INFO] [stdout]      |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:1247:1
[INFO] [stdout]      |
[INFO] [stdout] 1247 | pub enum VkFormat {
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkFormatProperties` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:97:33
[INFO] [stdout]     |
[INFO] [stdout] 97  |                 let mut props = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub linear_tiling_features: VkFlags,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkDevice` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:122:22
[INFO] [stdout]     |
[INFO] [stdout] 122 |     let mut device = mem::uninitialized();
[INFO] [stdout]     |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      this code causes undefined behavior when executed
[INFO] [stdout]     |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:47:28
[INFO] [stdout]     |
[INFO] [stdout] 47  | pub(crate) struct VkDevice(*mut c_void);
[INFO] [stdout]     |                            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkQueue` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/queue.rs:29:21
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let mut queue = mem::uninitialized();
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     this code causes undefined behavior when executed
[INFO] [stdout]    |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:56:20
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub struct VkQueue(*mut c_void);
[INFO] [stdout]    |                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/sampler.rs:27:23
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut sampler = mem::uninitialized();
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                       |
[INFO] [stdout]    |                       this code causes undefined behavior when executed
[INFO] [stdout]    |                       help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/surface.rs:37:36
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut surface = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                    |
[INFO] [stdout]    |                                    this code causes undefined behavior when executed
[INFO] [stdout]    |                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:42:29
[INFO] [stdout]    |
[INFO] [stdout] 42 |             let mut image = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                             |
[INFO] [stdout]    |                             this code causes undefined behavior when executed
[INFO] [stdout]    |                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:43:30
[INFO] [stdout]    |
[INFO] [stdout] 43 |             let mut memory = mem::uninitialized();
[INFO] [stdout]    |                              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              this code causes undefined behavior when executed
[INFO] [stdout]    |                              help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkMemoryRequirements` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/image.rs:44:35
[INFO] [stdout]     |
[INFO] [stdout] 44  |             let mut memory_reqs = mem::uninitialized();
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   this code causes undefined behavior when executed
[INFO] [stdout]     |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:516:5
[INFO] [stdout]     |
[INFO] [stdout] 516 |     pub size: VkDeviceSize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:48:29
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let mut desc_pool = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                             |
[INFO] [stdout]    |                             this code causes undefined behavior when executed
[INFO] [stdout]    |                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:49:28
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let mut desc_set = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            this code causes undefined behavior when executed
[INFO] [stdout]    |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::buffer::Buffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:123:13
[INFO] [stdout]     |
[INFO] [stdout] 123 |             ::std::mem::uninitialized()
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             this code causes undefined behavior when executed
[INFO] [stdout]     |             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: `screen::ffi::render::vulkan::asi::buffer::Buffer` must be non-null
[INFO] [stdout] note: because `std::rc::Rc<screen::ffi::render::vulkan::asi::buffer::BufferContext>` must be non-null (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:23:19
[INFO] [stdout]     |
[INFO] [stdout] 23  | pub struct Buffer(Rc<BufferContext>);
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: because `std::ptr::NonNull<std::rc::RcBox<screen::ffi::render::vulkan::asi::buffer::BufferContext>>` must be non-null
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[Set; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:209:28
[INFO] [stdout]     |
[INFO] [stdout] 209 |             sets: unsafe { mem::uninitialized() },
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:297:1
[INFO] [stdout]     |
[INFO] [stdout] 297 | enum Set {
[INFO] [stdout]     | ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkDescriptorBufferInfo; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:244:72
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut buffer_infos: [VkDescriptorBufferInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                                        |
[INFO] [stdout]     |                                                                        this code causes undefined behavior when executed
[INFO] [stdout]     |                                                                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:429:5
[INFO] [stdout]     |
[INFO] [stdout] 429 |     pub buffer: VkBuffer,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkDescriptorImageInfo; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:245:70
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let mut image_infos: [VkDescriptorImageInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                                      |
[INFO] [stdout]     |                                                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:450:5
[INFO] [stdout]     |
[INFO] [stdout] 450 |     pub sampler: VkSampler,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkWriteDescriptorSet; 255]` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/sprite.rs:246:64
[INFO] [stdout]      |
[INFO] [stdout] 246  |         let mut writes: [VkWriteDescriptorSet; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]      |                                                                ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                                                                |
[INFO] [stdout]      |                                                                this code causes undefined behavior when executed
[INFO] [stdout]      |                                                                help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:436:5
[INFO] [stdout]      |
[INFO] [stdout] 436  |     pub s_type: VkStructureType,
[INFO] [stdout]      |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:1438:1
[INFO] [stdout]      |
[INFO] [stdout] 1438 | pub(crate) enum VkStructureType {
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:68:28
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let mut pipeline = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            this code causes undefined behavior when executed
[INFO] [stdout]    |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:69:35
[INFO] [stdout]    |
[INFO] [stdout] 69 |         let mut pipeline_layout = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:70:33
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut descsetlayout = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                 |
[INFO] [stdout]    |                                 this code causes undefined behavior when executed
[INFO] [stdout]    |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkFramebuffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:256:63
[INFO] [stdout]     |
[INFO] [stdout] 256 |         let mut frame_buffers: [VkFramebuffer; 2] = [unsafe { mem::uninitialized() }; 2];
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                               |
[INFO] [stdout]     |                                                               this code causes undefined behavior when executed
[INFO] [stdout]     |                                                               help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:35:26
[INFO] [stdout]     |
[INFO] [stdout] 35  | pub struct VkFramebuffer(pub(crate) u64);
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `&render::vulkan::asi::buffer::Buffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:564:17
[INFO] [stdout]     |
[INFO] [stdout] 564 |                 ::std::mem::uninitialized(),
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 this code causes undefined behavior when executed
[INFO] [stdout]     |                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: references must be non-null
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:575:17
[INFO] [stdout]     |
[INFO] [stdout] 575 |                 mem::uninitialized()
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 this code causes undefined behavior when executed
[INFO] [stdout]     |                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `ami::Matrix` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:578:33
[INFO] [stdout]     |
[INFO] [stdout] 578 |             transform: unsafe { ::std::mem::uninitialized() },
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: floats must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:910:26
[INFO] [stdout]     |
[INFO] [stdout] 910 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:967:26
[INFO] [stdout]     |
[INFO] [stdout] 967 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:968:26
[INFO] [stdout]     |
[INFO] [stdout] 968 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1027:26
[INFO] [stdout]      |
[INFO] [stdout] 1027 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1092:26
[INFO] [stdout]      |
[INFO] [stdout] 1092 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1151:26
[INFO] [stdout]      |
[INFO] [stdout] 1151 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:118:37
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let mut nconfigs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:169:38
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut visual_id = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                      |
[INFO] [stdout]     |                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/buffer.rs:19:37
[INFO] [stdout]    |
[INFO] [stdout] 19 |         let mut buffers = [unsafe { mem::uninitialized() }];
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                     |
[INFO] [stdout]    |                                     this code causes undefined behavior when executed
[INFO] [stdout]    |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:111:34
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  this code causes undefined behavior when executed
[INFO] [stdout]     |                                  help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:119:38
[INFO] [stdout]     |
[INFO] [stdout] 119 |             let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                      |
[INFO] [stdout]     |                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u8` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:124:53
[INFO] [stdout]     |
[INFO] [stdout] 124 |             let mut buffer: Vec<u8> = vec![unsafe { ::std::mem::uninitialized() }; value as usize];
[INFO] [stdout]     |                                                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                     |
[INFO] [stdout]     |                                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/texture.rs:20:38
[INFO] [stdout]    |
[INFO] [stdout] 20 |                 let mut a = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                      |
[INFO] [stdout]    |                                      this code causes undefined behavior when executed
[INFO] [stdout]    |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `AbsInfo` does not permit being left uninitialized
[INFO] [stdout]    --> src/hid/ffi/linux.rs:414:23
[INFO] [stdout]     |
[INFO] [stdout] 414 |     let mut a = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/hid/ffi/linux.rs:406:3
[INFO] [stdout]     |
[INFO] [stdout] 406 |         value: i32,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Event` does not permit being left uninitialized
[INFO] [stdout]    --> src/hid/ffi/linux.rs:456:24
[INFO] [stdout]     |
[INFO] [stdout] 456 |     let mut js = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           this code causes undefined behavior when executed
[INFO] [stdout]     |                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]    --> src/hid/ffi/linux.rs:15:2
[INFO] [stdout]     |
[INFO] [stdout] 15  |     ev_time: TimeVal,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/hid/ffi/linux.rs:9:2
[INFO] [stdout]     |
[INFO] [stdout] 9   |     tv_sec: isize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `free` redeclared with a different signature
[INFO] [stdout]    --> src/screen/ffi/linux.rs:359:9
[INFO] [stdout]     |
[INFO] [stdout] 304 |             fn free(this: *mut XcbInternAtomReply) -> ();
[INFO] [stdout]     |             -------------------------------------------- `free` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 359 |         fn free(event: *mut XcbGenericEvent) -> ();
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(*mut XcbInternAtomReply)`
[INFO] [stdout]                found `unsafe extern "C" fn(*mut XcbGenericEvent)`
[INFO] [stdout]     = note: `#[warn(clashing_extern_declarations)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `ioctl` redeclared with a different signature
[INFO] [stdout]    --> src/hid/ffi/linux.rs:393:3
[INFO] [stdout]     |
[INFO] [stdout] 364 |         fn ioctl(fd: i32, request: usize, v: *mut FfEffect) -> i32;
[INFO] [stdout]     |         ---------------------------------------------------------- `ioctl` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 393 |         fn ioctl(fd: i32, request: usize, v: *mut i16) -> i32;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(i32, usize, *mut FfEffect) -> i32`
[INFO] [stdout]                found `unsafe extern "C" fn(i32, usize, *mut i16) -> i32`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `ioctl` redeclared with a different signature
[INFO] [stdout]    --> src/hid/ffi/linux.rs:417:3
[INFO] [stdout]     |
[INFO] [stdout] 364 |         fn ioctl(fd: i32, request: usize, v: *mut FfEffect) -> i32;
[INFO] [stdout]     |         ---------------------------------------------------------- `ioctl` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 417 |         fn ioctl(fd: i32, request: usize, v: *mut AbsInfo) -> i32;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(i32, usize, *mut FfEffect) -> i32`
[INFO] [stdout]                found `unsafe extern "C" fn(i32, usize, *mut AbsInfo) -> i32`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FogUniform` is never constructed
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct FogUniform {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FogUniform` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 152 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Box::<T>::from_raw` that must be used
[INFO] [stdout]   --> src/screen/opengl/mod.rs:38:14
[INFO] [stdout]    |
[INFO] [stdout] 38 |     unsafe { OpenGLViewer::from_raw(viewer as *mut _) };
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: call `drop(Box::from_raw(ptr))` if you intend to drop the `Box`
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 38 |     unsafe { let _ = OpenGLViewer::from_raw(viewer as *mut _); };
[INFO] [stdout]    |              +++++++                                         +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSubresourceLayout` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/mod.rs:79:22
[INFO] [stdout]    |
[INFO] [stdout] 79 |     let mut layout = mem::uninitialized();
[INFO] [stdout]    |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                      |
[INFO] [stdout]    |                      this code causes undefined behavior when executed
[INFO] [stdout]    |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub offset: VkDeviceSize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut T` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:101:22
[INFO] [stdout]     |
[INFO] [stdout] 101 |     let mut mapped = mem::uninitialized();
[INFO] [stdout]     |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      this code causes undefined behavior when executed
[INFO] [stdout]     |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkPhysicalDeviceMemoryProperties` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:125:21
[INFO] [stdout]     |
[INFO] [stdout] 125 |     let mut props = mem::uninitialized();
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     this code causes undefined behavior when executed
[INFO] [stdout]     |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:563:5
[INFO] [stdout]     |
[INFO] [stdout] 563 |     pub memory_type_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:217:25
[INFO] [stdout]     |
[INFO] [stdout] 217 |     let mut semaphore = mem::uninitialized();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         this code causes undefined behavior when executed
[INFO] [stdout]     |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:395:24
[INFO] [stdout]     |
[INFO] [stdout] 395 |     let mut image_id = mem::uninitialized();
[INFO] [stdout]     |                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                        |
[INFO] [stdout]     |                        this code causes undefined behavior when executed
[INFO] [stdout]     |                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceCapabilitiesKHR` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:421:28
[INFO] [stdout]     |
[INFO] [stdout] 421 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:704:5
[INFO] [stdout]     |
[INFO] [stdout] 704 |     pub min_image_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceCapabilitiesKHR` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:478:28
[INFO] [stdout]     |
[INFO] [stdout] 478 |     let mut surface_info = mem::uninitialized();
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:704:5
[INFO] [stdout]     |
[INFO] [stdout] 704 |     pub min_image_count: u32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:537:26
[INFO] [stdout]     |
[INFO] [stdout] 537 |     let mut image_view = mem::uninitialized();
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkRenderPass` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:790:27
[INFO] [stdout]     |
[INFO] [stdout] 790 |     let mut render_pass = mem::uninitialized();
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           this code causes undefined behavior when executed
[INFO] [stdout]     |                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:32:25
[INFO] [stdout]     |
[INFO] [stdout] 32  | pub struct VkRenderPass(pub(crate) u64);
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkShaderModule` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/mod.rs:956:35
[INFO] [stdout]     |
[INFO] [stdout] 956 |         let mut shader = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   this code causes undefined behavior when executed
[INFO] [stdout]     |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:38:34
[INFO] [stdout]     |
[INFO] [stdout] 38  | pub(crate) struct VkShaderModule(pub(crate) u64);
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:36:35
[INFO] [stdout]    |
[INFO] [stdout] 36 |         let mut buffer = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/buffer.rs:37:35
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut memory = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkMemoryRequirements` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:38:37
[INFO] [stdout]     |
[INFO] [stdout] 38  |         let mut mem_reqs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:516:5
[INFO] [stdout]     |
[INFO] [stdout] 516 |     pub size: VkDeviceSize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut T` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:108:43
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let mut mapped: *mut T = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                           |
[INFO] [stdout]     |                                           this code causes undefined behavior when executed
[INFO] [stdout]     |                                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/fence.rs:40:21
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let mut fence = mem::uninitialized();
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     this code causes undefined behavior when executed
[INFO] [stdout]    |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkInstance` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/mod.rs:99:24
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let mut instance = mem::uninitialized();
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                        |
[INFO] [stdout]    |                        this code causes undefined behavior when executed
[INFO] [stdout]    |                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:53:30
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub(crate) struct VkInstance(*mut c_void);
[INFO] [stdout]    |                              ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `*mut c_void` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/command_pool.rs:53:30
[INFO] [stdout]    |
[INFO] [stdout] 53 |     let mut command_buffer = mem::uninitialized();
[INFO] [stdout]    |                              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              this code causes undefined behavior when executed
[INFO] [stdout]    |                              help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkPhysicalDevice` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:42:25
[INFO] [stdout]    |
[INFO] [stdout] 42 |     let mut gpus = vec![mem::uninitialized(); num_gpus as usize];
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                         |
[INFO] [stdout]    |                         this code causes undefined behavior when executed
[INFO] [stdout]    |                         help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:50:36
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub(crate) struct VkPhysicalDevice(*mut c_void);
[INFO] [stdout]    |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkSurfaceFormatKHR` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:92:34
[INFO] [stdout]      |
[INFO] [stdout] 92   |                 let mut format = mem::uninitialized();
[INFO] [stdout]      |                                  ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                                  |
[INFO] [stdout]      |                                  this code causes undefined behavior when executed
[INFO] [stdout]      |                                  help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: `screen::ffi::render::vulkan::asi::types::VkSurfaceFormatKHR` must be initialized inside its custom valid range
[INFO] [stdout] note: in this struct field
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:718:5
[INFO] [stdout]      |
[INFO] [stdout] 718  |     pub format: VkFormat,
[INFO] [stdout]      |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:1247:1
[INFO] [stdout]      |
[INFO] [stdout] 1247 | pub enum VkFormat {
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkFormatProperties` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:97:33
[INFO] [stdout]     |
[INFO] [stdout] 97  |                 let mut props = mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub linear_tiling_features: VkFlags,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkDevice` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/gpu/device.rs:122:22
[INFO] [stdout]     |
[INFO] [stdout] 122 |     let mut device = mem::uninitialized();
[INFO] [stdout]     |                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      this code causes undefined behavior when executed
[INFO] [stdout]     |                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:47:28
[INFO] [stdout]     |
[INFO] [stdout] 47  | pub(crate) struct VkDevice(*mut c_void);
[INFO] [stdout]     |                            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkQueue` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/queue.rs:29:21
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let mut queue = mem::uninitialized();
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     this code causes undefined behavior when executed
[INFO] [stdout]    |                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/types.rs:56:20
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub struct VkQueue(*mut c_void);
[INFO] [stdout]    |                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/sampler.rs:27:23
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut sampler = mem::uninitialized();
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                       |
[INFO] [stdout]    |                       this code causes undefined behavior when executed
[INFO] [stdout]    |                       help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/gpu/surface.rs:37:36
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mut surface = unsafe { mem::uninitialized() };
[INFO] [stdout]    |                                    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                    |
[INFO] [stdout]    |                                    this code causes undefined behavior when executed
[INFO] [stdout]    |                                    help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:42:29
[INFO] [stdout]    |
[INFO] [stdout] 42 |             let mut image = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                             |
[INFO] [stdout]    |                             this code causes undefined behavior when executed
[INFO] [stdout]    |                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/image.rs:43:30
[INFO] [stdout]    |
[INFO] [stdout] 43 |             let mut memory = mem::uninitialized();
[INFO] [stdout]    |                              ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                              |
[INFO] [stdout]    |                              this code causes undefined behavior when executed
[INFO] [stdout]    |                              help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkMemoryRequirements` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/image.rs:44:35
[INFO] [stdout]     |
[INFO] [stdout] 44  |             let mut memory_reqs = mem::uninitialized();
[INFO] [stdout]     |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                   |
[INFO] [stdout]     |                                   this code causes undefined behavior when executed
[INFO] [stdout]     |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:516:5
[INFO] [stdout]     |
[INFO] [stdout] 516 |     pub size: VkDeviceSize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:48:29
[INFO] [stdout]    |
[INFO] [stdout] 48 |         let mut desc_pool = mem::uninitialized();
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                             |
[INFO] [stdout]    |                             this code causes undefined behavior when executed
[INFO] [stdout]    |                             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/sprite.rs:49:28
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let mut desc_set = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            this code causes undefined behavior when executed
[INFO] [stdout]    |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::buffer::Buffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:123:13
[INFO] [stdout]     |
[INFO] [stdout] 123 |             ::std::mem::uninitialized()
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             this code causes undefined behavior when executed
[INFO] [stdout]     |             help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: `screen::ffi::render::vulkan::asi::buffer::Buffer` must be non-null
[INFO] [stdout] note: because `std::rc::Rc<screen::ffi::render::vulkan::asi::buffer::BufferContext>` must be non-null (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/buffer.rs:23:19
[INFO] [stdout]     |
[INFO] [stdout] 23  | pub struct Buffer(Rc<BufferContext>);
[INFO] [stdout]     |                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: because `std::ptr::NonNull<std::rc::RcBox<screen::ffi::render::vulkan::asi::buffer::BufferContext>>` must be non-null
[INFO] [stdout]     = note: raw pointers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[Set; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:209:28
[INFO] [stdout]     |
[INFO] [stdout] 209 |             sets: unsafe { mem::uninitialized() },
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                            |
[INFO] [stdout]     |                            this code causes undefined behavior when executed
[INFO] [stdout]     |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:297:1
[INFO] [stdout]     |
[INFO] [stdout] 297 | enum Set {
[INFO] [stdout]     | ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkDescriptorBufferInfo; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:244:72
[INFO] [stdout]     |
[INFO] [stdout] 244 |         let mut buffer_infos: [VkDescriptorBufferInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                                        |
[INFO] [stdout]     |                                                                        this code causes undefined behavior when executed
[INFO] [stdout]     |                                                                        help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:429:5
[INFO] [stdout]     |
[INFO] [stdout] 429 |     pub buffer: VkBuffer,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkDescriptorImageInfo; 255]` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/sprite.rs:245:70
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let mut image_infos: [VkDescriptorImageInfo; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                                                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                                      |
[INFO] [stdout]     |                                                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:450:5
[INFO] [stdout]     |
[INFO] [stdout] 450 |     pub sampler: VkSampler,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `[render::vulkan::asi::types::VkWriteDescriptorSet; 255]` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/sprite.rs:246:64
[INFO] [stdout]      |
[INFO] [stdout] 246  |         let mut writes: [VkWriteDescriptorSet; 255] = unsafe { mem::uninitialized() };
[INFO] [stdout]      |                                                                ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                                                                |
[INFO] [stdout]      |                                                                this code causes undefined behavior when executed
[INFO] [stdout]      |                                                                help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:436:5
[INFO] [stdout]      |
[INFO] [stdout] 436  |     pub s_type: VkStructureType,
[INFO] [stdout]      |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] note: enums with multiple inhabited variants have to be initialized to a variant
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/asi/types.rs:1438:1
[INFO] [stdout]      |
[INFO] [stdout] 1438 | pub(crate) enum VkStructureType {
[INFO] [stdout]      | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:68:28
[INFO] [stdout]    |
[INFO] [stdout] 68 |         let mut pipeline = mem::uninitialized();
[INFO] [stdout]    |                            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            this code causes undefined behavior when executed
[INFO] [stdout]    |                            help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:69:35
[INFO] [stdout]    |
[INFO] [stdout] 69 |         let mut pipeline_layout = mem::uninitialized();
[INFO] [stdout]    |                                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                   |
[INFO] [stdout]    |                                   this code causes undefined behavior when executed
[INFO] [stdout]    |                                   help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/vulkan/asi/style.rs:70:33
[INFO] [stdout]    |
[INFO] [stdout] 70 |         let mut descsetlayout = mem::uninitialized();
[INFO] [stdout]    |                                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                 |
[INFO] [stdout]    |                                 this code causes undefined behavior when executed
[INFO] [stdout]    |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `render::vulkan::asi::types::VkFramebuffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:256:63
[INFO] [stdout]     |
[INFO] [stdout] 256 |         let mut frame_buffers: [VkFramebuffer; 2] = [unsafe { mem::uninitialized() }; 2];
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                               |
[INFO] [stdout]     |                                                               this code causes undefined behavior when executed
[INFO] [stdout]     |                                                               help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/asi/types.rs:35:26
[INFO] [stdout]     |
[INFO] [stdout] 35  | pub struct VkFramebuffer(pub(crate) u64);
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `&render::vulkan::asi::buffer::Buffer` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:564:17
[INFO] [stdout]     |
[INFO] [stdout] 564 |                 ::std::mem::uninitialized(),
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 this code causes undefined behavior when executed
[INFO] [stdout]     |                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: references must be non-null
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:575:17
[INFO] [stdout]     |
[INFO] [stdout] 575 |                 mem::uninitialized()
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 this code causes undefined behavior when executed
[INFO] [stdout]     |                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `ami::Matrix` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:578:33
[INFO] [stdout]     |
[INFO] [stdout] 578 |             transform: unsafe { ::std::mem::uninitialized() },
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: floats must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:910:26
[INFO] [stdout]     |
[INFO] [stdout] 910 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:967:26
[INFO] [stdout]     |
[INFO] [stdout] 967 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/vulkan/renderer/mod.rs:968:26
[INFO] [stdout]     |
[INFO] [stdout] 968 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1027:26
[INFO] [stdout]      |
[INFO] [stdout] 1027 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1092:26
[INFO] [stdout]      |
[INFO] [stdout] 1092 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u64` does not permit being left uninitialized
[INFO] [stdout]     --> src/screen/ffi/render/vulkan/renderer/mod.rs:1151:26
[INFO] [stdout]      |
[INFO] [stdout] 1151 |                 unsafe { mem::uninitialized() },
[INFO] [stdout]      |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          this code causes undefined behavior when executed
[INFO] [stdout]      |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]      |
[INFO] [stdout]      = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:118:37
[INFO] [stdout]     |
[INFO] [stdout] 118 |         let mut nconfigs = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/loader.rs:169:38
[INFO] [stdout]     |
[INFO] [stdout] 169 |         let mut visual_id = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                      |
[INFO] [stdout]     |                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/buffer.rs:19:37
[INFO] [stdout]    |
[INFO] [stdout] 19 |         let mut buffers = [unsafe { mem::uninitialized() }];
[INFO] [stdout]    |                                     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                     |
[INFO] [stdout]    |                                     this code causes undefined behavior when executed
[INFO] [stdout]    |                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:111:34
[INFO] [stdout]     |
[INFO] [stdout] 111 |         let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  this code causes undefined behavior when executed
[INFO] [stdout]     |                                  help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `i32` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:119:38
[INFO] [stdout]     |
[INFO] [stdout] 119 |             let mut value = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]     |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                      |
[INFO] [stdout]     |                                      this code causes undefined behavior when executed
[INFO] [stdout]     |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u8` does not permit being left uninitialized
[INFO] [stdout]    --> src/screen/ffi/render/opengl/asi/program.rs:124:53
[INFO] [stdout]     |
[INFO] [stdout] 124 |             let mut buffer: Vec<u8> = vec![unsafe { ::std::mem::uninitialized() }; value as usize];
[INFO] [stdout]     |                                                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                                     |
[INFO] [stdout]     |                                                     this code causes undefined behavior when executed
[INFO] [stdout]     |                                                     help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout]     = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `u32` does not permit being left uninitialized
[INFO] [stdout]   --> src/screen/ffi/render/opengl/asi/texture.rs:20:38
[INFO] [stdout]    |
[INFO] [stdout] 20 |                 let mut a = unsafe { ::std::mem::uninitialized() };
[INFO] [stdout]    |                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |                                      |
[INFO] [stdout]    |                                      this code causes undefined behavior when executed
[INFO] [stdout]    |                                      help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]    |
[INFO] [stdout]    = note: integers must be initialized
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `AbsInfo` does not permit being left uninitialized
[INFO] [stdout]    --> src/hid/ffi/linux.rs:414:23
[INFO] [stdout]     |
[INFO] [stdout] 414 |     let mut a = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                          ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          this code causes undefined behavior when executed
[INFO] [stdout]     |                          help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/hid/ffi/linux.rs:406:3
[INFO] [stdout]     |
[INFO] [stdout] 406 |         value: i32,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Event` does not permit being left uninitialized
[INFO] [stdout]    --> src/hid/ffi/linux.rs:456:24
[INFO] [stdout]     |
[INFO] [stdout] 456 |     let mut js = unsafe { mem::uninitialized() };
[INFO] [stdout]     |                           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           this code causes undefined behavior when executed
[INFO] [stdout]     |                           help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]    --> src/hid/ffi/linux.rs:15:2
[INFO] [stdout]     |
[INFO] [stdout] 15  |     ev_time: TimeVal,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] note: integers must be initialized (in this struct field)
[INFO] [stdout]    --> src/hid/ffi/linux.rs:9:2
[INFO] [stdout]     |
[INFO] [stdout] 9   |     tv_sec: isize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `free` redeclared with a different signature
[INFO] [stdout]    --> src/screen/ffi/linux.rs:359:9
[INFO] [stdout]     |
[INFO] [stdout] 304 |             fn free(this: *mut XcbInternAtomReply) -> ();
[INFO] [stdout]     |             -------------------------------------------- `free` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 359 |         fn free(event: *mut XcbGenericEvent) -> ();
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(*mut XcbInternAtomReply)`
[INFO] [stdout]                found `unsafe extern "C" fn(*mut XcbGenericEvent)`
[INFO] [stdout]     = note: `#[warn(clashing_extern_declarations)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `ioctl` redeclared with a different signature
[INFO] [stdout]    --> src/hid/ffi/linux.rs:393:3
[INFO] [stdout]     |
[INFO] [stdout] 364 |         fn ioctl(fd: i32, request: usize, v: *mut FfEffect) -> i32;
[INFO] [stdout]     |         ---------------------------------------------------------- `ioctl` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 393 |         fn ioctl(fd: i32, request: usize, v: *mut i16) -> i32;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(i32, usize, *mut FfEffect) -> i32`
[INFO] [stdout]                found `unsafe extern "C" fn(i32, usize, *mut i16) -> i32`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `ioctl` redeclared with a different signature
[INFO] [stdout]    --> src/hid/ffi/linux.rs:417:3
[INFO] [stdout]     |
[INFO] [stdout] 364 |         fn ioctl(fd: i32, request: usize, v: *mut FfEffect) -> i32;
[INFO] [stdout]     |         ---------------------------------------------------------- `ioctl` previously declared here
[INFO] [stdout] ...
[INFO] [stdout] 417 |         fn ioctl(fd: i32, request: usize, v: *mut AbsInfo) -> i32;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ this signature doesn't match the previous declaration
[INFO] [stdout]     |
[INFO] [stdout]     = note: expected `unsafe extern "C" fn(i32, usize, *mut FfEffect) -> i32`
[INFO] [stdout]                found `unsafe extern "C" fn(i32, usize, *mut AbsInfo) -> i32`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 152 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved imports `adi::screen::Event`, `adi::screen::Runner`
[INFO] [stdout]  --> examples/screen_texture.rs:6:24
[INFO] [stdout]   |
[INFO] [stdout] 6 | use adi::screen::{App, Event, Runner};
[INFO] [stdout]   |                        ^^^^^  ^^^^^^ no `Runner` in `screen`
[INFO] [stdout]   |                        |
[INFO] [stdout]   |                        no `Event` in `screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved imports `adi::screen::Event`, `adi::screen::Runner`
[INFO] [stdout]  --> examples/screen_fps.rs:6:24
[INFO] [stdout]   |
[INFO] [stdout] 6 | use adi::screen::{App, Event, Runner};
[INFO] [stdout]   |                        ^^^^^  ^^^^^^ no `Runner` in `screen`
[INFO] [stdout]   |                        |
[INFO] [stdout]   |                        no `Event` in `screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved imports `adi::screen::Event`, `adi::screen::Runner`
[INFO] [stdout]  --> examples/screen_blank.rs:8:24
[INFO] [stdout]   |
[INFO] [stdout] 8 | use adi::screen::{App, Event, Runner};
[INFO] [stdout]   |                        ^^^^^  ^^^^^^ no `Runner` in `screen`
[INFO] [stdout]   |                        |
[INFO] [stdout]   |                        no `Event` in `screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `main` in module `adi::screen`
[INFO] [stdout]   --> examples/screen_blank.rs:19:18
[INFO] [stdout]    |
[INFO] [stdout] 19 |     adi::screen::main(mode)
[INFO] [stdout]    |                  ^^^^ not found in `adi::screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Font` in this scope
[INFO] [stdout]   --> examples/input.rs:18:15
[INFO] [stdout]    |
[INFO] [stdout] 18 |         font: Font<'static>,
[INFO] [stdout]    |               ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find value `FONT` in this scope
[INFO] [stdout]   --> examples/input.rs:31:29
[INFO] [stdout]    |
[INFO] [stdout] 31 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                             ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Font`
[INFO] [stdout]   --> examples/input.rs:31:19
[INFO] [stdout]    |
[INFO] [stdout] 31 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                   ^^^^ use of undeclared type `Font`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved imports `adi::screen::Event`, `adi::screen::Runner`
[INFO] [stdout]  --> examples/screen_circle.rs:6:24
[INFO] [stdout]   |
[INFO] [stdout] 6 | use adi::screen::{App, Event, Runner};
[INFO] [stdout]   |                        ^^^^^  ^^^^^^ no `Runner` in `screen`
[INFO] [stdout]   |                        |
[INFO] [stdout]   |                        no `Event` in `screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0412, E0425, E0433.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0412`.
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `SurfaceInfo` in this scope
[INFO] [stdout]   --> examples/screen_texture.rs:15:18
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub surface: SurfaceInfo,
[INFO] [stdout]    |                  ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Font` in this scope
[INFO] [stdout]   --> examples/screen_texture.rs:17:15
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub font: Font<'static>,
[INFO] [stdout]    |               ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find value `FONT` in this scope
[INFO] [stdout]   --> examples/screen_texture.rs:29:29
[INFO] [stdout]    |
[INFO] [stdout] 29 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                             ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `main` in module `adi::screen`
[INFO] [stdout]   --> examples/screen_texture.rs:97:18
[INFO] [stdout]    |
[INFO] [stdout] 97 |     adi::screen::main(mode)
[INFO] [stdout]    |                  ^^^^ not found in `adi::screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `adi` (example "input") due to 4 previous errors
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_texture.rs:28:22
[INFO] [stdout]    |
[INFO] [stdout] 28 |             surface: SurfaceInfo::new(Size(0, 0), None),
[INFO] [stdout]    |                      ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Font`
[INFO] [stdout]   --> examples/screen_texture.rs:29:19
[INFO] [stdout]    |
[INFO] [stdout] 29 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                   ^^^^ use of undeclared type `Font`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `SurfaceInfo` in this scope
[INFO] [stdout]   --> examples/screen_fps.rs:15:18
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub surface: SurfaceInfo,
[INFO] [stdout]    |                  ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Font` in this scope
[INFO] [stdout]   --> examples/screen_fps.rs:17:15
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub font: Font<'static>,
[INFO] [stdout]    |               ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find value `FONT` in this scope
[INFO] [stdout]   --> examples/screen_fps.rs:26:29
[INFO] [stdout]    |
[INFO] [stdout] 26 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                             ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `main` in module `adi::screen`
[INFO] [stdout]   --> examples/screen_fps.rs:70:18
[INFO] [stdout]    |
[INFO] [stdout] 70 |     adi::screen::main(mode)
[INFO] [stdout]    |                  ^^^^ not found in `adi::screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_fps.rs:25:22
[INFO] [stdout]    |
[INFO] [stdout] 25 |             surface: SurfaceInfo::new(Size(0, 0), None),
[INFO] [stdout]    |                      ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Font`
[INFO] [stdout]   --> examples/screen_fps.rs:26:19
[INFO] [stdout]    |
[INFO] [stdout] 26 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                   ^^^^ use of undeclared type `Font`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `SurfaceInfo` in this scope
[INFO] [stdout]   --> examples/screen_circle.rs:15:18
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub surface: SurfaceInfo,
[INFO] [stdout]    |                  ^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Font` in this scope
[INFO] [stdout]   --> examples/screen_circle.rs:17:15
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub font: Font<'static>,
[INFO] [stdout]    |               ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find value `FONT` in this scope
[INFO] [stdout]   --> examples/screen_circle.rs:29:29
[INFO] [stdout]    |
[INFO] [stdout] 29 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                             ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `main` in module `adi::screen`
[INFO] [stdout]   --> examples/screen_circle.rs:88:18
[INFO] [stdout]    |
[INFO] [stdout] 88 |     adi::screen::main(mode)
[INFO] [stdout]    |                  ^^^^ not found in `adi::screen`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `stop` found for mutable reference `&mut adi::screen::App` in the current scope
[INFO] [stdout]   --> examples/screen_blank.rs:13:28
[INFO] [stdout]    |
[INFO] [stdout] 13 |         Event::Exit => app.stop(),
[INFO] [stdout]    |                            ^^^^ method not found in `&mut App`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_circle.rs:28:22
[INFO] [stdout]    |
[INFO] [stdout] 28 |             surface: SurfaceInfo::new(Size(0, 0), None),
[INFO] [stdout]    |                      ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Font`
[INFO] [stdout]   --> examples/screen_circle.rs:29:19
[INFO] [stdout]    |
[INFO] [stdout] 29 |             font: Font::new(FONT).expect("Failed to load font!"),
[INFO] [stdout]    |                   ^^^^ use of undeclared type `Font`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 3 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0425, E0432, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0425`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `adi` (example "screen_blank") due to 4 previous errors
[INFO] [stdout] error[E0599]: no method named `stop` found for mutable reference `&mut adi::screen::App` in the current scope
[INFO] [stdout]   --> examples/screen_texture.rs:38:28
[INFO] [stdout]    |
[INFO] [stdout] 38 |         Event::Exit => app.stop(),
[INFO] [stdout]    |                            ^^^^ method not found in `&mut App`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_texture.rs:43:31
[INFO] [stdout]    |
[INFO] [stdout] 43 |                 ctx.surface = SurfaceInfo::new(Size(w, h), Some(app.pitch()));
[INFO] [stdout]    |                               ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `LinkSurface`
[INFO] [stdout]   --> examples/screen_texture.rs:62:35
[INFO] [stdout]    |
[INFO] [stdout] 62 |                 let mut surface = LinkSurface::new(&mut ctx.surface, pixel_buffer);
[INFO] [stdout]    |                                   ^^^^^^^^^^^ use of undeclared type `LinkSurface`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_texture.rs:77:25
[INFO] [stdout]    |
[INFO] [stdout] 77 |                         Move(0.75, 0.75, 0.0),
[INFO] [stdout]    |                         ^^^^           -----
[INFO] [stdout]    |                                        | |
[INFO] [stdout]    |                                        | unexpected argument of type `{float}`
[INFO] [stdout]    |                                        help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     Move(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_texture.rs:78:25
[INFO] [stdout]    |
[INFO] [stdout] 78 |                         Line(0.25, 0.75, 0.0),
[INFO] [stdout]    |                         ^^^^           -----
[INFO] [stdout]    |                                        | |
[INFO] [stdout]    |                                        | unexpected argument of type `{float}`
[INFO] [stdout]    |                                        help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     Line(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_texture.rs:79:25
[INFO] [stdout]    |
[INFO] [stdout] 79 |                         Line(0.25, 0.25, 0.0),
[INFO] [stdout]    |                         ^^^^           -----
[INFO] [stdout]    |                                        | |
[INFO] [stdout]    |                                        | unexpected argument of type `{float}`
[INFO] [stdout]    |                                        help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     Line(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_texture.rs:80:25
[INFO] [stdout]    |
[INFO] [stdout] 80 |                         Line(0.75, 0.25, 0.0),
[INFO] [stdout]    |                         ^^^^           -----
[INFO] [stdout]    |                                        | |
[INFO] [stdout]    |                                        | unexpected argument of type `{float}`
[INFO] [stdout]    |                                        help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     Line(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_texture.rs:81:25
[INFO] [stdout]    |
[INFO] [stdout] 81 |                         Line(0.75, 0.75, 0.0),
[INFO] [stdout]    |                         ^^^^           -----
[INFO] [stdout]    |                                        | |
[INFO] [stdout]    |                                        | unexpected argument of type `{float}`
[INFO] [stdout]    |                                        help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     Line(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 15 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0061, E0412, E0425, E0432, E0433, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0061`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `adi` (example "screen_texture") due to 16 previous errors
[INFO] [stdout] error[E0599]: no method named `stop` found for mutable reference `&mut adi::screen::App` in the current scope
[INFO] [stdout]   --> examples/screen_fps.rs:34:28
[INFO] [stdout]    |
[INFO] [stdout] 34 |         Event::Exit => app.stop(),
[INFO] [stdout]    |                            ^^^^ method not found in `&mut App`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_fps.rs:41:35
[INFO] [stdout]    |
[INFO] [stdout] 41 |                     ctx.surface = SurfaceInfo::new(Size(w, h), Some(app.pitch()));
[INFO] [stdout]    |                                   ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `LinkSurface`
[INFO] [stdout]   --> examples/screen_fps.rs:52:39
[INFO] [stdout]    |
[INFO] [stdout] 52 |                     let mut surface = LinkSurface::new(&mut ctx.surface, pixel_buffer);
[INFO] [stdout]    |                                       ^^^^^^^^^^^ use of undeclared type `LinkSurface`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 10 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0412, E0425, E0432, E0433, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0412`.
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: no method named `stop` found for mutable reference `&mut adi::screen::App` in the current scope
[INFO] [stdout]   --> examples/screen_circle.rs:38:28
[INFO] [stdout]    |
[INFO] [stdout] 38 |         Event::Exit => app.stop(),
[INFO] [stdout]    |                            ^^^^ method not found in `&mut App`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `SurfaceInfo`
[INFO] [stdout]   --> examples/screen_circle.rs:43:31
[INFO] [stdout]    |
[INFO] [stdout] 43 |                 ctx.surface = SurfaceInfo::new(Size(w, h), Some(app.pitch()));
[INFO] [stdout]    |                               ^^^^^^^^^^^ use of undeclared type `SurfaceInfo`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `LinkSurface`
[INFO] [stdout]   --> examples/screen_circle.rs:62:35
[INFO] [stdout]    |
[INFO] [stdout] 62 |                 let mut surface = LinkSurface::new(&mut ctx.surface, pixel_buffer);
[INFO] [stdout]    |                                   ^^^^^^^^^^^ use of undeclared type `LinkSurface`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 2 arguments but 3 arguments were supplied
[INFO] [stdout]   --> examples/screen_circle.rs:68:25
[INFO] [stdout]    |
[INFO] [stdout] 68 |                         Move(0.25, 0.5, 0.0),
[INFO] [stdout]    |                         ^^^^          -----
[INFO] [stdout]    |                                       | |
[INFO] [stdout]    |                                       | unexpected argument of type `{float}`
[INFO] [stdout]    |                                       help: remove the extra argument
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     Move(f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 4 arguments but 6 arguments were supplied
[INFO] [stdout]   --> examples/screen_circle.rs:69:25
[INFO] [stdout]    |
[INFO] [stdout] 69 |                         Quad(0.25, 0.75, 0.0, 0.5, 0.75, 0.0),
[INFO] [stdout]    |                         ^^^^                       ----  --- unexpected argument of type `{float}`
[INFO] [stdout]    |                                                    |
[INFO] [stdout]    |                                                    unexpected argument of type `{float}`
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Quad(f32, f32, f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] help: remove the extra arguments
[INFO] [stdout]    |
[INFO] [stdout] 69 -                         Quad(0.25, 0.75, 0.0, 0.5, 0.75, 0.0),
[INFO] [stdout] 69 +                         Quad(0.25, 0.75, 0.0, 0.5),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 4 arguments but 6 arguments were supplied
[INFO] [stdout]   --> examples/screen_circle.rs:70:25
[INFO] [stdout]    |
[INFO] [stdout] 70 |                         Quad(0.75, 0.75, 0.0, 0.75, 0.5, 0.0),
[INFO] [stdout]    |                         ^^^^                        ---  --- unexpected argument of type `{float}`
[INFO] [stdout]    |                                                     |
[INFO] [stdout]    |                                                     unexpected argument of type `{float}`
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Quad(f32, f32, f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] help: remove the extra arguments
[INFO] [stdout]    |
[INFO] [stdout] 70 -                         Quad(0.75, 0.75, 0.0, 0.75, 0.5, 0.0),
[INFO] [stdout] 70 +                         Quad(0.75, 0.75, 0.0, 0.75),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 4 arguments but 6 arguments were supplied
[INFO] [stdout]   --> examples/screen_circle.rs:71:25
[INFO] [stdout]    |
[INFO] [stdout] 71 |                         Quad(0.75, 0.25, 0.0, 0.5, 0.25, 0.0),
[INFO] [stdout]    |                         ^^^^                       ----  --- unexpected argument of type `{float}`
[INFO] [stdout]    |                                                    |
[INFO] [stdout]    |                                                    unexpected argument of type `{float}`
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Quad(f32, f32, f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] help: remove the extra arguments
[INFO] [stdout]    |
[INFO] [stdout] 71 -                         Quad(0.75, 0.25, 0.0, 0.5, 0.25, 0.0),
[INFO] [stdout] 71 +                         Quad(0.75, 0.25, 0.0, 0.5),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0061]: this enum variant takes 4 arguments but 6 arguments were supplied
[INFO] [stdout]   --> examples/screen_circle.rs:72:25
[INFO] [stdout]    |
[INFO] [stdout] 72 |                         Quad(0.25, 0.25, 0.0, 0.25, 0.5, 0.0),
[INFO] [stdout]    |                         ^^^^                        ---  --- unexpected argument of type `{float}`
[INFO] [stdout]    |                                                     |
[INFO] [stdout]    |                                                     unexpected argument of type `{float}`
[INFO] [stdout]    |
[INFO] [stdout] note: tuple variant defined here
[INFO] [stdout]   --> /opt/rustwide/cargo-home/registry/src/index.crates.io-6f17d22bba15001f/footile-0.2.0/src/path.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     Quad(f32, f32, f32, f32),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] help: remove the extra arguments
[INFO] [stdout]    |
[INFO] [stdout] 72 -                         Quad(0.25, 0.25, 0.0, 0.25, 0.5, 0.0),
[INFO] [stdout] 72 +                         Quad(0.25, 0.25, 0.0, 0.25),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `adi` (example "screen_fps") due to 11 previous errors
[INFO] [stdout] error: aborting due to 15 previous errors
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0061, E0412, E0425, E0432, E0433, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0061`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `adi` (example "screen_circle") due to 16 previous errors
[INFO] running `Command { std: "docker" "inspect" "a96e63188e0acb8b8d15b13ee9e25924cf16eb5dca0fe478bee89003d6200294", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a96e63188e0acb8b8d15b13ee9e25924cf16eb5dca0fe478bee89003d6200294", kill_on_drop: false }`
[INFO] [stdout] a96e63188e0acb8b8d15b13ee9e25924cf16eb5dca0fe478bee89003d6200294
