[INFO] updating cached repository https://github.com/thomcc/rs-stuff
[INFO] running `"git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune"`
[INFO] running `"git" "rev-parse" "HEAD"`
[INFO] [stdout] 94340101ec23e86d58d831ed0e4417dcfb9d225f
[INFO] checking thomcc/rs-stuff against master#bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc for pr-70917
[INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fthomcc%2Frs-stuff" "/workspace/builds/worker-1/source"`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/thomcc/rs-stuff on toolchain bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking git repo https://github.com/thomcc/rs-stuff
[INFO] finished tweaking git repo https://github.com/thomcc/rs-stuff
[INFO] tweaked toml for git repo https://github.com/thomcc/rs-stuff written to /workspace/builds/worker-1/source/Cargo.toml
[INFO] crate git repo https://github.com/thomcc/rs-stuff already has a lockfile, it will not be regenerated
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] [stderr] error: the lock file /workspace/builds/worker-1/source/Cargo.lock needs to be updated but --locked was passed to prevent this
[INFO] [stderr] If you want to try to generate the lock file without accessing the network, use the --offline flag.
[INFO] the lockfile is outdated, regenerating it
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"`
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "check" "--frozen" "--all" "--all-targets"`
[INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
[INFO] [stdout] f478fc5313a1d3b8fb1fc67f68c5aecb24cfa5831a35c008293d0ac5947e620a
[INFO] running `"docker" "start" "-a" "f478fc5313a1d3b8fb1fc67f68c5aecb24cfa5831a35c008293d0ac5947e620a"`
[INFO] [stderr]     Checking takeable-option v0.5.0
[INFO] [stderr]     Checking more-asserts v0.2.1
[INFO] [stderr]     Checking memmap v0.7.0
[INFO] [stderr]     Checking shared_library v0.1.9
[INFO] [stderr]     Checking raw-window-handle v0.3.3
[INFO] [stderr]    Compiling gl_generator v0.13.1
[INFO] [stderr]     Checking stb_truetype v0.3.1
[INFO] [stderr]     Checking nix v0.14.1
[INFO] [stderr]    Compiling wayland-scanner v0.23.6
[INFO] [stderr]    Compiling glium v0.27.0
[INFO] [stderr]     Checking mio-extras v2.0.6
[INFO] [stderr]     Checking x11-dl v2.18.5
[INFO] [stderr]    Compiling rustversion v1.0.2
[INFO] [stderr]    Compiling time-macros-impl v0.1.0
[INFO] [stderr]     Checking osmesa-sys v0.1.2
[INFO] [stderr]     Checking rusttype v0.8.3
[INFO] [stderr]     Checking stb_truetype v0.2.8
[INFO] [stderr]     Checking rusttype v0.7.9
[INFO] [stderr]    Compiling glutin_egl_sys v0.1.4
[INFO] [stderr]    Compiling glutin_glx_sys v0.1.6
[INFO] [stderr]     Checking rusttype v0.2.4
[INFO] [stderr]    Compiling time v0.2.9
[INFO] [stderr]     Checking time-macros v0.1.0
[INFO] [stderr]     Checking andrew v0.2.1
[INFO] [stderr]    Compiling wayland-client v0.23.6
[INFO] [stderr]    Compiling wayland-protocols v0.23.6
[INFO] [stderr]     Checking wayland-commons v0.23.6
[INFO] [stderr]     Checking calloop v0.4.4
[INFO] [stderr]     Checking smithay-client-toolkit v0.6.6
[INFO] [stderr]     Checking winit v0.22.0
[INFO] [stderr]     Checking glutin v0.24.0
[INFO] [stderr]     Checking stuff v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] error[E0432]: unresolved import `glium::backend::glutin_backend`
[INFO] [stderr]  --> src/font.rs:3:21
[INFO] [stderr]   |
[INFO] [stderr] 3 | use glium::backend::glutin_backend::GlutinFacade;
[INFO] [stderr]   |                     ^^^^^^^^^^^^^^ could not find `glutin_backend` in `backend`
[INFO] [stderr] 
[INFO] [stderr] error[E0432]: unresolved import `glium::DisplayBuild`
[INFO] [stderr]   --> src/main.rs:22:13
[INFO] [stderr]    |
[INFO] [stderr] 22 | use glium::{DisplayBuild, Surface};
[INFO] [stderr]    |             ^^^^^^^^^^^^ no `DisplayBuild` in the root
[INFO] [stderr] 
[INFO] [stderr] error[E0432]: unresolved import `glium::backend::glutin_backend`
[INFO] [stderr]   --> src/main.rs:27:21
[INFO] [stderr]    |
[INFO] [stderr] 27 | use glium::backend::glutin_backend::GlutinFacade;
[INFO] [stderr]    |                     ^^^^^^^^^^^^^^ could not find `glutin_backend` in `backend`
[INFO] [stderr] 
[INFO] [stderr] error[E0432]: unresolved imports `glium::glutin::Event`, `glium::glutin::ElementState`, `glium::glutin::MouseButton`
[INFO] [stderr]    --> src/main.rs:162:29
[INFO] [stderr]     |
[INFO] [stderr] 162 |         use glium::glutin::{Event, ElementState, MouseButton};
[INFO] [stderr]     |                             ^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^^^ no `MouseButton` in `glutin`
[INFO] [stderr]     |                             |      |
[INFO] [stderr]     |                             |      no `ElementState` in `glutin`
[INFO] [stderr]     |                             no `Event` in `glutin`
[INFO] [stderr]     |                             help: a similar name exists in the module: `event`
[INFO] [stderr] 
[INFO] [stderr] error[E0432]: unresolved import `glium::backend::glutin_backend`
[INFO] [stderr]  --> src/font.rs:3:21
[INFO] [stderr]   |
[INFO] [stderr] 3 | use glium::backend::glutin_backend::GlutinFacade;
[INFO] [stderr]   |                     ^^^^^^^^^^^^^^ could not find `glutin_backend` in `backend`
[INFO] [stderr] 
[INFO] [stderr] error[E0432]: unresolved import `glium::DisplayBuild`
[INFO] [stderr]   --> src/main.rs:22:13
[INFO] [stderr]    |
[INFO] [stderr] 22 | use glium::{DisplayBuild, Surface};
[INFO] [stderr]    |             ^^^^^^^^^^^^ no `DisplayBuild` in the root
[INFO] [stderr] 
[INFO] [stderr] error[E0432]: unresolved import `glium::backend::glutin_backend`
[INFO] [stderr]   --> src/main.rs:27:21
[INFO] [stderr]    |
[INFO] [stderr] 27 | use glium::backend::glutin_backend::GlutinFacade;
[INFO] [stderr]    |                     ^^^^^^^^^^^^^^ could not find `glutin_backend` in `backend`
[INFO] [stderr] 
[INFO] [stderr] error[E0432]: unresolved imports `glium::glutin::Event`, `glium::glutin::ElementState`, `glium::glutin::MouseButton`
[INFO] [stderr]    --> src/main.rs:162:29
[INFO] [stderr]     |
[INFO] [stderr] 162 |         use glium::glutin::{Event, ElementState, MouseButton};
[INFO] [stderr]     |                             ^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^^^ no `MouseButton` in `glutin`
[INFO] [stderr]     |                             |      |
[INFO] [stderr]     |                             |      no `ElementState` in `glutin`
[INFO] [stderr]     |                             no `Event` in `glutin`
[INFO] [stderr]     |                             help: a similar name exists in the module: `event`
[INFO] [stderr] 
[INFO] [stderr] error[E0433]: failed to resolve: could not find `glutin_backend` in `backend`
[INFO] [stderr]    --> src/main.rs:161:52
[INFO] [stderr]     |
[INFO] [stderr] 161 |     fn update(&mut self, display: &glium::backend::glutin_backend::GlutinFacade) -> bool {
[INFO] [stderr]     |                                                    ^^^^^^^^^^^^^^ could not find `glutin_backend` in `backend`
[INFO] [stderr] 
[INFO] [stderr] error[E0433]: failed to resolve: could not find `WindowBuilder` in `glutin`
[INFO] [stderr]    --> src/main.rs:234:38
[INFO] [stderr]     |
[INFO] [stderr] 234 |         let display = glium::glutin::WindowBuilder::new()
[INFO] [stderr]     |                                      ^^^^^^^^^^^^^ could not find `WindowBuilder` in `glutin`
[INFO] [stderr] 
[INFO] [stderr] error[E0433]: failed to resolve: could not find `VirtualKeyCode` in `glutin`
[INFO] [stderr]    --> src/main.rs:397:80
[INFO] [stderr]     |
[INFO] [stderr] 397 |         if win.input.key_changes.iter().any(|&(a, b)| b && a == glium::glutin::VirtualKeyCode::D) {
[INFO] [stderr]     |                                                                                ^^^^^^^^^^^^^^ could not find `VirtualKeyCode` in `glutin`
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `VirtualKeyCode` in crate `glium::glutin`
[INFO] [stderr]    --> src/main.rs:105:43
[INFO] [stderr]     |
[INFO] [stderr] 105 |     pub keys_down: HashSet<glium::glutin::VirtualKeyCode>,
[INFO] [stderr]     |                                           ^^^^^^^^^^^^^^ not found in `glium::glutin`
[INFO] [stderr]     |
[INFO] [stderr] help: possible candidate is found in another module, you can import it into scope
[INFO] [stderr]     |
[INFO] [stderr] 18  | use glium::glutin::event::VirtualKeyCode;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `VirtualKeyCode` in crate `glium::glutin`
[INFO] [stderr]    --> src/main.rs:106:42
[INFO] [stderr]     |
[INFO] [stderr] 106 |     pub key_changes: Vec<(glium::glutin::VirtualKeyCode, bool)>
[INFO] [stderr]     |                                          ^^^^^^^^^^^^^^ not found in `glium::glutin`
[INFO] [stderr]     |
[INFO] [stderr] help: possible candidate is found in another module, you can import it into scope
[INFO] [stderr]     |
[INFO] [stderr] 18  | use glium::glutin::event::VirtualKeyCode;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `VirtualKeyCode` in crate `glium::glutin`
[INFO] [stderr]    --> src/main.rs:155:47
[INFO] [stderr]     |
[INFO] [stderr] 155 |     pub fn keys_dir(&self, k1: glium::glutin::VirtualKeyCode, k2: glium::glutin::VirtualKeyCode) -> f32 {
[INFO] [stderr]     |                                               ^^^^^^^^^^^^^^ not found in `glium::glutin`
[INFO] [stderr]     |
[INFO] [stderr] help: possible candidate is found in another module, you can import it into scope
[INFO] [stderr]     |
[INFO] [stderr] 18  | use glium::glutin::event::VirtualKeyCode;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `VirtualKeyCode` in crate `glium::glutin`
[INFO] [stderr]    --> src/main.rs:155:82
[INFO] [stderr]     |
[INFO] [stderr] 155 |     pub fn keys_dir(&self, k1: glium::glutin::VirtualKeyCode, k2: glium::glutin::VirtualKeyCode) -> f32 {
[INFO] [stderr]     |                                                                                  ^^^^^^^^^^^^^^ not found in `glium::glutin`
[INFO] [stderr]     |
[INFO] [stderr] help: possible candidate is found in another module, you can import it into scope
[INFO] [stderr]     |
[INFO] [stderr] 18  | use glium::glutin::event::VirtualKeyCode;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `precise_time_ns` in crate `time`
[INFO] [stderr]    --> src/main.rs:261:32
[INFO] [stderr]     |
[INFO] [stderr] 261 |             frame_start: time::precise_time_ns(),
[INFO] [stderr]     |                                ^^^^^^^^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `precise_time_ns` in crate `time`
[INFO] [stderr]    --> src/main.rs:262:34
[INFO] [stderr]     |
[INFO] [stderr] 262 |             last_fps_time: time::precise_time_ns(),
[INFO] [stderr]     |                                  ^^^^^^^^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `precise_time_ns` in crate `time`
[INFO] [stderr]    --> src/main.rs:269:34
[INFO] [stderr]     |
[INFO] [stderr] 269 |         self.frame_start = time::precise_time_ns();
[INFO] [stderr]     |                                  ^^^^^^^^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `precise_time_ns` in crate `time`
[INFO] [stderr]    --> src/main.rs:351:25
[INFO] [stderr]     |
[INFO] [stderr] 351 |         let now = time::precise_time_ns();
[INFO] [stderr]     |                         ^^^^^^^^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0433]: failed to resolve: could not find `glutin_backend` in `backend`
[INFO] [stderr]    --> src/main.rs:161:52
[INFO] [stderr]     |
[INFO] [stderr] 161 |     fn update(&mut self, display: &glium::backend::glutin_backend::GlutinFacade) -> bool {
[INFO] [stderr]     |                                                    ^^^^^^^^^^^^^^ could not find `glutin_backend` in `backend`
[INFO] [stderr] 
[INFO] [stderr] error[E0433]: failed to resolve: could not find `WindowBuilder` in `glutin`
[INFO] [stderr]    --> src/main.rs:234:38
[INFO] [stderr]     |
[INFO] [stderr] 234 |         let display = glium::glutin::WindowBuilder::new()
[INFO] [stderr]     |                                      ^^^^^^^^^^^^^ could not find `WindowBuilder` in `glutin`
[INFO] [stderr] 
[INFO] [stderr] error[E0433]: failed to resolve: could not find `VirtualKeyCode` in `glutin`
[INFO] [stderr]    --> src/main.rs:397:80
[INFO] [stderr]     |
[INFO] [stderr] 397 |         if win.input.key_changes.iter().any(|&(a, b)| b && a == glium::glutin::VirtualKeyCode::D) {
[INFO] [stderr]     |                                                                                ^^^^^^^^^^^^^^ could not find `VirtualKeyCode` in `glutin`
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `VirtualKeyCode` in crate `glium::glutin`
[INFO] [stderr]    --> src/main.rs:105:43
[INFO] [stderr]     |
[INFO] [stderr] 105 |     pub keys_down: HashSet<glium::glutin::VirtualKeyCode>,
[INFO] [stderr]     |                                           ^^^^^^^^^^^^^^ not found in `glium::glutin`
[INFO] [stderr]     |
[INFO] [stderr] help: possible candidate is found in another module, you can import it into scope
[INFO] [stderr]     |
[INFO] [stderr] 18  | use glium::glutin::event::VirtualKeyCode;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `math::scalar::*`
[INFO] [stderr]  --> src/math/quat.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use math::scalar::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `VirtualKeyCode` in crate `glium::glutin`
[INFO] [stderr]    --> src/main.rs:106:42
[INFO] [stderr]     |
[INFO] [stderr] 106 |     pub key_changes: Vec<(glium::glutin::VirtualKeyCode, bool)>
[INFO] [stderr]     |                                          ^^^^^^^^^^^^^^ not found in `glium::glutin`
[INFO] [stderr]     |
[INFO] [stderr] help: possible candidate is found in another module, you can import it into scope
[INFO] [stderr]     |
[INFO] [stderr] 18  | use glium::glutin::event::VirtualKeyCode;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `VirtualKeyCode` in crate `glium::glutin`
[INFO] [stderr]    --> src/main.rs:155:47
[INFO] [stderr]     |
[INFO] [stderr] 155 |     pub fn keys_dir(&self, k1: glium::glutin::VirtualKeyCode, k2: glium::glutin::VirtualKeyCode) -> f32 {
[INFO] [stderr]     |                                               ^^^^^^^^^^^^^^ not found in `glium::glutin`
[INFO] [stderr]     |
[INFO] [stderr] help: possible candidate is found in another module, you can import it into scope
[INFO] [stderr]     |
[INFO] [stderr] 18  | use glium::glutin::event::VirtualKeyCode;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `VirtualKeyCode` in crate `glium::glutin`
[INFO] [stderr]    --> src/main.rs:155:82
[INFO] [stderr]     |
[INFO] [stderr] 155 |     pub fn keys_dir(&self, k1: glium::glutin::VirtualKeyCode, k2: glium::glutin::VirtualKeyCode) -> f32 {
[INFO] [stderr]     |                                                                                  ^^^^^^^^^^^^^^ not found in `glium::glutin`
[INFO] [stderr]     |
[INFO] [stderr] help: possible candidate is found in another module, you can import it into scope
[INFO] [stderr]     |
[INFO] [stderr] 18  | use glium::glutin::event::VirtualKeyCode;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `precise_time_ns` in crate `time`
[INFO] [stderr]    --> src/main.rs:261:32
[INFO] [stderr]     |
[INFO] [stderr] 261 |             frame_start: time::precise_time_ns(),
[INFO] [stderr]     |                                ^^^^^^^^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `precise_time_ns` in crate `time`
[INFO] [stderr]    --> src/main.rs:262:34
[INFO] [stderr]     |
[INFO] [stderr] 262 |             last_fps_time: time::precise_time_ns(),
[INFO] [stderr]     |                                  ^^^^^^^^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `precise_time_ns` in crate `time`
[INFO] [stderr]    --> src/main.rs:269:34
[INFO] [stderr]     |
[INFO] [stderr] 269 |         self.frame_start = time::precise_time_ns();
[INFO] [stderr]     |                                  ^^^^^^^^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `precise_time_ns` in crate `time`
[INFO] [stderr]    --> src/main.rs:351:25
[INFO] [stderr]     |
[INFO] [stderr] 351 |         let now = time::precise_time_ns();
[INFO] [stderr]     |                         ^^^^^^^^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `PositionedGlyph`
[INFO] [stderr]  --> src/font.rs:4:60
[INFO] [stderr]   |
[INFO] [stderr] 4 | use rusttype::{FontCollection, Font, Scale, point, vector, PositionedGlyph};
[INFO] [stderr]   |                                                            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around const expression
[INFO] [stderr]   --> src/bsp.rs:34:13
[INFO] [stderr]    |
[INFO] [stderr] 34 |     Under = (PlaneTestResult::Under as u8), // 0b01
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around const expression
[INFO] [stderr]   --> src/bsp.rs:35:12
[INFO] [stderr]    |
[INFO] [stderr] 35 |     Over = (PlaneTestResult::Over as u8), // 0b10
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `BspNode`
[INFO] [stderr]   --> src/main.rs:18:11
[INFO] [stderr]    |
[INFO] [stderr] 18 | use bsp::{BspNode, Face};
[INFO] [stderr]    |           ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `RefCell`
[INFO] [stderr]   --> src/main.rs:24:17
[INFO] [stderr]    |
[INFO] [stderr] 24 | use std::cell::{RefCell};
[INFO] [stderr]    |                 ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::rc::Rc`
[INFO] [stderr]   --> src/main.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 | use std::rc::Rc;
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around block return value
[INFO] [stderr]    --> src/main.rs:131:9
[INFO] [stderr]     |
[INFO] [stderr] 131 |         (now - prev)
[INFO] [stderr]     |         ^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `math::scalar::*`
[INFO] [stderr]  --> src/math/quat.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use math::scalar::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `PositionedGlyph`
[INFO] [stderr]  --> src/font.rs:4:60
[INFO] [stderr]   |
[INFO] [stderr] 4 | use rusttype::{FontCollection, Font, Scale, point, vector, PositionedGlyph};
[INFO] [stderr]   |                                                            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around const expression
[INFO] [stderr]   --> src/bsp.rs:34:13
[INFO] [stderr]    |
[INFO] [stderr] 34 |     Under = (PlaneTestResult::Under as u8), // 0b01
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around const expression
[INFO] [stderr]   --> src/bsp.rs:35:12
[INFO] [stderr]    |
[INFO] [stderr] 35 |     Over = (PlaneTestResult::Over as u8), // 0b10
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `BspNode`
[INFO] [stderr]   --> src/main.rs:18:11
[INFO] [stderr]    |
[INFO] [stderr] 18 | use bsp::{BspNode, Face};
[INFO] [stderr]    |           ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `RefCell`
[INFO] [stderr]   --> src/main.rs:24:17
[INFO] [stderr]    |
[INFO] [stderr] 24 | use std::cell::{RefCell};
[INFO] [stderr]    |                 ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::rc::Rc`
[INFO] [stderr]   --> src/main.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 | use std::rc::Rc;
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around block return value
[INFO] [stderr]    --> src/main.rs:131:9
[INFO] [stderr]     |
[INFO] [stderr] 131 |         (now - prev)
[INFO] [stderr]     |         ^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] error[E0282]: type annotations needed
[INFO] [stderr]    --> src/main.rs:119:24
[INFO] [stderr]     |
[INFO] [stderr] 119 |             keys_down: HashSet::new(),
[INFO] [stderr]     |                        ^^^^^^^^^^^^ cannot infer type for type parameter `T`
[INFO] [stderr] 
[INFO] [stderr] error[E0282]: type annotations needed
[INFO] [stderr]    --> src/main.rs:119:24
[INFO] [stderr]     |
[INFO] [stderr] 119 |             keys_down: HashSet::new(),
[INFO] [stderr]     |                        ^^^^^^^^^^^^ cannot infer type for type parameter `T`
[INFO] [stderr] 
[INFO] [stderr] warning: a method with this name may be added to the standard library in the future
[INFO] [stderr]    --> src/math/vec.rs:170:41
[INFO] [stderr]     |
[INFO] [stderr] 170 |         self.map3(min, max, |v, l, h| v.clamp(l, h))
[INFO] [stderr]     |                                         ^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unstable_name_collisions)]` on by default
[INFO] [stderr]     = warning: once this method is added to the standard library, the ambiguity may cause an error or change in behavior!
[INFO] [stderr]     = note: for more information, see issue #48919 <https://github.com/rust-lang/rust/issues/48919>
[INFO] [stderr]     = help: call with fully qualified syntax `math::traits::Clamp::clamp(...)` to keep using the current method
[INFO] [stderr]     = help: add `#![feature(clamp)]` to the crate attributes to enable `std::f32::<impl f32>::clamp`
[INFO] [stderr] 
[INFO] [stderr] warning: a method with this name may be added to the standard library in the future
[INFO] [stderr]    --> src/math/vec.rs:170:41
[INFO] [stderr]     |
[INFO] [stderr] 170 |         self.map3(min, max, |v, l, h| v.clamp(l, h))
[INFO] [stderr]     |                                         ^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unstable_name_collisions)]` on by default
[INFO] [stderr]     = warning: once this method is added to the standard library, the ambiguity may cause an error or change in behavior!
[INFO] [stderr]     = note: for more information, see issue #48919 <https://github.com/rust-lang/rust/issues/48919>
[INFO] [stderr]     = help: call with fully qualified syntax `math::traits::Clamp::clamp(...)` to keep using the current method
[INFO] [stderr]     = help: add `#![feature(clamp)]` to the crate attributes to enable `std::f32::<impl f32>::clamp`
[INFO] [stderr] 
[INFO] [stderr] error: aborting due to 16 previous errors
[INFO] [stderr] 
[INFO] [stderr] Some errors have detailed explanations: E0282, E0412, E0425, E0432, E0433.
[INFO] [stderr] For more information about an error, try `rustc --explain E0282`.
[INFO] [stderr] error: could not compile `stuff`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error: aborting due to 16 previous errors
[INFO] [stderr] 
[INFO] [stderr] Some errors have detailed explanations: E0282, E0412, E0425, E0432, E0433.
[INFO] [stderr] For more information about an error, try `rustc --explain E0282`.
[INFO] [stderr] error: could not compile `stuff`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] running `"docker" "inspect" "f478fc5313a1d3b8fb1fc67f68c5aecb24cfa5831a35c008293d0ac5947e620a"`
[INFO] running `"docker" "rm" "-f" "f478fc5313a1d3b8fb1fc67f68c5aecb24cfa5831a35c008293d0ac5947e620a"`
[INFO] [stdout] f478fc5313a1d3b8fb1fc67f68c5aecb24cfa5831a35c008293d0ac5947e620a
