[INFO] cloning repository https://github.com/PeterJFB/opengl-rs-project [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/PeterJFB/opengl-rs-project" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FPeterJFB%2Fopengl-rs-project", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FPeterJFB%2Fopengl-rs-project'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 09058c14ef5993eec33a1ceed576a923abc44a33 [INFO] testing PeterJFB/opengl-rs-project against master#ad85bc524b1ad696e42061ad8338d382dffbdbe5 for pr-146237 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FPeterJFB%2Fopengl-rs-project" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/PeterJFB/opengl-rs-project [INFO] finished tweaking git repo https://github.com/PeterJFB/opengl-rs-project [INFO] tweaked toml for git repo https://github.com/PeterJFB/opengl-rs-project written to /workspace/builds/worker-3-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/PeterJFB/opengl-rs-project on toolchain ad85bc524b1ad696e42061ad8338d382dffbdbe5 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/PeterJFB/opengl-rs-project already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded wasm-bindgen-shared v0.2.82 [INFO] [stderr] Downloaded tobj v3.1.0 [INFO] [stderr] Downloaded wasm-bindgen-macro v0.2.82 [INFO] [stderr] Downloaded wayland-cursor v0.29.4 [INFO] [stderr] Downloaded futures-sink v0.3.23 [INFO] [stderr] Downloaded wayland-egl v0.29.4 [INFO] [stderr] Downloaded futures-core v0.3.23 [INFO] [stderr] Downloaded num_enum_derive v0.5.4 [INFO] [stderr] Downloaded num_enum v0.5.4 [INFO] [stderr] Downloaded crossfont v0.5.0 [INFO] [stderr] Downloaded calloop v0.10.1 [INFO] [stderr] Downloaded wayland-client v0.29.4 [INFO] [stderr] Downloaded wide v0.7.0 [INFO] [stderr] Downloaded ahash v0.7.4 [INFO] [stderr] Downloaded nom v6.2.1 [INFO] [stderr] Downloaded wayland-protocols v0.29.4 [INFO] [stderr] Downloaded wasm-bindgen v0.2.82 [INFO] [stderr] Downloaded matrixmultiply v0.3.1 [INFO] [stderr] Downloaded simba v0.7.2 [INFO] [stderr] Downloaded nalgebra-glm v0.17.0 [INFO] [stderr] Downloaded js-sys v0.3.59 [INFO] [stderr] Downloaded image v0.24.3 [INFO] [stderr] Downloaded nix v0.24.2 [INFO] [stderr] Downloaded wayland-scanner v0.29.4 [INFO] [stderr] Downloaded ndk-sys v0.4.0 [INFO] [stderr] Downloaded num-complex v0.4.0 [INFO] [stderr] Downloaded winit v0.27.2 [INFO] [stderr] Downloaded wasm-bindgen-backend v0.2.82 [INFO] [stderr] Downloaded approx v0.5.0 [INFO] [stderr] Downloaded nalgebra v0.31.1 [INFO] [stderr] Downloaded paste v1.0.5 [INFO] [stderr] Downloaded sctk-adwaita v0.4.2 [INFO] [stderr] Downloaded memmap2 v0.5.7 [INFO] [stderr] Downloaded wayland-commons v0.29.4 [INFO] [stderr] Downloaded proc-macro-crate v1.0.0 [INFO] [stderr] Downloaded cmake v0.1.48 [INFO] [stderr] Downloaded wayland-sys v0.29.4 [INFO] [stderr] Downloaded wasm-bindgen-macro-support v0.2.82 [INFO] [stderr] Downloaded web-sys v0.3.59 [INFO] [stderr] Downloaded tiff v0.7.3 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 5d2ba400b86b3997070574233616ca61b4798f1051e71c52b67dded680957397 [INFO] running `Command { std: "docker" "start" "-a" "5d2ba400b86b3997070574233616ca61b4798f1051e71c52b67dded680957397", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "5d2ba400b86b3997070574233616ca61b4798f1051e71c52b67dded680957397", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5d2ba400b86b3997070574233616ca61b4798f1051e71c52b67dded680957397", kill_on_drop: false }` [INFO] [stdout] 5d2ba400b86b3997070574233616ca61b4798f1051e71c52b67dded680957397 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] dc181a81af8f25a3b8ae30e39bdfef62e2c2638ffc1210ad8b60b243278af97d [INFO] running `Command { std: "docker" "start" "-a" "dc181a81af8f25a3b8ae30e39bdfef62e2c2638ffc1210ad8b60b243278af97d", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.132 [INFO] [stderr] Compiling pkg-config v0.3.19 [INFO] [stderr] Compiling proc-macro2 v1.0.28 [INFO] [stderr] Compiling xml-rs v0.8.4 [INFO] [stderr] Compiling memoffset v0.6.4 [INFO] [stderr] Compiling log v0.4.14 [INFO] [stderr] Compiling syn v1.0.74 [INFO] [stderr] Compiling cc v1.0.73 [INFO] [stderr] Compiling khronos_api v3.1.0 [INFO] [stderr] Compiling bytemuck v1.7.2 [INFO] [stderr] Compiling libloading v0.7.0 [INFO] [stderr] Compiling once_cell v1.13.1 [INFO] [stderr] Compiling num-traits v0.2.14 [INFO] [stderr] Compiling memchr v2.3.4 [INFO] [stderr] Compiling miniz_oxide v0.5.3 [INFO] [stderr] Compiling nom v6.2.1 [INFO] [stderr] Compiling dlib v0.5.0 [INFO] [stderr] Compiling downcast-rs v1.2.0 [INFO] [stderr] Compiling deflate v1.0.0 [INFO] [stderr] Compiling slotmap v1.0.6 [INFO] [stderr] Compiling num-integer v0.1.44 [INFO] [stderr] Compiling maybe-uninit v2.0.0 [INFO] [stderr] Compiling rayon v1.5.1 [INFO] [stderr] Compiling crossbeam-epoch v0.9.5 [INFO] [stderr] Compiling num-rational v0.4.0 [INFO] [stderr] Compiling arrayref v0.3.6 [INFO] [stderr] Compiling futures-core v0.3.23 [INFO] [stderr] Compiling cmake v0.1.48 [INFO] [stderr] Compiling foreign-types-shared v0.3.1 [INFO] [stderr] Compiling wayland-sys v0.29.4 [INFO] [stderr] Compiling gl_generator v0.14.0 [INFO] [stderr] Compiling servo-fontconfig-sys v5.1.0 [INFO] [stderr] Compiling x11-dl v2.18.5 [INFO] [stderr] Compiling crossbeam-deque v0.8.1 [INFO] [stderr] Compiling smithay-client-toolkit v0.16.0 [INFO] [stderr] Compiling quote v1.0.9 [INFO] [stderr] Compiling crossfont v0.5.0 [INFO] [stderr] Compiling png v0.17.5 [INFO] [stderr] Compiling wayland-scanner v0.29.4 [INFO] [stderr] Compiling tiny-skia-path v0.7.0 [INFO] [stderr] Compiling safe_arch v0.5.2 [INFO] [stderr] Compiling safe_arch v0.6.0 [INFO] [stderr] Compiling cty v0.2.2 [INFO] [stderr] Compiling arrayvec v0.5.2 [INFO] [stderr] Compiling num-complex v0.4.0 [INFO] [stderr] Compiling freetype-sys v0.13.1 [INFO] [stderr] Compiling expat-sys v2.1.6 [INFO] [stderr] Compiling getrandom v0.2.7 [INFO] [stderr] Compiling nix v0.22.3 [INFO] [stderr] Compiling num_cpus v1.13.0 [INFO] [stderr] Compiling nix v0.24.2 [INFO] [stderr] Compiling memmap2 v0.5.7 [INFO] [stderr] Compiling freetype-rs v0.26.0 [INFO] [stderr] Compiling nanorand v0.7.0 [INFO] [stderr] Compiling glutin_egl_sys v0.1.6 [INFO] [stderr] Compiling servo-fontconfig v0.5.1 [INFO] [stderr] Compiling glutin_glx_sys v0.1.8 [INFO] [stderr] Compiling wayland-client v0.29.4 [INFO] [stderr] Compiling wayland-protocols v0.29.4 [INFO] [stderr] Compiling rayon-core v1.9.1 [INFO] [stderr] Compiling tiny-skia v0.7.0 [INFO] [stderr] Compiling parking_lot_core v0.9.3 [INFO] [stderr] Compiling wide v0.7.0 [INFO] [stderr] Compiling approx v0.5.0 [INFO] [stderr] Compiling spin v0.9.4 [INFO] [stderr] Compiling ahash v0.7.4 [INFO] [stderr] Compiling paste v1.0.5 [INFO] [stderr] Compiling futures-sink v0.3.23 [INFO] [stderr] Compiling matrixmultiply v0.3.1 [INFO] [stderr] Compiling parking_lot v0.12.1 [INFO] [stderr] Compiling xcursor v0.3.3 [INFO] [stderr] Compiling threadpool v1.8.1 [INFO] [stderr] Compiling gl v0.14.0 [INFO] [stderr] Compiling rand_core v0.6.3 [INFO] [stderr] Compiling mio v0.8.4 [INFO] [stderr] Compiling shared_library v0.1.9 [INFO] [stderr] Compiling raw-window-handle v0.5.0 [INFO] [stderr] Compiling raw-window-handle v0.4.3 [INFO] [stderr] Compiling flate2 v1.0.24 [INFO] [stderr] Compiling inflate v0.4.5 [INFO] [stderr] Compiling instant v0.1.10 [INFO] [stderr] Compiling bit_field v0.10.1 [INFO] [stderr] Compiling lebe v0.5.2 [INFO] [stderr] Compiling half v1.8.2 [INFO] [stderr] Compiling rand_chacha v0.3.1 [INFO] [stderr] Compiling osmesa-sys v0.1.2 [INFO] [stderr] Compiling rand v0.8.4 [INFO] [stderr] Compiling tobj v3.1.0 [INFO] [stderr] Compiling wayland-commons v0.29.4 [INFO] [stderr] Compiling simba v0.7.2 [INFO] [stderr] Compiling jpeg-decoder v0.2.6 [INFO] [stderr] Compiling thiserror-impl v1.0.26 [INFO] [stderr] Compiling foreign-types-macros v0.2.2 [INFO] [stderr] Compiling pin-project-internal v1.0.12 [INFO] [stderr] Compiling foreign-types v0.5.0 [INFO] [stderr] Compiling tiff v0.7.3 [INFO] [stderr] Compiling wayland-cursor v0.29.4 [INFO] [stderr] Compiling wayland-egl v0.29.4 [INFO] [stderr] Compiling pin-project v1.0.12 [INFO] [stderr] Compiling flume v0.10.14 [INFO] [stderr] Compiling exr v1.4.2 [INFO] [stderr] Compiling thiserror v1.0.26 [INFO] [stderr] Compiling calloop v0.10.1 [INFO] [stderr] Compiling image v0.24.3 [INFO] [stderr] Compiling nalgebra v0.31.1 [INFO] [stderr] Compiling nalgebra-glm v0.17.0 [INFO] [stderr] Compiling sctk-adwaita v0.4.2 [INFO] [stderr] Compiling winit v0.27.2 [INFO] [stderr] Compiling glutin v0.29.1 [INFO] [stderr] Compiling gloom-rs v0.3.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `glm::pi` [INFO] [stdout] --> src/main.rs:25:5 [INFO] [stdout] | [INFO] [stdout] 25 | use glm::pi; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `obj_reader::ObjReader` [INFO] [stdout] --> src/main.rs:34:5 [INFO] [stdout] | [INFO] [stdout] 34 | use obj_reader::ObjReader; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::Rng` [INFO] [stdout] --> src/main.rs:35:5 [INFO] [stdout] | [INFO] [stdout] 35 | use rand::Rng; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `shape_generator::ShapeGenerator` [INFO] [stdout] --> src/main.rs:37:5 [INFO] [stdout] | [INFO] [stdout] 37 | use shape_generator::ShapeGenerator; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `door` is never read [INFO] [stdout] --> src/main.rs:79:5 [INFO] [stdout] | [INFO] [stdout] 77 | struct HelicopterNode { [INFO] [stdout] | -------------- field in this struct [INFO] [stdout] 78 | body: ManuallyDrop>>, [INFO] [stdout] 79 | door: ManuallyDrop>>, [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `index_count` is never read [INFO] [stdout] --> src/mesh.rs:15:9 [INFO] [stdout] | [INFO] [stdout] 10 | pub struct Mesh { [INFO] [stdout] | ---- field in this struct [INFO] [stdout] ... [INFO] [stdout] 15 | pub index_count : i32, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ObjReader` is never constructed [INFO] [stdout] --> src/obj_reader.rs:3:12 [INFO] [stdout] | [INFO] [stdout] 3 | pub struct ObjReader {} [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `ObjEntry` is never used [INFO] [stdout] --> src/obj_reader.rs:5:10 [INFO] [stdout] | [INFO] [stdout] 5 | pub enum ObjEntry { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `from_code` is never used [INFO] [stdout] --> src/obj_reader.rs:12:8 [INFO] [stdout] | [INFO] [stdout] 11 | impl ObjEntry { [INFO] [stdout] | ------------- associated function in this implementation [INFO] [stdout] 12 | fn from_code(code: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated functions `read` and `parse_obj_src` are never used [INFO] [stdout] --> src/obj_reader.rs:23:12 [INFO] [stdout] | [INFO] [stdout] 22 | impl ObjReader { [INFO] [stdout] | -------------- associated functions in this implementation [INFO] [stdout] 23 | pub fn read(obj_path: &str) -> (Vec, Vec) { [INFO] [stdout] | ^^^^ [INFO] [stdout] ... [INFO] [stdout] 50 | pub fn parse_obj_src(obj_src: &str) -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `scale` is never read [INFO] [stdout] --> src/scene_graph.rs:22:9 [INFO] [stdout] | [INFO] [stdout] 19 | pub struct SceneNode { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 22 | pub scale : glm::Vec3, // How I should be scaled [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ShapeGenerator` is never constructed [INFO] [stdout] --> src/shape_generator.rs:5:12 [INFO] [stdout] | [INFO] [stdout] 5 | pub struct ShapeGenerator {} [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated functions are never used [INFO] [stdout] --> src/shape_generator.rs:8:12 [INFO] [stdout] | [INFO] [stdout] 7 | impl ShapeGenerator { [INFO] [stdout] | ------------------- associated functions in this implementation [INFO] [stdout] 8 | pub fn generate_n_force( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 54 | pub fn generate_circle(n_perimeter_verticies: usize, rad: f32) -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 80 | pub fn generate_spiral( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 123 | pub fn generate_square(side_length: f32) -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 147 | pub fn generate_sine(n_points: usize, width: f32, angle_rate: f32) -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 197 | pub fn overlapping_triangles(width: f32, height: f32, overlap: f32) -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 244 | pub fn flat_thing() -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static variable `uniform_time_location` should have an upper case name [INFO] [stdout] --> src/main.rs:84:12 [INFO] [stdout] | [INFO] [stdout] 84 | static mut uniform_time_location: i32 = 0; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stdout] help: convert the identifier to upper case [INFO] [stdout] | [INFO] [stdout] 84 - static mut uniform_time_location: i32 = 0; [INFO] [stdout] 84 + static mut UNIFORM_TIME_LOCATION: i32 = 0; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static variable `uniform_matrix_location` should have an upper case name [INFO] [stdout] --> src/main.rs:85:12 [INFO] [stdout] | [INFO] [stdout] 85 | static mut uniform_matrix_location: i32 = 0; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] help: convert the identifier to upper case [INFO] [stdout] | [INFO] [stdout] 85 - static mut uniform_matrix_location: i32 = 0; [INFO] [stdout] 85 + static mut UNIFORM_MATRIX_LOCATION: i32 = 0; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static variable `uniform_normal_matrix_location` should have an upper case name [INFO] [stdout] --> src/main.rs:86:12 [INFO] [stdout] | [INFO] [stdout] 86 | static mut uniform_normal_matrix_location: i32 = 0; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] help: convert the identifier to upper case [INFO] [stdout] | [INFO] [stdout] 86 - static mut uniform_normal_matrix_location: i32 = 0; [INFO] [stdout] 86 + static mut UNIFORM_NORMAL_MATRIX_LOCATION: i32 = 0; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 18s [INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: nom v6.2.1 [INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2` [INFO] running `Command { std: "docker" "inspect" "dc181a81af8f25a3b8ae30e39bdfef62e2c2638ffc1210ad8b60b243278af97d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "dc181a81af8f25a3b8ae30e39bdfef62e2c2638ffc1210ad8b60b243278af97d", kill_on_drop: false }` [INFO] [stdout] dc181a81af8f25a3b8ae30e39bdfef62e2c2638ffc1210ad8b60b243278af97d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 7762b1194b3829e1ab2a30db020d48a81cd372c0866cca5f051901a8a2dd9bad [INFO] running `Command { std: "docker" "start" "-a" "7762b1194b3829e1ab2a30db020d48a81cd372c0866cca5f051901a8a2dd9bad", kill_on_drop: false }` [INFO] [stderr] Compiling gloom-rs v0.3.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `glm::pi` [INFO] [stdout] --> src/main.rs:25:5 [INFO] [stdout] | [INFO] [stdout] 25 | use glm::pi; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `obj_reader::ObjReader` [INFO] [stdout] --> src/main.rs:34:5 [INFO] [stdout] | [INFO] [stdout] 34 | use obj_reader::ObjReader; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `rand::Rng` [INFO] [stdout] --> src/main.rs:35:5 [INFO] [stdout] | [INFO] [stdout] 35 | use rand::Rng; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `shape_generator::ShapeGenerator` [INFO] [stdout] --> src/main.rs:37:5 [INFO] [stdout] | [INFO] [stdout] 37 | use shape_generator::ShapeGenerator; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `door` is never read [INFO] [stdout] --> src/main.rs:79:5 [INFO] [stdout] | [INFO] [stdout] 77 | struct HelicopterNode { [INFO] [stdout] | -------------- field in this struct [INFO] [stdout] 78 | body: ManuallyDrop>>, [INFO] [stdout] 79 | door: ManuallyDrop>>, [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `index_count` is never read [INFO] [stdout] --> src/mesh.rs:15:9 [INFO] [stdout] | [INFO] [stdout] 10 | pub struct Mesh { [INFO] [stdout] | ---- field in this struct [INFO] [stdout] ... [INFO] [stdout] 15 | pub index_count : i32, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ObjReader` is never constructed [INFO] [stdout] --> src/obj_reader.rs:3:12 [INFO] [stdout] | [INFO] [stdout] 3 | pub struct ObjReader {} [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `ObjEntry` is never used [INFO] [stdout] --> src/obj_reader.rs:5:10 [INFO] [stdout] | [INFO] [stdout] 5 | pub enum ObjEntry { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `from_code` is never used [INFO] [stdout] --> src/obj_reader.rs:12:8 [INFO] [stdout] | [INFO] [stdout] 11 | impl ObjEntry { [INFO] [stdout] | ------------- associated function in this implementation [INFO] [stdout] 12 | fn from_code(code: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated functions `read` and `parse_obj_src` are never used [INFO] [stdout] --> src/obj_reader.rs:23:12 [INFO] [stdout] | [INFO] [stdout] 22 | impl ObjReader { [INFO] [stdout] | -------------- associated functions in this implementation [INFO] [stdout] 23 | pub fn read(obj_path: &str) -> (Vec, Vec) { [INFO] [stdout] | ^^^^ [INFO] [stdout] ... [INFO] [stdout] 50 | pub fn parse_obj_src(obj_src: &str) -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `scale` is never read [INFO] [stdout] --> src/scene_graph.rs:22:9 [INFO] [stdout] | [INFO] [stdout] 19 | pub struct SceneNode { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 22 | pub scale : glm::Vec3, // How I should be scaled [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ShapeGenerator` is never constructed [INFO] [stdout] --> src/shape_generator.rs:5:12 [INFO] [stdout] | [INFO] [stdout] 5 | pub struct ShapeGenerator {} [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated functions are never used [INFO] [stdout] --> src/shape_generator.rs:8:12 [INFO] [stdout] | [INFO] [stdout] 7 | impl ShapeGenerator { [INFO] [stdout] | ------------------- associated functions in this implementation [INFO] [stdout] 8 | pub fn generate_n_force( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 54 | pub fn generate_circle(n_perimeter_verticies: usize, rad: f32) -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 80 | pub fn generate_spiral( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 123 | pub fn generate_square(side_length: f32) -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 147 | pub fn generate_sine(n_points: usize, width: f32, angle_rate: f32) -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 197 | pub fn overlapping_triangles(width: f32, height: f32, overlap: f32) -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 244 | pub fn flat_thing() -> (Vec, Vec) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static variable `uniform_time_location` should have an upper case name [INFO] [stdout] --> src/main.rs:84:12 [INFO] [stdout] | [INFO] [stdout] 84 | static mut uniform_time_location: i32 = 0; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stdout] help: convert the identifier to upper case [INFO] [stdout] | [INFO] [stdout] 84 - static mut uniform_time_location: i32 = 0; [INFO] [stdout] 84 + static mut UNIFORM_TIME_LOCATION: i32 = 0; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static variable `uniform_matrix_location` should have an upper case name [INFO] [stdout] --> src/main.rs:85:12 [INFO] [stdout] | [INFO] [stdout] 85 | static mut uniform_matrix_location: i32 = 0; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] help: convert the identifier to upper case [INFO] [stdout] | [INFO] [stdout] 85 - static mut uniform_matrix_location: i32 = 0; [INFO] [stdout] 85 + static mut UNIFORM_MATRIX_LOCATION: i32 = 0; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static variable `uniform_normal_matrix_location` should have an upper case name [INFO] [stdout] --> src/main.rs:86:12 [INFO] [stdout] | [INFO] [stdout] 86 | static mut uniform_normal_matrix_location: i32 = 0; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] help: convert the identifier to upper case [INFO] [stdout] | [INFO] [stdout] 86 - static mut uniform_normal_matrix_location: i32 = 0; [INFO] [stdout] 86 + static mut UNIFORM_NORMAL_MATRIX_LOCATION: i32 = 0; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.92s [INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: nom v6.2.1 [INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2` [INFO] running `Command { std: "docker" "inspect" "7762b1194b3829e1ab2a30db020d48a81cd372c0866cca5f051901a8a2dd9bad", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7762b1194b3829e1ab2a30db020d48a81cd372c0866cca5f051901a8a2dd9bad", kill_on_drop: false }` [INFO] [stdout] 7762b1194b3829e1ab2a30db020d48a81cd372c0866cca5f051901a8a2dd9bad [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 60628e25d3b270adcc7bf125ef59c72c4735050772a40b4819aad4154282884b [INFO] running `Command { std: "docker" "start" "-a" "60628e25d3b270adcc7bf125ef59c72c4735050772a40b4819aad4154282884b", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `glm::pi` [INFO] [stderr] --> src/main.rs:25:5 [INFO] [stderr] | [INFO] [stderr] 25 | use glm::pi; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `obj_reader::ObjReader` [INFO] [stderr] --> src/main.rs:34:5 [INFO] [stderr] | [INFO] [stderr] 34 | use obj_reader::ObjReader; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `rand::Rng` [INFO] [stderr] --> src/main.rs:35:5 [INFO] [stderr] | [INFO] [stderr] 35 | use rand::Rng; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `shape_generator::ShapeGenerator` [INFO] [stderr] --> src/main.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | use shape_generator::ShapeGenerator; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `door` is never read [INFO] [stderr] --> src/main.rs:79:5 [INFO] [stderr] | [INFO] [stderr] 77 | struct HelicopterNode { [INFO] [stderr] | -------------- field in this struct [INFO] [stderr] 78 | body: ManuallyDrop>>, [INFO] [stderr] 79 | door: ManuallyDrop>>, [INFO] [stderr] | ^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: field `index_count` is never read [INFO] [stderr] --> src/mesh.rs:15:9 [INFO] [stderr] | [INFO] [stderr] 10 | pub struct Mesh { [INFO] [stderr] | ---- field in this struct [INFO] [stderr] ... [INFO] [stderr] 15 | pub index_count : i32, [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `ObjReader` is never constructed [INFO] [stderr] --> src/obj_reader.rs:3:12 [INFO] [stderr] | [INFO] [stderr] 3 | pub struct ObjReader {} [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum `ObjEntry` is never used [INFO] [stderr] --> src/obj_reader.rs:5:10 [INFO] [stderr] | [INFO] [stderr] 5 | pub enum ObjEntry { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function `from_code` is never used [INFO] [stderr] --> src/obj_reader.rs:12:8 [INFO] [stderr] | [INFO] [stderr] 11 | impl ObjEntry { [INFO] [stderr] | ------------- associated function in this implementation [INFO] [stderr] 12 | fn from_code(code: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated functions `read` and `parse_obj_src` are never used [INFO] [stderr] --> src/obj_reader.rs:23:12 [INFO] [stderr] | [INFO] [stderr] 22 | impl ObjReader { [INFO] [stderr] | -------------- associated functions in this implementation [INFO] [stderr] 23 | pub fn read(obj_path: &str) -> (Vec, Vec) { [INFO] [stderr] | ^^^^ [INFO] [stderr] ... [INFO] [stderr] 50 | pub fn parse_obj_src(obj_src: &str) -> (Vec, Vec) { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field `scale` is never read [INFO] [stderr] --> src/scene_graph.rs:22:9 [INFO] [stderr] | [INFO] [stderr] 19 | pub struct SceneNode { [INFO] [stderr] | --------- field in this struct [INFO] [stderr] ... [INFO] [stderr] 22 | pub scale : glm::Vec3, // How I should be scaled [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `ShapeGenerator` is never constructed [INFO] [stderr] --> src/shape_generator.rs:5:12 [INFO] [stderr] | [INFO] [stderr] 5 | pub struct ShapeGenerator {} [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: multiple associated functions are never used [INFO] [stderr] --> src/shape_generator.rs:8:12 [INFO] [stderr] | [INFO] [stderr] 7 | impl ShapeGenerator { [INFO] [stderr] | ------------------- associated functions in this implementation [INFO] [stderr] 8 | pub fn generate_n_force( [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 54 | pub fn generate_circle(n_perimeter_verticies: usize, rad: f32) -> (Vec, Vec) { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 80 | pub fn generate_spiral( [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 123 | pub fn generate_square(side_length: f32) -> (Vec, Vec) { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 147 | pub fn generate_sine(n_points: usize, width: f32, angle_rate: f32) -> (Vec, Vec) { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 197 | pub fn overlapping_triangles(width: f32, height: f32, overlap: f32) -> (Vec, Vec) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 244 | pub fn flat_thing() -> (Vec, Vec) { [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: static variable `uniform_time_location` should have an upper case name [INFO] [stderr] --> src/main.rs:84:12 [INFO] [stderr] | [INFO] [stderr] 84 | static mut uniform_time_location: i32 = 0; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default [INFO] [stderr] help: convert the identifier to upper case [INFO] [stderr] | [INFO] [stderr] 84 - static mut uniform_time_location: i32 = 0; [INFO] [stderr] 84 + static mut UNIFORM_TIME_LOCATION: i32 = 0; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: static variable `uniform_matrix_location` should have an upper case name [INFO] [stderr] --> src/main.rs:85:12 [INFO] [stderr] | [INFO] [stderr] 85 | static mut uniform_matrix_location: i32 = 0; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] help: convert the identifier to upper case [INFO] [stderr] | [INFO] [stderr] 85 - static mut uniform_matrix_location: i32 = 0; [INFO] [stderr] 85 + static mut UNIFORM_MATRIX_LOCATION: i32 = 0; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: static variable `uniform_normal_matrix_location` should have an upper case name [INFO] [stderr] --> src/main.rs:86:12 [INFO] [stderr] | [INFO] [stderr] 86 | static mut uniform_normal_matrix_location: i32 = 0; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] help: convert the identifier to upper case [INFO] [stderr] | [INFO] [stderr] 86 - static mut uniform_normal_matrix_location: i32 = 0; [INFO] [stderr] 86 + static mut UNIFORM_NORMAL_MATRIX_LOCATION: i32 = 0; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: `gloom-rs` (bin "gloom-rs" test) generated 16 warnings (run `cargo fix --bin "gloom-rs" --tests` to apply 7 suggestions) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.21s [INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: nom v6.2.1 [INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2` [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/gloom_rs-29898b685078ff56) [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "60628e25d3b270adcc7bf125ef59c72c4735050772a40b4819aad4154282884b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "60628e25d3b270adcc7bf125ef59c72c4735050772a40b4819aad4154282884b", kill_on_drop: false }` [INFO] [stdout] 60628e25d3b270adcc7bf125ef59c72c4735050772a40b4819aad4154282884b