[INFO] updating cached repository https://github.com/marony/rust3d
[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] 9fb3b53b4668ecd4fe8a6104d874ad64a65edb49
[INFO] checking marony/rust3d against master#bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc for pr-70917
[INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmarony%2Frust3d" "/workspace/builds/worker-6/source"`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/marony/rust3d 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/marony/rust3d
[INFO] finished tweaking git repo https://github.com/marony/rust3d
[INFO] tweaked toml for git repo https://github.com/marony/rust3d written to /workspace/builds/worker-6/source/Cargo.toml
[INFO] crate git repo https://github.com/marony/rust3d 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]     Blocking waiting for file lock on package cache
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/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] 04d2b8c994b6d9781263811ed52db068622dd6114f9b3f18317f161e1101849e
[INFO] running `"docker" "start" "-a" "04d2b8c994b6d9781263811ed52db068622dd6114f9b3f18317f161e1101849e"`
[INFO] [stderr]    Compiling glib-sys v0.5.0
[INFO] [stderr]    Compiling gio-sys v0.5.0
[INFO] [stderr]    Compiling gdk-pixbuf-sys v0.5.0
[INFO] [stderr]    Compiling cairo-sys-rs v0.5.0
[INFO] [stderr]    Compiling pango-sys v0.5.0
[INFO] [stderr]    Compiling gdk-sys v0.5.0
[INFO] [stderr]    Compiling gtk-sys v0.5.0
[INFO] [stderr]    Compiling strcursor v0.2.5
[INFO] [stderr]    Compiling scan-rules v0.2.0
[INFO] [stderr]    Compiling gobject-sys v0.5.0
[INFO] [stderr]    Compiling cairo-rs v0.3.0
[INFO] [stderr]    Compiling atk-sys v0.5.0
[INFO] [stderr]    Compiling gio v0.3.0
[INFO] [stderr]    Compiling gdk-pixbuf v0.3.0
[INFO] [stderr]    Compiling gdk v0.7.0
[INFO] [stderr]    Compiling gtk v0.3.0
[INFO] [stderr]     Checking glib v0.4.1
[INFO] [stderr]     Checking pango v0.3.0
[INFO] [stderr]     Checking rust3d v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] warning: unused import: `gio::prelude::*`
[INFO] [stderr]  --> src/util/polygon3.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use gio::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `gio::prelude::*`
[INFO] [stderr]  --> src/util/world.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use gio::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `FontSlant`, `FontWeight`
[INFO] [stderr]   --> src/main.rs:21:20
[INFO] [stderr]    |
[INFO] [stderr] 21 | use cairo::enums::{FontSlant, FontWeight};
[INFO] [stderr]    |                    ^^^^^^^^^  ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `gio::prelude::*`
[INFO] [stderr]  --> src/util/polygon3.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use gio::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `gio::prelude::*`
[INFO] [stderr]  --> src/util/world.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 7 | use gio::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `FontSlant`, `FontWeight`
[INFO] [stderr]   --> src/main.rs:21:20
[INFO] [stderr]    |
[INFO] [stderr] 21 | use cairo::enums::{FontSlant, FontWeight};
[INFO] [stderr]    |                    ^^^^^^^^^  ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `gtk::prelude`
[INFO] [stderr]  --> src/util/polygon3.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use gtk::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `gtk::prelude`
[INFO] [stderr]  --> src/util/world.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use gtk::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `gio::prelude`
[INFO] [stderr]  --> src/main.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use gio::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `n`
[INFO] [stderr]   --> src/main.rs:88:29
[INFO] [stderr]    |
[INFO] [stderr] 88 |                 }).or_else(|n| {
[INFO] [stderr]    |                             ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `n`
[INFO] [stderr]   --> src/main.rs:98:29
[INFO] [stderr]    |
[INFO] [stderr] 98 |                 }).or_else(|n| {
[INFO] [stderr]    |                             ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rotate`
[INFO] [stderr]   --> src/util/world.rs:29:13
[INFO] [stderr]    |
[INFO] [stderr] 29 |         let rotate = 0i32;
[INFO] [stderr]    |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_rotate`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `c`
[INFO] [stderr]   --> src/util/world.rs:72:27
[INFO] [stderr]    |
[INFO] [stderr] 72 |             .filter(|&(p, c)| !self.camera.is_cull(p))
[INFO] [stderr]    |                           ^ help: if this is intentional, prefix it with an underscore: `_c`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `c`
[INFO] [stderr]   --> src/util/world.rs:86:27
[INFO] [stderr]    |
[INFO] [stderr] 86 |             .filter(|&(p, c)|
[INFO] [stderr]    |                           ^ help: if this is intentional, prefix it with an underscore: `_c`
[INFO] [stderr] 
[INFO] [stderr] warning: method is never used: `move_`
[INFO] [stderr]   --> src/util/polygon3.rs:67:5
[INFO] [stderr]    |
[INFO] [stderr] 67 |     pub fn move_(&self, v: &Vector3) -> Polygon3 {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: method is never used: `scale`
[INFO] [stderr]   --> src/util/polygon3.rs:81:5
[INFO] [stderr]    |
[INFO] [stderr] 81 |     pub fn scale(&self, v: &Vector3) -> Polygon3 {
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method is never used: `rotate_z`
[INFO] [stderr]    --> src/util/polygon3.rs:124:5
[INFO] [stderr]     |
[INFO] [stderr] 124 |     pub fn rotate_z(&self, r: f64) -> Polygon3 {
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused `std::result::Result` that must be used
[INFO] [stderr]    --> src/main.rs:84:17
[INFO] [stderr]     |
[INFO] [stderr] 84  | /                 scan!(&line; ("v ", let x: f64, let y: f64, let z: f64) => {
[INFO] [stderr] 85  | |                     let p = Point3::new(x, y, z, 1.0f64);
[INFO] [stderr] 86  | | //                    println!("{:?}", p);
[INFO] [stderr] 87  | |                     vs.push(p);
[INFO] [stderr] ...   |
[INFO] [stderr] 104 | |                     })
[INFO] [stderr] 105 | |                 });
[INFO] [stderr]     | |___________________^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:95:33
[INFO] [stderr]    |
[INFO] [stderr] 95 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]    |                                 ^
[INFO] [stderr]    |                                 |
[INFO] [stderr]    |                                 expected `f64`, found integer
[INFO] [stderr]    |                                 help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:95:36
[INFO] [stderr]    |
[INFO] [stderr] 95 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]    |                                    ^
[INFO] [stderr]    |                                    |
[INFO] [stderr]    |                                    expected `f64`, found integer
[INFO] [stderr]    |                                    help: use a float literal: `2.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:95:39
[INFO] [stderr]    |
[INFO] [stderr] 95 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]    |                                       ^
[INFO] [stderr]    |                                       |
[INFO] [stderr]    |                                       expected `f64`, found integer
[INFO] [stderr]    |                                       help: use a float literal: `3.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:95:42
[INFO] [stderr]    |
[INFO] [stderr] 95 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]    |                                          ^
[INFO] [stderr]    |                                          |
[INFO] [stderr]    |                                          expected `f64`, found integer
[INFO] [stderr]    |                                          help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:96:34
[INFO] [stderr]    |
[INFO] [stderr] 96 |             let b = Vector3::new(2, 3, 4, 1);
[INFO] [stderr]    |                                  ^
[INFO] [stderr]    |                                  |
[INFO] [stderr]    |                                  expected `f64`, found integer
[INFO] [stderr]    |                                  help: use a float literal: `2.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:96:37
[INFO] [stderr]    |
[INFO] [stderr] 96 |             let b = Vector3::new(2, 3, 4, 1);
[INFO] [stderr]    |                                     ^
[INFO] [stderr]    |                                     |
[INFO] [stderr]    |                                     expected `f64`, found integer
[INFO] [stderr]    |                                     help: use a float literal: `3.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:96:40
[INFO] [stderr]    |
[INFO] [stderr] 96 |             let b = Vector3::new(2, 3, 4, 1);
[INFO] [stderr]    |                                        ^
[INFO] [stderr]    |                                        |
[INFO] [stderr]    |                                        expected `f64`, found integer
[INFO] [stderr]    |                                        help: use a float literal: `4.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:96:43
[INFO] [stderr]    |
[INFO] [stderr] 96 |             let b = Vector3::new(2, 3, 4, 1);
[INFO] [stderr]    |                                           ^
[INFO] [stderr]    |                                           |
[INFO] [stderr]    |                                           expected `f64`, found integer
[INFO] [stderr]    |                                           help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: cannot add `util::vector3::Vector3` to `util::point3::Point3`
[INFO] [stderr]   --> src/util/point3.rs:97:23
[INFO] [stderr]    |
[INFO] [stderr] 97 |             let c = a + b;
[INFO] [stderr]    |                     - ^ - util::vector3::Vector3
[INFO] [stderr]    |                     |
[INFO] [stderr]    |                     util::point3::Point3
[INFO] [stderr]    |
[INFO] [stderr]    = note: an implementation of `std::ops::Add` might be missing for `util::point3::Point3`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:98:36
[INFO] [stderr]    |
[INFO] [stderr] 98 |             assert_eq!(Point3::new(3, 5, 7, 1), c);
[INFO] [stderr]    |                                    ^
[INFO] [stderr]    |                                    |
[INFO] [stderr]    |                                    expected `f64`, found integer
[INFO] [stderr]    |                                    help: use a float literal: `3.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:98:39
[INFO] [stderr]    |
[INFO] [stderr] 98 |             assert_eq!(Point3::new(3, 5, 7, 1), c);
[INFO] [stderr]    |                                       ^
[INFO] [stderr]    |                                       |
[INFO] [stderr]    |                                       expected `f64`, found integer
[INFO] [stderr]    |                                       help: use a float literal: `5.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:98:42
[INFO] [stderr]    |
[INFO] [stderr] 98 |             assert_eq!(Point3::new(3, 5, 7, 1), c);
[INFO] [stderr]    |                                          ^
[INFO] [stderr]    |                                          |
[INFO] [stderr]    |                                          expected `f64`, found integer
[INFO] [stderr]    |                                          help: use a float literal: `7.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]   --> src/util/point3.rs:98:45
[INFO] [stderr]    |
[INFO] [stderr] 98 |             assert_eq!(Point3::new(3, 5, 7, 1), c);
[INFO] [stderr]    |                                             ^
[INFO] [stderr]    |                                             |
[INFO] [stderr]    |                                             expected `f64`, found integer
[INFO] [stderr]    |                                             help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: binary operation `==` cannot be applied to type `util::point3::Point3`
[INFO] [stderr]   --> src/util/point3.rs:98:13
[INFO] [stderr]    |
[INFO] [stderr] 98 |             assert_eq!(Point3::new(3, 5, 7, 1), c);
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |             |
[INFO] [stderr]    |             util::point3::Point3
[INFO] [stderr]    |             _
[INFO] [stderr]    |
[INFO] [stderr]    = note: an implementation of `std::cmp::PartialEq` might be missing for `util::point3::Point3`
[INFO] [stderr]    = note: this error originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:105:33
[INFO] [stderr]     |
[INFO] [stderr] 105 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]     |                                 ^
[INFO] [stderr]     |                                 |
[INFO] [stderr]     |                                 expected `f64`, found integer
[INFO] [stderr]     |                                 help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:105:36
[INFO] [stderr]     |
[INFO] [stderr] 105 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]     |                                    ^
[INFO] [stderr]     |                                    |
[INFO] [stderr]     |                                    expected `f64`, found integer
[INFO] [stderr]     |                                    help: use a float literal: `2.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:105:39
[INFO] [stderr]     |
[INFO] [stderr] 105 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]     |                                       ^
[INFO] [stderr]     |                                       |
[INFO] [stderr]     |                                       expected `f64`, found integer
[INFO] [stderr]     |                                       help: use a float literal: `3.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:105:42
[INFO] [stderr]     |
[INFO] [stderr] 105 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]     |                                          ^
[INFO] [stderr]     |                                          |
[INFO] [stderr]     |                                          expected `f64`, found integer
[INFO] [stderr]     |                                          help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:106:34
[INFO] [stderr]     |
[INFO] [stderr] 106 |             let b = Vector3::new(2, 3, 4, 1);
[INFO] [stderr]     |                                  ^
[INFO] [stderr]     |                                  |
[INFO] [stderr]     |                                  expected `f64`, found integer
[INFO] [stderr]     |                                  help: use a float literal: `2.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:106:37
[INFO] [stderr]     |
[INFO] [stderr] 106 |             let b = Vector3::new(2, 3, 4, 1);
[INFO] [stderr]     |                                     ^
[INFO] [stderr]     |                                     |
[INFO] [stderr]     |                                     expected `f64`, found integer
[INFO] [stderr]     |                                     help: use a float literal: `3.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:106:40
[INFO] [stderr]     |
[INFO] [stderr] 106 |             let b = Vector3::new(2, 3, 4, 1);
[INFO] [stderr]     |                                        ^
[INFO] [stderr]     |                                        |
[INFO] [stderr]     |                                        expected `f64`, found integer
[INFO] [stderr]     |                                        help: use a float literal: `4.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:106:43
[INFO] [stderr]     |
[INFO] [stderr] 106 |             let b = Vector3::new(2, 3, 4, 1);
[INFO] [stderr]     |                                           ^
[INFO] [stderr]     |                                           |
[INFO] [stderr]     |                                           expected `f64`, found integer
[INFO] [stderr]     |                                           help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: cannot subtract `util::vector3::Vector3` from `util::point3::Point3`
[INFO] [stderr]    --> src/util/point3.rs:107:23
[INFO] [stderr]     |
[INFO] [stderr] 107 |             let c = a - b;
[INFO] [stderr]     |                     - ^ - util::vector3::Vector3
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     util::point3::Point3
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::ops::Sub` might be missing for `util::point3::Point3`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:108:36
[INFO] [stderr]     |
[INFO] [stderr] 108 |             assert_eq!(Point3::new(-1, -1, -1, 1), c);
[INFO] [stderr]     |                                    ^^
[INFO] [stderr]     |                                    |
[INFO] [stderr]     |                                    expected `f64`, found integer
[INFO] [stderr]     |                                    help: use a float literal: `-1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:108:40
[INFO] [stderr]     |
[INFO] [stderr] 108 |             assert_eq!(Point3::new(-1, -1, -1, 1), c);
[INFO] [stderr]     |                                        ^^
[INFO] [stderr]     |                                        |
[INFO] [stderr]     |                                        expected `f64`, found integer
[INFO] [stderr]     |                                        help: use a float literal: `-1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:108:44
[INFO] [stderr]     |
[INFO] [stderr] 108 |             assert_eq!(Point3::new(-1, -1, -1, 1), c);
[INFO] [stderr]     |                                            ^^
[INFO] [stderr]     |                                            |
[INFO] [stderr]     |                                            expected `f64`, found integer
[INFO] [stderr]     |                                            help: use a float literal: `-1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:108:48
[INFO] [stderr]     |
[INFO] [stderr] 108 |             assert_eq!(Point3::new(-1, -1, -1, 1), c);
[INFO] [stderr]     |                                                ^
[INFO] [stderr]     |                                                |
[INFO] [stderr]     |                                                expected `f64`, found integer
[INFO] [stderr]     |                                                help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: binary operation `==` cannot be applied to type `util::point3::Point3`
[INFO] [stderr]    --> src/util/point3.rs:108:13
[INFO] [stderr]     |
[INFO] [stderr] 108 |             assert_eq!(Point3::new(-1, -1, -1, 1), c);
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             util::point3::Point3
[INFO] [stderr]     |             _
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::cmp::PartialEq` might be missing for `util::point3::Point3`
[INFO] [stderr]     = note: this error originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:115:33
[INFO] [stderr]     |
[INFO] [stderr] 115 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]     |                                 ^
[INFO] [stderr]     |                                 |
[INFO] [stderr]     |                                 expected `f64`, found integer
[INFO] [stderr]     |                                 help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:115:36
[INFO] [stderr]     |
[INFO] [stderr] 115 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]     |                                    ^
[INFO] [stderr]     |                                    |
[INFO] [stderr]     |                                    expected `f64`, found integer
[INFO] [stderr]     |                                    help: use a float literal: `2.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:115:39
[INFO] [stderr]     |
[INFO] [stderr] 115 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]     |                                       ^
[INFO] [stderr]     |                                       |
[INFO] [stderr]     |                                       expected `f64`, found integer
[INFO] [stderr]     |                                       help: use a float literal: `3.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:115:42
[INFO] [stderr]     |
[INFO] [stderr] 115 |             let a = Point3::new(1, 2, 3, 1);
[INFO] [stderr]     |                                          ^
[INFO] [stderr]     |                                          |
[INFO] [stderr]     |                                          expected `f64`, found integer
[INFO] [stderr]     |                                          help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:116:33
[INFO] [stderr]     |
[INFO] [stderr] 116 |             let b = Point3::new(2, 3, 4, 1);
[INFO] [stderr]     |                                 ^
[INFO] [stderr]     |                                 |
[INFO] [stderr]     |                                 expected `f64`, found integer
[INFO] [stderr]     |                                 help: use a float literal: `2.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:116:36
[INFO] [stderr]     |
[INFO] [stderr] 116 |             let b = Point3::new(2, 3, 4, 1);
[INFO] [stderr]     |                                    ^
[INFO] [stderr]     |                                    |
[INFO] [stderr]     |                                    expected `f64`, found integer
[INFO] [stderr]     |                                    help: use a float literal: `3.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:116:39
[INFO] [stderr]     |
[INFO] [stderr] 116 |             let b = Point3::new(2, 3, 4, 1);
[INFO] [stderr]     |                                       ^
[INFO] [stderr]     |                                       |
[INFO] [stderr]     |                                       expected `f64`, found integer
[INFO] [stderr]     |                                       help: use a float literal: `4.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:116:42
[INFO] [stderr]     |
[INFO] [stderr] 116 |             let b = Point3::new(2, 3, 4, 1);
[INFO] [stderr]     |                                          ^
[INFO] [stderr]     |                                          |
[INFO] [stderr]     |                                          expected `f64`, found integer
[INFO] [stderr]     |                                          help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: cannot subtract `util::point3::Point3` from `util::point3::Point3`
[INFO] [stderr]    --> src/util/point3.rs:117:23
[INFO] [stderr]     |
[INFO] [stderr] 117 |             let c = a - b;
[INFO] [stderr]     |                     - ^ - util::point3::Point3
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     util::point3::Point3
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::ops::Sub` might be missing for `util::point3::Point3`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:118:36
[INFO] [stderr]     |
[INFO] [stderr] 118 |             assert_eq!(Point3::new(-1, -1, -1, 1), c);
[INFO] [stderr]     |                                    ^^
[INFO] [stderr]     |                                    |
[INFO] [stderr]     |                                    expected `f64`, found integer
[INFO] [stderr]     |                                    help: use a float literal: `-1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:118:40
[INFO] [stderr]     |
[INFO] [stderr] 118 |             assert_eq!(Point3::new(-1, -1, -1, 1), c);
[INFO] [stderr]     |                                        ^^
[INFO] [stderr]     |                                        |
[INFO] [stderr]     |                                        expected `f64`, found integer
[INFO] [stderr]     |                                        help: use a float literal: `-1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:118:44
[INFO] [stderr]     |
[INFO] [stderr] 118 |             assert_eq!(Point3::new(-1, -1, -1, 1), c);
[INFO] [stderr]     |                                            ^^
[INFO] [stderr]     |                                            |
[INFO] [stderr]     |                                            expected `f64`, found integer
[INFO] [stderr]     |                                            help: use a float literal: `-1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/point3.rs:118:48
[INFO] [stderr]     |
[INFO] [stderr] 118 |             assert_eq!(Point3::new(-1, -1, -1, 1), c);
[INFO] [stderr]     |                                                ^
[INFO] [stderr]     |                                                |
[INFO] [stderr]     |                                                expected `f64`, found integer
[INFO] [stderr]     |                                                help: use a float literal: `1.0`
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: binary operation `==` cannot be applied to type `util::point3::Point3`
[INFO] [stderr]    --> src/util/point3.rs:118:13
[INFO] [stderr]     |
[INFO] [stderr] 118 |             assert_eq!(Point3::new(-1, -1, -1, 1), c);
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             util::point3::Point3
[INFO] [stderr]     |             _
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::cmp::PartialEq` might be missing for `util::point3::Point3`
[INFO] [stderr]     = note: this error originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:128:34
[INFO] [stderr]     |
[INFO] [stderr] 128 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                  ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 128 |             let a = Vector3::new(2f64, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                  ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:128:40
[INFO] [stderr]     |
[INFO] [stderr] 128 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                        ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 128 |             let a = Vector3::new(2f32, 3f64, 4f32, 1f32);
[INFO] [stderr]     |                                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:128:46
[INFO] [stderr]     |
[INFO] [stderr] 128 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                              ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 128 |             let a = Vector3::new(2f32, 3f32, 4f64, 1f32);
[INFO] [stderr]     |                                              ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:128:52
[INFO] [stderr]     |
[INFO] [stderr] 128 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                                    ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 128 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f64);
[INFO] [stderr]     |                                                    ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:130:28
[INFO] [stderr]     |
[INFO] [stderr] 130 |             assert!(norm - 5.3851648071345037f32 < 1e-10f32);
[INFO] [stderr]     |                            ^^^^^^^^^^^^^^^^^^^^^ expected `f64`, found `f32`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: cannot subtract `f32` from `f64`
[INFO] [stderr]    --> src/util/vector3.rs:130:26
[INFO] [stderr]     |
[INFO] [stderr] 130 |             assert!(norm - 5.3851648071345037f32 < 1e-10f32);
[INFO] [stderr]     |                          ^ no implementation for `f64 - f32`
[INFO] [stderr]     |
[INFO] [stderr]     = help: the trait `std::ops::Sub<f32>` is not implemented for `f64`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:130:52
[INFO] [stderr]     |
[INFO] [stderr] 130 |             assert!(norm - 5.3851648071345037f32 < 1e-10f32);
[INFO] [stderr]     |                                                    ^^^^^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 130 |             assert!(norm - 5.3851648071345037f32 < 1e-10f64);
[INFO] [stderr]     |                                                    ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:143:34
[INFO] [stderr]     |
[INFO] [stderr] 143 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                  ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 143 |             let a = Vector3::new(2f64, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                  ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:143:40
[INFO] [stderr]     |
[INFO] [stderr] 143 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                        ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 143 |             let a = Vector3::new(2f32, 3f64, 4f32, 1f32);
[INFO] [stderr]     |                                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:143:46
[INFO] [stderr]     |
[INFO] [stderr] 143 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                              ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 143 |             let a = Vector3::new(2f32, 3f32, 4f64, 1f32);
[INFO] [stderr]     |                                              ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:143:52
[INFO] [stderr]     |
[INFO] [stderr] 143 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                                    ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 143 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f64);
[INFO] [stderr]     |                                                    ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:146:27
[INFO] [stderr]     |
[INFO] [stderr] 146 |             assert!(b.x - 0.37139068f32 < 1e-5f32);
[INFO] [stderr]     |                           ^^^^^^^^^^^^^ expected `f64`, found `f32`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: cannot subtract `f32` from `f64`
[INFO] [stderr]    --> src/util/vector3.rs:146:25
[INFO] [stderr]     |
[INFO] [stderr] 146 |             assert!(b.x - 0.37139068f32 < 1e-5f32);
[INFO] [stderr]     |                         ^ no implementation for `f64 - f32`
[INFO] [stderr]     |
[INFO] [stderr]     = help: the trait `std::ops::Sub<f32>` is not implemented for `f64`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:146:43
[INFO] [stderr]     |
[INFO] [stderr] 146 |             assert!(b.x - 0.37139068f32 < 1e-5f32);
[INFO] [stderr]     |                                           ^^^^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 146 |             assert!(b.x - 0.37139068f32 < 1e-5f64);
[INFO] [stderr]     |                                           ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:147:27
[INFO] [stderr]     |
[INFO] [stderr] 147 |             assert!(b.y - 0.55708601f32 < 1e-5f32);
[INFO] [stderr]     |                           ^^^^^^^^^^^^^ expected `f64`, found `f32`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: cannot subtract `f32` from `f64`
[INFO] [stderr]    --> src/util/vector3.rs:147:25
[INFO] [stderr]     |
[INFO] [stderr] 147 |             assert!(b.y - 0.55708601f32 < 1e-5f32);
[INFO] [stderr]     |                         ^ no implementation for `f64 - f32`
[INFO] [stderr]     |
[INFO] [stderr]     = help: the trait `std::ops::Sub<f32>` is not implemented for `f64`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:147:43
[INFO] [stderr]     |
[INFO] [stderr] 147 |             assert!(b.y - 0.55708601f32 < 1e-5f32);
[INFO] [stderr]     |                                           ^^^^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 147 |             assert!(b.y - 0.55708601f32 < 1e-5f64);
[INFO] [stderr]     |                                           ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:148:27
[INFO] [stderr]     |
[INFO] [stderr] 148 |             assert!(b.z - 0.74278135f32 < 1e-5f32);
[INFO] [stderr]     |                           ^^^^^^^^^^^^^ expected `f64`, found `f32`
[INFO] [stderr] 
[INFO] [stderr] error[E0277]: cannot subtract `f32` from `f64`
[INFO] [stderr]    --> src/util/vector3.rs:148:25
[INFO] [stderr]     |
[INFO] [stderr] 148 |             assert!(b.z - 0.74278135f32 < 1e-5f32);
[INFO] [stderr]     |                         ^ no implementation for `f64 - f32`
[INFO] [stderr]     |
[INFO] [stderr]     = help: the trait `std::ops::Sub<f32>` is not implemented for `f64`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:148:43
[INFO] [stderr]     |
[INFO] [stderr] 148 |             assert!(b.z - 0.74278135f32 < 1e-5f32);
[INFO] [stderr]     |                                           ^^^^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 148 |             assert!(b.z - 0.74278135f32 < 1e-5f64);
[INFO] [stderr]     |                                           ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:164:34
[INFO] [stderr]     |
[INFO] [stderr] 164 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                  ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 164 |             let a = Vector3::new(2f64, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                  ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:164:40
[INFO] [stderr]     |
[INFO] [stderr] 164 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                        ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 164 |             let a = Vector3::new(2f32, 3f64, 4f32, 1f32);
[INFO] [stderr]     |                                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:164:46
[INFO] [stderr]     |
[INFO] [stderr] 164 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                              ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 164 |             let a = Vector3::new(2f32, 3f32, 4f64, 1f32);
[INFO] [stderr]     |                                              ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:164:52
[INFO] [stderr]     |
[INFO] [stderr] 164 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f32);
[INFO] [stderr]     |                                                    ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 164 |             let a = Vector3::new(2f32, 3f32, 4f32, 1f64);
[INFO] [stderr]     |                                                    ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:165:34
[INFO] [stderr]     |
[INFO] [stderr] 165 |             let b = Vector3::new(5f32, 6f32, 7f32, 1f32);
[INFO] [stderr]     |                                  ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 165 |             let b = Vector3::new(5f64, 6f32, 7f32, 1f32);
[INFO] [stderr]     |                                  ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:165:40
[INFO] [stderr]     |
[INFO] [stderr] 165 |             let b = Vector3::new(5f32, 6f32, 7f32, 1f32);
[INFO] [stderr]     |                                        ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 165 |             let b = Vector3::new(5f32, 6f64, 7f32, 1f32);
[INFO] [stderr]     |                                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:165:46
[INFO] [stderr]     |
[INFO] [stderr] 165 |             let b = Vector3::new(5f32, 6f32, 7f32, 1f32);
[INFO] [stderr]     |                                              ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 165 |             let b = Vector3::new(5f32, 6f32, 7f64, 1f32);
[INFO] [stderr]     |                                              ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:165:52
[INFO] [stderr]     |
[INFO] [stderr] 165 |             let b = Vector3::new(5f32, 6f32, 7f32, 1f32);
[INFO] [stderr]     |                                                    ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 165 |             let b = Vector3::new(5f32, 6f32, 7f32, 1f64);
[INFO] [stderr]     |                                                    ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:166:29
[INFO] [stderr]     |
[INFO] [stderr] 166 |             let dot = a.dot(b);
[INFO] [stderr]     |                             ^
[INFO] [stderr]     |                             |
[INFO] [stderr]     |                             expected `&util::vector3::Vector3`, found struct `util::vector3::Vector3`
[INFO] [stderr]     |                             help: consider borrowing here: `&b`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:167:13
[INFO] [stderr]     |
[INFO] [stderr] 167 |             assert_eq!(56f32, dot);
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^ expected `f32`, found `f64`
[INFO] [stderr]     |
[INFO] [stderr]     = note: this error originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:186:34
[INFO] [stderr]     |
[INFO] [stderr] 186 |             let a = Vector3::new(3f32, 4f32, 5f32, 1f32);
[INFO] [stderr]     |                                  ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 186 |             let a = Vector3::new(3f64, 4f32, 5f32, 1f32);
[INFO] [stderr]     |                                  ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:186:40
[INFO] [stderr]     |
[INFO] [stderr] 186 |             let a = Vector3::new(3f32, 4f32, 5f32, 1f32);
[INFO] [stderr]     |                                        ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 186 |             let a = Vector3::new(3f32, 4f64, 5f32, 1f32);
[INFO] [stderr]     |                                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:186:46
[INFO] [stderr]     |
[INFO] [stderr] 186 |             let a = Vector3::new(3f32, 4f32, 5f32, 1f32);
[INFO] [stderr]     |                                              ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 186 |             let a = Vector3::new(3f32, 4f32, 5f64, 1f32);
[INFO] [stderr]     |                                              ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:186:52
[INFO] [stderr]     |
[INFO] [stderr] 186 |             let a = Vector3::new(3f32, 4f32, 5f32, 1f32);
[INFO] [stderr]     |                                                    ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 186 |             let a = Vector3::new(3f32, 4f32, 5f32, 1f64);
[INFO] [stderr]     |                                                    ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:187:34
[INFO] [stderr]     |
[INFO] [stderr] 187 |             let b = Vector3::new(6f32, 7f32, 8f32, 1f32);
[INFO] [stderr]     |                                  ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 187 |             let b = Vector3::new(6f64, 7f32, 8f32, 1f32);
[INFO] [stderr]     |                                  ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:187:40
[INFO] [stderr]     |
[INFO] [stderr] 187 |             let b = Vector3::new(6f32, 7f32, 8f32, 1f32);
[INFO] [stderr]     |                                        ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 187 |             let b = Vector3::new(6f32, 7f64, 8f32, 1f32);
[INFO] [stderr]     |                                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:187:46
[INFO] [stderr]     |
[INFO] [stderr] 187 |             let b = Vector3::new(6f32, 7f32, 8f32, 1f32);
[INFO] [stderr]     |                                              ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 187 |             let b = Vector3::new(6f32, 7f32, 8f64, 1f32);
[INFO] [stderr]     |                                              ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:187:52
[INFO] [stderr]     |
[INFO] [stderr] 187 |             let b = Vector3::new(6f32, 7f32, 8f32, 1f32);
[INFO] [stderr]     |                                                    ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 187 |             let b = Vector3::new(6f32, 7f32, 8f32, 1f64);
[INFO] [stderr]     |                                                    ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: cannot multiply `util::vector3::Vector3` to `util::vector3::Vector3`
[INFO] [stderr]    --> src/util/vector3.rs:188:24
[INFO] [stderr]     |
[INFO] [stderr] 188 |             let cp = a * b;
[INFO] [stderr]     |                      - ^ - util::vector3::Vector3
[INFO] [stderr]     |                      |
[INFO] [stderr]     |                      util::vector3::Vector3
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::ops::Mul` might be missing for `util::vector3::Vector3`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:189:37
[INFO] [stderr]     |
[INFO] [stderr] 189 |             assert_eq!(Vector3::new(-3f32, 6f32, -3f32, 1f32), cp);
[INFO] [stderr]     |                                     ^^^^^
[INFO] [stderr]     |                                     |
[INFO] [stderr]     |                                     expected `f64`, found `f32`
[INFO] [stderr]     |                                     help: you can convert an `f32` to `f64`: `(-3f32).into()`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:189:44
[INFO] [stderr]     |
[INFO] [stderr] 189 |             assert_eq!(Vector3::new(-3f32, 6f32, -3f32, 1f32), cp);
[INFO] [stderr]     |                                            ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 189 |             assert_eq!(Vector3::new(-3f32, 6f64, -3f32, 1f32), cp);
[INFO] [stderr]     |                                            ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:189:50
[INFO] [stderr]     |
[INFO] [stderr] 189 |             assert_eq!(Vector3::new(-3f32, 6f32, -3f32, 1f32), cp);
[INFO] [stderr]     |                                                  ^^^^^
[INFO] [stderr]     |                                                  |
[INFO] [stderr]     |                                                  expected `f64`, found `f32`
[INFO] [stderr]     |                                                  help: you can convert an `f32` to `f64`: `(-3f32).into()`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/util/vector3.rs:189:57
[INFO] [stderr]     |
[INFO] [stderr] 189 |             assert_eq!(Vector3::new(-3f32, 6f32, -3f32, 1f32), cp);
[INFO] [stderr]     |                                                         ^^^^ expected `f64`, found `f32`
[INFO] [stderr]     |
[INFO] [stderr] help: change the type of the numeric literal from `f32` to `f64`
[INFO] [stderr]     |
[INFO] [stderr] 189 |             assert_eq!(Vector3::new(-3f32, 6f32, -3f32, 1f64), cp);
[INFO] [stderr]     |                                                         ^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: binary operation `==` cannot be applied to type `util::vector3::Vector3`
[INFO] [stderr]    --> src/util/vector3.rs:189:13
[INFO] [stderr]     |
[INFO] [stderr] 189 |             assert_eq!(Vector3::new(-3f32, 6f32, -3f32, 1f32), cp);
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             util::vector3::Vector3
[INFO] [stderr]     |             _
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::cmp::PartialEq` might be missing for `util::vector3::Vector3`
[INFO] [stderr]     = note: this error originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: cannot add `util::matrix4::Matrix4` to `util::matrix4::Matrix4`
[INFO] [stderr]    --> src/util/matrix4.rs:120:23
[INFO] [stderr]     |
[INFO] [stderr] 120 |             let c = a + b;
[INFO] [stderr]     |                     - ^ - util::matrix4::Matrix4
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     util::matrix4::Matrix4
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::ops::Add` might be missing for `util::matrix4::Matrix4`
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: cannot subtract `util::matrix4::Matrix4` from `util::matrix4::Matrix4`
[INFO] [stderr]    --> src/util/matrix4.rs:144:23
[INFO] [stderr]     |
[INFO] [stderr] 144 |             let c = a - b;
[INFO] [stderr]     |                     - ^ - util::matrix4::Matrix4
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     util::matrix4::Matrix4
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::ops::Sub` might be missing for `util::matrix4::Matrix4`
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: cannot multiply `f64` to `util::matrix4::Matrix4`
[INFO] [stderr]    --> src/util/matrix4.rs:163:23
[INFO] [stderr]     |
[INFO] [stderr] 163 |             let b = a * 3f64;
[INFO] [stderr]     |                     - ^ ---- f64
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     util::matrix4::Matrix4
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::ops::Mul` might be missing for `util::matrix4::Matrix4`
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: cannot multiply `util::vector3::Vector3` to `util::matrix4::Matrix4`
[INFO] [stderr]    --> src/util/matrix4.rs:189:23
[INFO] [stderr]     |
[INFO] [stderr] 189 |             let c = a * b;
[INFO] [stderr]     |                     - ^ - util::vector3::Vector3
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     util::matrix4::Matrix4
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::ops::Mul` might be missing for `util::matrix4::Matrix4`
[INFO] [stderr] 
[INFO] [stderr] error[E0369]: cannot multiply `util::matrix4::Matrix4` to `util::matrix4::Matrix4`
[INFO] [stderr]    --> src/util/matrix4.rs:218:23
[INFO] [stderr]     |
[INFO] [stderr] 218 |             let c = a * b;
[INFO] [stderr]     |                     - ^ - util::matrix4::Matrix4
[INFO] [stderr]     |                     |
[INFO] [stderr]     |                     util::matrix4::Matrix4
[INFO] [stderr]     |
[INFO] [stderr]     = note: an implementation of `std::ops::Mul` might be missing for `util::matrix4::Matrix4`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `gtk::prelude`
[INFO] [stderr]  --> src/util/polygon3.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use gtk::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `gtk::prelude`
[INFO] [stderr]  --> src/util/world.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use gtk::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `gio::prelude`
[INFO] [stderr]  --> src/main.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use gio::prelude::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error: aborting due to 91 previous errors
[INFO] [stderr] 
[INFO] [stderr] Some errors have detailed explanations: E0277, E0308, E0369.
[INFO] [stderr] For more information about an error, try `rustc --explain E0277`.
[INFO] [stderr] error: could not compile `rust3d`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] running `"docker" "inspect" "04d2b8c994b6d9781263811ed52db068622dd6114f9b3f18317f161e1101849e"`
[INFO] running `"docker" "rm" "-f" "04d2b8c994b6d9781263811ed52db068622dd6114f9b3f18317f161e1101849e"`
[INFO] [stdout] 04d2b8c994b6d9781263811ed52db068622dd6114f9b3f18317f161e1101849e
