[INFO] fetching crate chip 0.0.6...
[INFO] testing chip-0.0.6 against master#c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38 for pr-146098-7
[INFO] extracting crate chip 0.0.6 into /workspace/builds/worker-0-tc1/source
[INFO] started tweaking crates.io crate chip 0.0.6
[INFO] finished tweaking crates.io crate chip 0.0.6
[INFO] tweaked toml for crates.io crate chip 0.0.6 written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate chip 0.0.6 on toolchain c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 32 packages to latest compatible versions
[INFO] [stderr]       Adding nalgebra v0.18.1 (available: v0.34.1)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded cloudabi v0.0.3
[INFO] [stderr]   Downloaded rand_pcg v0.1.2
[INFO] [stderr]   Downloaded autocfg v0.1.8
[INFO] [stderr]   Downloaded rand_isaac v0.1.1
[INFO] [stderr]   Downloaded rand_chacha v0.1.1
[INFO] [stderr]   Downloaded num-complex v0.2.4
[INFO] [stderr]   Downloaded rand_os v0.1.3
[INFO] [stderr]   Downloaded num-rational v0.2.4
[INFO] [stderr]   Downloaded rand_jitter v0.1.4
[INFO] [stderr]   Downloaded approx v0.3.2
[INFO] [stderr]   Downloaded alga v0.9.3
[INFO] [stderr]   Downloaded rand v0.6.5
[INFO] [stderr]   Downloaded matrixmultiply v0.2.4
[INFO] [stderr]   Downloaded nalgebra v0.18.1
[INFO] [stderr]   Downloaded rand_hc v0.1.0
[INFO] [stderr]   Downloaded rand_xorshift v0.1.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] a906032f21e4d469c6be8fbe02983df4c340b1c9c28e1edae73e20ddce2ec549
[INFO] running `Command { std: "docker" "start" "-a" "a906032f21e4d469c6be8fbe02983df4c340b1c9c28e1edae73e20ddce2ec549", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "a906032f21e4d469c6be8fbe02983df4c340b1c9c28e1edae73e20ddce2ec549", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a906032f21e4d469c6be8fbe02983df4c340b1c9c28e1edae73e20ddce2ec549", kill_on_drop: false }`
[INFO] [stdout] a906032f21e4d469c6be8fbe02983df4c340b1c9c28e1edae73e20ddce2ec549
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d03b639c41e6868f320c4e5b8366808e6ee5571b81e40d21cdb3a975daf2967a
[INFO] running `Command { std: "docker" "start" "-a" "d03b639c41e6868f320c4e5b8366808e6ee5571b81e40d21cdb3a975daf2967a", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]    Compiling autocfg v0.1.8
[INFO] [stderr]    Compiling rand_core v0.4.2
[INFO] [stderr]    Compiling libm v0.2.15
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling libc v0.2.177
[INFO] [stderr]    Compiling num-complex v0.2.4
[INFO] [stderr]    Compiling typenum v1.19.0
[INFO] [stderr]    Compiling num-rational v0.2.4
[INFO] [stderr]    Compiling rand_core v0.3.1
[INFO] [stderr]    Compiling rand_pcg v0.1.2
[INFO] [stderr]    Compiling rand_chacha v0.1.1
[INFO] [stderr]    Compiling rand v0.6.5
[INFO] [stderr]    Compiling rand_hc v0.1.0
[INFO] [stderr]    Compiling rand_isaac v0.1.1
[INFO] [stderr]    Compiling rand_xorshift v0.1.1
[INFO] [stderr]    Compiling rand_jitter v0.1.4
[INFO] [stderr]    Compiling rawpointer v0.2.1
[INFO] [stderr]    Compiling chip v0.0.6 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling matrixmultiply v0.2.4
[INFO] [stderr]    Compiling generic-array v0.12.4
[INFO] [stderr]    Compiling rand_os v0.1.3
[INFO] [stderr]    Compiling approx v0.3.2
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling alga v0.9.3
[INFO] [stderr]    Compiling nalgebra v0.18.1
[INFO] [stdout] warning: anonymous parameters are deprecated and will be removed in the next edition
[INFO] [stdout]  --> src/extend.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 |     fn from_c(T) -> Self;
[INFO] [stdout]   |               ^ help: try naming the parameter or explicitly ignoring it: `_: T`
[INFO] [stdout]   |
[INFO] [stdout]   = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2018!
[INFO] [stdout]   = note: for more information, see issue #41686 <https://github.com/rust-lang/rust/issues/41686>
[INFO] [stdout]   = note: `#[warn(anonymous_parameters)]` (part of `#[warn(rust_2018_compatibility)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:101:45
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:159:45
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:165:45
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:247:45
[INFO] [stdout]     |
[INFO] [stdout] 247 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:253:45
[INFO] [stdout]     |
[INFO] [stdout] 253 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:502:45
[INFO] [stdout]     |
[INFO] [stdout] 502 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:508:45
[INFO] [stdout]     |
[INFO] [stdout] 508 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:531:45
[INFO] [stdout]     |
[INFO] [stdout] 531 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:577:45
[INFO] [stdout]     |
[INFO] [stdout] 577 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:583:45
[INFO] [stdout]     |
[INFO] [stdout] 583 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:589:45
[INFO] [stdout]     |
[INFO] [stdout] 589 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:595:45
[INFO] [stdout]     |
[INFO] [stdout] 595 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:601:45
[INFO] [stdout]     |
[INFO] [stdout] 601 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:682:45
[INFO] [stdout]     |
[INFO] [stdout] 682 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:736:45
[INFO] [stdout]     |
[INFO] [stdout] 736 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:846:45
[INFO] [stdout]     |
[INFO] [stdout] 846 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Container_proxy` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:101:33
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:86:5
[INFO] [stdout]     |
[INFO] [stdout]  86 |     pub _Mycont: *const std__Container_base12,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Container_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:159:33
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Container_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:165:33
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Iterator_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:247:33
[INFO] [stdout]     |
[INFO] [stdout] 247 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Iterator_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:253:33
[INFO] [stdout]     |
[INFO] [stdout] 253 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 9]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:438:57
[INFO] [stdout]     |
[INFO] [stdout] 438 |     pub fn euler_rotation(pyr: *const [f32; 3usize]) -> [f32; 9usize];
[INFO] [stdout]     |                                                         ^^^^^^^^^^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout]     = note: `#[warn(improper_ctypes)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:472:44
[INFO] [stdout]     |
[INFO] [stdout] 472 |     pub fn tri_center(this: *const tri) -> vec3;
[INFO] [stdout]     |                                            ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:476:49
[INFO] [stdout]     |
[INFO] [stdout] 476 |     pub fn tri_unit_normal(this: *const tri) -> vec3;
[INFO] [stdout]     |                                                 ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `tri` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:502:33
[INFO] [stdout]     |
[INFO] [stdout] 502 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:468:5
[INFO] [stdout]     |
[INFO] [stdout] 468 |     pub p: [vec3; 3usize],
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `tri` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:508:33
[INFO] [stdout]     |
[INFO] [stdout] 508 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:468:5
[INFO] [stdout]     |
[INFO] [stdout] 468 |     pub p: [vec3; 3usize],
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `obb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:531:33
[INFO] [stdout]     |
[INFO] [stdout] 531 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:515:5
[INFO] [stdout]     |
[INFO] [stdout] 515 |     pub center: vec3,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:548:46
[INFO] [stdout]     |
[INFO] [stdout] 548 |     pub fn aabb_center(this: *const aabb) -> vec3;
[INFO] [stdout]     |                                              ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:577:33
[INFO] [stdout]     |
[INFO] [stdout] 577 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:583:33
[INFO] [stdout]     |
[INFO] [stdout] 583 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:589:33
[INFO] [stdout]     |
[INFO] [stdout] 589 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:595:33
[INFO] [stdout]     |
[INFO] [stdout] 595 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:601:33
[INFO] [stdout]     |
[INFO] [stdout] 601 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Pitch` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:682:33
[INFO] [stdout]     |
[INFO] [stdout] 682 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]    --> src/ffi.rs:633:5
[INFO] [stdout]     |
[INFO] [stdout] 633 |     pub empty: aabb,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `ffi::Ball` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:736:33
[INFO] [stdout]     |
[INFO] [stdout] 736 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:689:5
[INFO] [stdout]     |
[INFO] [stdout] 689 |     pub x: vec3,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:784:56
[INFO] [stdout]     |
[INFO] [stdout] 784 |     pub fn Car_pitch_surface_normal(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                                        ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:796:43
[INFO] [stdout]     |
[INFO] [stdout] 796 |     pub fn Car_forward(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                           ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:800:40
[INFO] [stdout]     |
[INFO] [stdout] 800 |     pub fn Car_left(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                        ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:804:38
[INFO] [stdout]     |
[INFO] [stdout] 804 |     pub fn Car_up(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                      ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `ffi::Car` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:846:33
[INFO] [stdout]     |
[INFO] [stdout] 846 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:756:5
[INFO] [stdout]     |
[INFO] [stdout] 756 |     pub x: vec3,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 16.60s
[INFO] running `Command { std: "docker" "inspect" "d03b639c41e6868f320c4e5b8366808e6ee5571b81e40d21cdb3a975daf2967a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d03b639c41e6868f320c4e5b8366808e6ee5571b81e40d21cdb3a975daf2967a", kill_on_drop: false }`
[INFO] [stdout] d03b639c41e6868f320c4e5b8366808e6ee5571b81e40d21cdb3a975daf2967a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 26367d5b0440c95b9b1fe575a97e7314a83a8e8c940aa4d85558196affea4dad
[INFO] running `Command { std: "docker" "start" "-a" "26367d5b0440c95b9b1fe575a97e7314a83a8e8c940aa4d85558196affea4dad", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stdout] warning: anonymous parameters are deprecated and will be removed in the next edition
[INFO] [stdout]  --> src/extend.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 |     fn from_c(T) -> Self;
[INFO] [stdout]   |               ^ help: try naming the parameter or explicitly ignoring it: `_: T`
[INFO] [stdout]   |
[INFO] [stdout]   = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2018!
[INFO] [stdout]   = note: for more information, see issue #41686 <https://github.com/rust-lang/rust/issues/41686>
[INFO] [stdout]   = note: `#[warn(anonymous_parameters)]` (part of `#[warn(rust_2018_compatibility)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:101:45
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:159:45
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:165:45
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:247:45
[INFO] [stdout]     |
[INFO] [stdout] 247 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:253:45
[INFO] [stdout]     |
[INFO] [stdout] 253 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:502:45
[INFO] [stdout]     |
[INFO] [stdout] 502 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:508:45
[INFO] [stdout]     |
[INFO] [stdout] 508 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:531:45
[INFO] [stdout]     |
[INFO] [stdout] 531 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:577:45
[INFO] [stdout]     |
[INFO] [stdout] 577 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:583:45
[INFO] [stdout]     |
[INFO] [stdout] 583 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:589:45
[INFO] [stdout]     |
[INFO] [stdout] 589 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:595:45
[INFO] [stdout]     |
[INFO] [stdout] 595 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:601:45
[INFO] [stdout]     |
[INFO] [stdout] 601 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:682:45
[INFO] [stdout]     |
[INFO] [stdout] 682 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:736:45
[INFO] [stdout]     |
[INFO] [stdout] 736 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:846:45
[INFO] [stdout]     |
[INFO] [stdout] 846 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Container_proxy` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:101:33
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:86:5
[INFO] [stdout]     |
[INFO] [stdout]  86 |     pub _Mycont: *const std__Container_base12,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Container_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:159:33
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Container_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:165:33
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Iterator_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:247:33
[INFO] [stdout]     |
[INFO] [stdout] 247 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Iterator_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:253:33
[INFO] [stdout]     |
[INFO] [stdout] 253 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 9]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:438:57
[INFO] [stdout]     |
[INFO] [stdout] 438 |     pub fn euler_rotation(pyr: *const [f32; 3usize]) -> [f32; 9usize];
[INFO] [stdout]     |                                                         ^^^^^^^^^^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout]     = note: `#[warn(improper_ctypes)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:472:44
[INFO] [stdout]     |
[INFO] [stdout] 472 |     pub fn tri_center(this: *const tri) -> vec3;
[INFO] [stdout]     |                                            ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:476:49
[INFO] [stdout]     |
[INFO] [stdout] 476 |     pub fn tri_unit_normal(this: *const tri) -> vec3;
[INFO] [stdout]     |                                                 ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `tri` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:502:33
[INFO] [stdout]     |
[INFO] [stdout] 502 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:468:5
[INFO] [stdout]     |
[INFO] [stdout] 468 |     pub p: [vec3; 3usize],
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `tri` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:508:33
[INFO] [stdout]     |
[INFO] [stdout] 508 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:468:5
[INFO] [stdout]     |
[INFO] [stdout] 468 |     pub p: [vec3; 3usize],
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `obb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:531:33
[INFO] [stdout]     |
[INFO] [stdout] 531 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:515:5
[INFO] [stdout]     |
[INFO] [stdout] 515 |     pub center: vec3,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:548:46
[INFO] [stdout]     |
[INFO] [stdout] 548 |     pub fn aabb_center(this: *const aabb) -> vec3;
[INFO] [stdout]     |                                              ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:577:33
[INFO] [stdout]     |
[INFO] [stdout] 577 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:583:33
[INFO] [stdout]     |
[INFO] [stdout] 583 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:589:33
[INFO] [stdout]     |
[INFO] [stdout] 589 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:595:33
[INFO] [stdout]     |
[INFO] [stdout] 595 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:601:33
[INFO] [stdout]     |
[INFO] [stdout] 601 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Pitch` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:682:33
[INFO] [stdout]     |
[INFO] [stdout] 682 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]    --> src/ffi.rs:633:5
[INFO] [stdout]     |
[INFO] [stdout] 633 |     pub empty: aabb,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `ffi::Ball` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:736:33
[INFO] [stdout]     |
[INFO] [stdout] 736 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:689:5
[INFO] [stdout]     |
[INFO] [stdout] 689 |     pub x: vec3,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:784:56
[INFO] [stdout]     |
[INFO] [stdout] 784 |     pub fn Car_pitch_surface_normal(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                                        ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:796:43
[INFO] [stdout]     |
[INFO] [stdout] 796 |     pub fn Car_forward(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                           ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:800:40
[INFO] [stdout]     |
[INFO] [stdout] 800 |     pub fn Car_left(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                        ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:804:38
[INFO] [stdout]     |
[INFO] [stdout] 804 |     pub fn Car_up(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                      ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `ffi::Car` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:846:33
[INFO] [stdout]     |
[INFO] [stdout] 846 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:756:5
[INFO] [stdout]     |
[INFO] [stdout] 756 |     pub x: vec3,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling chip v0.0.6 (/opt/rustwide/workdir)
[INFO] [stdout] warning: anonymous parameters are deprecated and will be removed in the next edition
[INFO] [stdout]  --> src/extend.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 |     fn from_c(T) -> Self;
[INFO] [stdout]   |               ^ help: try naming the parameter or explicitly ignoring it: `_: T`
[INFO] [stdout]   |
[INFO] [stdout]   = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2018!
[INFO] [stdout]   = note: for more information, see issue #41686 <https://github.com/rust-lang/rust/issues/41686>
[INFO] [stdout]   = note: `#[warn(anonymous_parameters)]` (part of `#[warn(rust_2018_compatibility)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:101:45
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:159:45
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:165:45
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:247:45
[INFO] [stdout]     |
[INFO] [stdout] 247 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:253:45
[INFO] [stdout]     |
[INFO] [stdout] 253 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:502:45
[INFO] [stdout]     |
[INFO] [stdout] 502 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:508:45
[INFO] [stdout]     |
[INFO] [stdout] 508 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:531:45
[INFO] [stdout]     |
[INFO] [stdout] 531 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:577:45
[INFO] [stdout]     |
[INFO] [stdout] 577 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:583:45
[INFO] [stdout]     |
[INFO] [stdout] 583 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:589:45
[INFO] [stdout]     |
[INFO] [stdout] 589 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:595:45
[INFO] [stdout]     |
[INFO] [stdout] 595 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:601:45
[INFO] [stdout]     |
[INFO] [stdout] 601 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:682:45
[INFO] [stdout]     |
[INFO] [stdout] 682 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:736:45
[INFO] [stdout]     |
[INFO] [stdout] 736 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::mem::uninitialized`: use `mem::MaybeUninit` instead
[INFO] [stdout]    --> src/ffi.rs:846:45
[INFO] [stdout]     |
[INFO] [stdout] 846 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Container_proxy` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:101:33
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:86:5
[INFO] [stdout]     |
[INFO] [stdout]  86 |     pub _Mycont: *const std__Container_base12,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(invalid_value)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Container_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:159:33
[INFO] [stdout]     |
[INFO] [stdout] 159 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Container_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:165:33
[INFO] [stdout]     |
[INFO] [stdout] 165 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:109:5
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Iterator_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:247:33
[INFO] [stdout]     |
[INFO] [stdout] 247 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `std__Iterator_base12` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:253:33
[INFO] [stdout]     |
[INFO] [stdout] 253 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: raw pointers must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:173:5
[INFO] [stdout]     |
[INFO] [stdout] 173 |     pub _Myproxy: *mut std__Container_proxy,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 9]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:438:57
[INFO] [stdout]     |
[INFO] [stdout] 438 |     pub fn euler_rotation(pyr: *const [f32; 3usize]) -> [f32; 9usize];
[INFO] [stdout]     |                                                         ^^^^^^^^^^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout]     = note: `#[warn(improper_ctypes)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:472:44
[INFO] [stdout]     |
[INFO] [stdout] 472 |     pub fn tri_center(this: *const tri) -> vec3;
[INFO] [stdout]     |                                            ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:476:49
[INFO] [stdout]     |
[INFO] [stdout] 476 |     pub fn tri_unit_normal(this: *const tri) -> vec3;
[INFO] [stdout]     |                                                 ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `tri` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:502:33
[INFO] [stdout]     |
[INFO] [stdout] 502 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:468:5
[INFO] [stdout]     |
[INFO] [stdout] 468 |     pub p: [vec3; 3usize],
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `tri` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:508:33
[INFO] [stdout]     |
[INFO] [stdout] 508 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:468:5
[INFO] [stdout]     |
[INFO] [stdout] 468 |     pub p: [vec3; 3usize],
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `obb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:531:33
[INFO] [stdout]     |
[INFO] [stdout] 531 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:515:5
[INFO] [stdout]     |
[INFO] [stdout] 515 |     pub center: vec3,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:548:46
[INFO] [stdout]     |
[INFO] [stdout] 548 |     pub fn aabb_center(this: *const aabb) -> vec3;
[INFO] [stdout]     |                                              ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:577:33
[INFO] [stdout]     |
[INFO] [stdout] 577 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:583:33
[INFO] [stdout]     |
[INFO] [stdout] 583 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:589:33
[INFO] [stdout]     |
[INFO] [stdout] 589 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:595:33
[INFO] [stdout]     |
[INFO] [stdout] 595 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `aabb` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:601:33
[INFO] [stdout]     |
[INFO] [stdout] 601 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `Pitch` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:682:33
[INFO] [stdout]     |
[INFO] [stdout] 682 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: in this struct field
[INFO] [stdout]    --> src/ffi.rs:633:5
[INFO] [stdout]     |
[INFO] [stdout] 633 |     pub empty: aabb,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:539:5
[INFO] [stdout]     |
[INFO] [stdout] 539 |     pub min_x: f32,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `ffi::Ball` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:736:33
[INFO] [stdout]     |
[INFO] [stdout] 736 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:689:5
[INFO] [stdout]     |
[INFO] [stdout] 689 |     pub x: vec3,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:784:56
[INFO] [stdout]     |
[INFO] [stdout] 784 |     pub fn Car_pitch_surface_normal(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                                        ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:796:43
[INFO] [stdout]     |
[INFO] [stdout] 796 |     pub fn Car_forward(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                           ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:800:40
[INFO] [stdout]     |
[INFO] [stdout] 800 |     pub fn Car_left(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                        ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: `extern` block uses type `[f32; 3]`, which is not FFI-safe
[INFO] [stdout]    --> src/ffi.rs:804:38
[INFO] [stdout]     |
[INFO] [stdout] 804 |     pub fn Car_up(this: *mut Car) -> vec3;
[INFO] [stdout]     |                                      ^^^^ not FFI-safe
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider passing a pointer to the array
[INFO] [stdout]     = note: passing raw arrays by value is not FFI-safe
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the type `ffi::Car` does not permit being left uninitialized
[INFO] [stdout]    --> src/ffi.rs:846:33
[INFO] [stdout]     |
[INFO] [stdout] 846 |         let mut __bindgen_tmp = ::std::mem::uninitialized();
[INFO] [stdout]     |                                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                 |
[INFO] [stdout]     |                                 this code causes undefined behavior when executed
[INFO] [stdout]     |                                 help: use `MaybeUninit<T>` instead, and only call `assume_init` after initialization is done
[INFO] [stdout]     |
[INFO] [stdout] note: floats must be initialized (in this struct field)
[INFO] [stdout]    --> src/ffi.rs:756:5
[INFO] [stdout]     |
[INFO] [stdout] 756 |     pub x: vec3,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: linking with `cc` failed: exit status: 1
[INFO] [stdout]   |
[INFO] [stdout]   = note:  "cc" "-m64" "/tmp/rustcDLWEbK/symbols.o" "<3 object files omitted>" "-Wl,--as-needed" "-Wl,-Bdynamic" "-lbot_utils" "-Wl,-Bstatic" "<sysroot>/lib/rustlib/x86_64-unknown-linux-gnu/lib/{libtest-*,libgetopts-*,librustc_std_workspace_std-*}.rlib" "/opt/rustwide/target/debug/deps/{libnalgebra-beaa6cdc34102b4f,libalga-63c976032faaf9e6,librand-c3ad8886b2489528,librand_xorshift-14e9b45bdf59ad1d,librand_pcg-e9528f8dfe279d43,librand_hc-8c6bc8b58dca19e2,librand_chacha-8349b7f8676f64e7,librand_isaac-d86d4a8db0c58845,librand_core-a81fe7808f612aa2,librand_os-4bebd4bd4532edc0,liblibc-e2775a15e5abc6fd,librand_jitter-7a2811bedef919f4,librand_core-071c4ecd390d5ba3,libnum_rational-56d6aa2b94467ef4,libnum_integer-e58cbb3672c06b5a,libnum_complex-509e86d29448b63c,libmatrixmultiply-4a4b7026a6a016ee,librawpointer-a726d041f28ef5ec,libgeneric_array-5c60ac94642fd1b3,libtypenum-5940090dfdb1430b,libapprox-21f90bcdfbac99fe,libnum_traits-6770d34d96eb45d5,liblibm-ce6ce238ee049dec}.rlib" "<sysroot>/lib/rustlib/x86_64-unknown-linux-gnu/lib/{libstd-*,libpanic_unwind-*,libobject-*,libmemchr-*,libaddr2line-*,libgimli-*,libcfg_if-*,librustc_demangle-*,libstd_detect-*,libhashbrown-*,librustc_std_workspace_alloc-*,libminiz_oxide-*,libadler2-*,libunwind-*,liblibc-*,librustc_std_workspace_core-*,liballoc-*,libcore-*,libcompiler_builtins-*}.rlib" "-Wl,-Bdynamic" "-lgcc_s" "-lutil" "-lrt" "-lpthread" "-lm" "-ldl" "-lc" "-L" "/tmp/rustcDLWEbK/raw-dylibs" "-B<sysroot>/lib/rustlib/x86_64-unknown-linux-gnu/bin/gcc-ld" "-fuse-ld=lld" "-Wl,--eh-frame-hdr" "-Wl,-z,noexecstack" "-L" "/opt/rustwide/workdir/upstream" "-L" "<sysroot>/lib/rustlib/x86_64-unknown-linux-gnu/lib" "-o" "/opt/rustwide/target/debug/deps/chip-a4597a89059b4912" "-Wl,--gc-sections" "-pie" "-Wl,-z,relro,-z,now" "-nodefaultlibs"
[INFO] [stdout]   = note: some arguments are omitted. use `--verbose` to show all linker arguments
[INFO] [stdout]   = note: rust-lld: error: unable to find library -lbot_utils
[INFO] [stdout]           collect2: error: ld returned 1 exit status
[INFO] [stdout]           
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `chip` (lib test) due to 1 previous error; 41 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "26367d5b0440c95b9b1fe575a97e7314a83a8e8c940aa4d85558196affea4dad", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "26367d5b0440c95b9b1fe575a97e7314a83a8e8c940aa4d85558196affea4dad", kill_on_drop: false }`
[INFO] [stdout] 26367d5b0440c95b9b1fe575a97e7314a83a8e8c940aa4d85558196affea4dad
