[INFO] fetching crate slut 0.2.1...
[INFO] building slut-0.2.1 against master#ad85bc524b1ad696e42061ad8338d382dffbdbe5 for pr-146237-1
[INFO] extracting crate slut 0.2.1 into /workspace/builds/worker-0-tc1/source
[INFO] removed /workspace/builds/worker-0-tc1/source/rust-toolchain.toml
[INFO] started tweaking crates.io crate slut 0.2.1
[INFO] finished tweaking crates.io crate slut 0.2.1
[INFO] tweaked toml for crates.io crate slut 0.2.1 written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate slut 0.2.1 on toolchain ad85bc524b1ad696e42061ad8338d382dffbdbe5
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate slut 0.2.1 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 4d042be27642e16bd1c0c46513901d1a4deb9451d4f6f933fa60e4e348ae5d4e
[INFO] running `Command { std: "docker" "start" "-a" "4d042be27642e16bd1c0c46513901d1a4deb9451d4f6f933fa60e4e348ae5d4e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4d042be27642e16bd1c0c46513901d1a4deb9451d4f6f933fa60e4e348ae5d4e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4d042be27642e16bd1c0c46513901d1a4deb9451d4f6f933fa60e4e348ae5d4e", kill_on_drop: false }`
[INFO] [stdout] 4d042be27642e16bd1c0c46513901d1a4deb9451d4f6f933fa60e4e348ae5d4e
[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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 245c9f0c86ff60a74213837d9c7c7061a6339928290ba0039518adb08c379558
[INFO] running `Command { std: "docker" "start" "-a" "245c9f0c86ff60a74213837d9c7c7061a6339928290ba0039518adb08c379558", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.171
[INFO] [stderr]    Compiling getrandom v0.3.2
[INFO] [stderr]    Compiling zerocopy v0.8.24
[INFO] [stderr]    Compiling rand_core v0.9.3
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling rand_chacha v0.9.0
[INFO] [stderr]    Compiling rand v0.9.0
[INFO] [stderr]    Compiling slut v0.2.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: the feature `generic_const_exprs` is incomplete and may not be safe to use and/or cause compiler crashes
[INFO] [stdout]  --> src/lib.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | #![feature(generic_const_exprs)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: see issue #76560 <https://github.com/rust-lang/rust/issues/76560> for more information
[INFO] [stdout]   = note: `#[warn(incomplete_features)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::complex::c64`
[INFO] [stdout]  --> src/tensor/base.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::complex::c64;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::dimension::Dimension`
[INFO] [stdout]  --> src/tensor/base.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::dimension::Dimension;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/tensor/ops.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/tensor/scalar.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/tensor/natural.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fmt::*`
[INFO] [stdout]   --> src/tensor/mod.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub use fmt::*;
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/units.rs:99:31
[INFO] [stdout]    |
[INFO] [stdout] 99 |     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout]    |                               ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 99 -     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout] 99 +     type Dimension = dim_mul!(<L as Unit>::Dimension, (<R as Unit>::Dimension));
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/units.rs:99:57
[INFO] [stdout]    |
[INFO] [stdout] 99 |     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout]    |                                                         ^                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 99 -     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout] 99 +     type Dimension = dim_mul!((<L as Unit>::Dimension), <R as Unit>::Dimension);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/units.rs:121:31
[INFO] [stdout]     |
[INFO] [stdout] 121 |     type Dimension = dim_inv!((<T as Unit>::Dimension));
[INFO] [stdout]     |                               ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 121 -     type Dimension = dim_inv!((<T as Unit>::Dimension));
[INFO] [stdout] 121 +     type Dimension = dim_inv!(<T as Unit>::Dimension);
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::complex::c64`
[INFO] [stdout]  --> src/si.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::complex::c64;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]    --> src/si.rs:192:5
[INFO] [stdout]     |
[INFO] [stdout] 192 | use std::marker::PhantomData;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/si.rs:199:5
[INFO] [stdout]     |
[INFO] [stdout] 199 |     (dim_mul!(
[INFO] [stdout]     |     ^
[INFO] [stdout] ...
[INFO] [stdout] 202 |     ))
[INFO] [stdout]     |      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 199 ~     dim_mul!(
[INFO] [stdout] 200 |         Mass,
[INFO] [stdout] 201 |         (dim_inv!(Time))
[INFO] [stdout] 202 ~     )
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/si.rs:201:9
[INFO] [stdout]     |
[INFO] [stdout] 201 |         (dim_inv!(Time))
[INFO] [stdout]     |         ^              ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 201 -         (dim_inv!(Time))
[INFO] [stdout] 201 +         dim_inv!(Time)
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the feature `generic_arg_infer` has been stable since 1.89.0 and no longer requires an attribute to enable
[INFO] [stdout]  --> src/lib.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | #![feature(generic_arg_infer)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(stable_features)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:214:20
[INFO] [stdout]     |
[INFO] [stdout] 214 | pub type Vector<E: TensorElement, D, const N: usize> = Tensor<E, D, 1, N, 1>;
[INFO] [stdout]     |                  --^^^^^^^^^^^^^
[INFO] [stdout]     |                  | |
[INFO] [stdout]     |                  | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                  help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout]     = note: `#[warn(type_alias_bounds)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:216:20
[INFO] [stdout]     |
[INFO] [stdout] 216 | pub type Matrix<E: TensorElement, D, const N: usize, const M: usize> = Tensor<E, D, 1, N, M>;
[INFO] [stdout]     |                  --^^^^^^^^^^^^^
[INFO] [stdout]     |                  | |
[INFO] [stdout]     |                  | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                  help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:218:18
[INFO] [stdout]     |
[INFO] [stdout] 218 | pub type Vec2<E: TensorElement, D> = Vector<E, D, 2>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:220:18
[INFO] [stdout]     |
[INFO] [stdout] 220 | pub type Vec3<E: TensorElement, D> = Vector<E, D, 3>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:222:18
[INFO] [stdout]     |
[INFO] [stdout] 222 | pub type Vec4<E: TensorElement, D> = Vector<E, D, 4>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:224:18
[INFO] [stdout]     |
[INFO] [stdout] 224 | pub type Mat2<E: TensorElement, D> = Matrix<E, D, 2, 2>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:226:18
[INFO] [stdout]     |
[INFO] [stdout] 226 | pub type Mat3<E: TensorElement, D> = Matrix<E, D, 3, 3>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:228:18
[INFO] [stdout]     |
[INFO] [stdout] 228 | pub type Mat4<E: TensorElement, D> = Matrix<E, D, 4, 4>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]  --> src/tensor/scalar.rs:6:20
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub type Scalar<E: TensorElement, D> = Tensor<E, D, 1, 1, 1>;
[INFO] [stdout]   |                  --^^^^^^^^^^^^^
[INFO] [stdout]   |                  | |
[INFO] [stdout]   |                  | will not be checked at usage sites of the type alias
[INFO] [stdout]   |                  help: remove this bound
[INFO] [stdout]   |
[INFO] [stdout]   = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]           see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]   = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/tensor/fmt.rs:55:21
[INFO] [stdout]    |
[INFO] [stdout] 55 |                     write!(f, " {} ", data[idx]);
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 55 |                     let _ = write!(f, " {} ", data[idx]);
[INFO] [stdout]    |                     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 4.58s
[INFO] running `Command { std: "docker" "inspect" "245c9f0c86ff60a74213837d9c7c7061a6339928290ba0039518adb08c379558", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "245c9f0c86ff60a74213837d9c7c7061a6339928290ba0039518adb08c379558", kill_on_drop: false }`
[INFO] [stdout] 245c9f0c86ff60a74213837d9c7c7061a6339928290ba0039518adb08c379558
[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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+ad85bc524b1ad696e42061ad8338d382dffbdbe5" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 98fc852cb51e0fcf0bcf5a4ed7af38f48e424617ad03eed82d54b88d6a6288db
[INFO] running `Command { std: "docker" "start" "-a" "98fc852cb51e0fcf0bcf5a4ed7af38f48e424617ad03eed82d54b88d6a6288db", kill_on_drop: false }`
[INFO] [stdout] warning: the feature `generic_const_exprs` is incomplete and may not be safe to use and/or cause compiler crashes
[INFO] [stdout]  --> src/lib.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | #![feature(generic_const_exprs)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: see issue #76560 <https://github.com/rust-lang/rust/issues/76560> for more information
[INFO] [stdout]   = note: `#[warn(incomplete_features)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::complex::c64`
[INFO] [stdout]  --> src/tensor/base.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::complex::c64;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::dimension::Dimension`
[INFO] [stdout]  --> src/tensor/base.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::dimension::Dimension;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/tensor/ops.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/tensor/scalar.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/tensor/natural.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fmt::*`
[INFO] [stdout]   --> src/tensor/mod.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub use fmt::*;
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/units.rs:99:31
[INFO] [stdout]    |
[INFO] [stdout] 99 |     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout]    |                               ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 99 -     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout] 99 +     type Dimension = dim_mul!(<L as Unit>::Dimension, (<R as Unit>::Dimension));
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/units.rs:99:57
[INFO] [stdout]    |
[INFO] [stdout] 99 |     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout]    |                                                         ^                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 99 -     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout] 99 +     type Dimension = dim_mul!((<L as Unit>::Dimension), <R as Unit>::Dimension);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/units.rs:121:31
[INFO] [stdout]     |
[INFO] [stdout] 121 |     type Dimension = dim_inv!((<T as Unit>::Dimension));
[INFO] [stdout]     |                               ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 121 -     type Dimension = dim_inv!((<T as Unit>::Dimension));
[INFO] [stdout] 121 +     type Dimension = dim_inv!(<T as Unit>::Dimension);
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::complex::c64`
[INFO] [stdout]  --> src/si.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::complex::c64;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]    --> src/si.rs:192:5
[INFO] [stdout]     |
[INFO] [stdout] 192 | use std::marker::PhantomData;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/si.rs:199:5
[INFO] [stdout]     |
[INFO] [stdout] 199 |     (dim_mul!(
[INFO] [stdout]     |     ^
[INFO] [stdout] ...
[INFO] [stdout] 202 |     ))
[INFO] [stdout]     |      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 199 ~     dim_mul!(
[INFO] [stdout] 200 |         Mass,
[INFO] [stdout] 201 |         (dim_inv!(Time))
[INFO] [stdout] 202 ~     )
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/si.rs:201:9
[INFO] [stdout]     |
[INFO] [stdout] 201 |         (dim_inv!(Time))
[INFO] [stdout]     |         ^              ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 201 -         (dim_inv!(Time))
[INFO] [stdout] 201 +         dim_inv!(Time)
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the feature `generic_arg_infer` has been stable since 1.89.0 and no longer requires an attribute to enable
[INFO] [stdout]  --> src/lib.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | #![feature(generic_arg_infer)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(stable_features)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling slut v0.2.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:214:20
[INFO] [stdout]     |
[INFO] [stdout] 214 | pub type Vector<E: TensorElement, D, const N: usize> = Tensor<E, D, 1, N, 1>;
[INFO] [stdout]     |                  --^^^^^^^^^^^^^
[INFO] [stdout]     |                  | |
[INFO] [stdout]     |                  | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                  help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout]     = note: `#[warn(type_alias_bounds)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:216:20
[INFO] [stdout]     |
[INFO] [stdout] 216 | pub type Matrix<E: TensorElement, D, const N: usize, const M: usize> = Tensor<E, D, 1, N, M>;
[INFO] [stdout]     |                  --^^^^^^^^^^^^^
[INFO] [stdout]     |                  | |
[INFO] [stdout]     |                  | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                  help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:218:18
[INFO] [stdout]     |
[INFO] [stdout] 218 | pub type Vec2<E: TensorElement, D> = Vector<E, D, 2>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:220:18
[INFO] [stdout]     |
[INFO] [stdout] 220 | pub type Vec3<E: TensorElement, D> = Vector<E, D, 3>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:222:18
[INFO] [stdout]     |
[INFO] [stdout] 222 | pub type Vec4<E: TensorElement, D> = Vector<E, D, 4>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:224:18
[INFO] [stdout]     |
[INFO] [stdout] 224 | pub type Mat2<E: TensorElement, D> = Matrix<E, D, 2, 2>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:226:18
[INFO] [stdout]     |
[INFO] [stdout] 226 | pub type Mat3<E: TensorElement, D> = Matrix<E, D, 3, 3>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:228:18
[INFO] [stdout]     |
[INFO] [stdout] 228 | pub type Mat4<E: TensorElement, D> = Matrix<E, D, 4, 4>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]  --> src/tensor/scalar.rs:6:20
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub type Scalar<E: TensorElement, D> = Tensor<E, D, 1, 1, 1>;
[INFO] [stdout]   |                  --^^^^^^^^^^^^^
[INFO] [stdout]   |                  | |
[INFO] [stdout]   |                  | will not be checked at usage sites of the type alias
[INFO] [stdout]   |                  help: remove this bound
[INFO] [stdout]   |
[INFO] [stdout]   = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]           see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]   = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/tensor/fmt.rs:55:21
[INFO] [stdout]    |
[INFO] [stdout] 55 |                     write!(f, " {} ", data[idx]);
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 55 |                     let _ = write!(f, " {} ", data[idx]);
[INFO] [stdout]    |                     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the feature `generic_const_exprs` is incomplete and may not be safe to use and/or cause compiler crashes
[INFO] [stdout]  --> src/lib.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | #![feature(generic_const_exprs)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: see issue #76560 <https://github.com/rust-lang/rust/issues/76560> for more information
[INFO] [stdout]   = note: `#[warn(incomplete_features)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::complex::c64`
[INFO] [stdout]  --> src/tensor/base.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::complex::c64;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::dimension::Dimension`
[INFO] [stdout]  --> src/tensor/base.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::dimension::Dimension;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/tensor/ops.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/tensor/scalar.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]  --> src/tensor/natural.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::marker::PhantomData;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `fmt::*`
[INFO] [stdout]   --> src/tensor/mod.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub use fmt::*;
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/units.rs:99:31
[INFO] [stdout]    |
[INFO] [stdout] 99 |     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout]    |                               ^                      ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 99 -     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout] 99 +     type Dimension = dim_mul!(<L as Unit>::Dimension, (<R as Unit>::Dimension));
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/units.rs:99:57
[INFO] [stdout]    |
[INFO] [stdout] 99 |     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout]    |                                                         ^                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 99 -     type Dimension = dim_mul!((<L as Unit>::Dimension), (<R as Unit>::Dimension));
[INFO] [stdout] 99 +     type Dimension = dim_mul!((<L as Unit>::Dimension), <R as Unit>::Dimension);
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/units.rs:121:31
[INFO] [stdout]     |
[INFO] [stdout] 121 |     type Dimension = dim_inv!((<T as Unit>::Dimension));
[INFO] [stdout]     |                               ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 121 -     type Dimension = dim_inv!((<T as Unit>::Dimension));
[INFO] [stdout] 121 +     type Dimension = dim_inv!(<T as Unit>::Dimension);
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::complex::c64`
[INFO] [stdout]  --> src/si.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::complex::c64;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::marker::PhantomData`
[INFO] [stdout]    --> src/si.rs:192:5
[INFO] [stdout]     |
[INFO] [stdout] 192 | use std::marker::PhantomData;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/si.rs:199:5
[INFO] [stdout]     |
[INFO] [stdout] 199 |     (dim_mul!(
[INFO] [stdout]     |     ^
[INFO] [stdout] ...
[INFO] [stdout] 202 |     ))
[INFO] [stdout]     |      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 199 ~     dim_mul!(
[INFO] [stdout] 200 |         Mass,
[INFO] [stdout] 201 |         (dim_inv!(Time))
[INFO] [stdout] 202 ~     )
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/si.rs:201:9
[INFO] [stdout]     |
[INFO] [stdout] 201 |         (dim_inv!(Time))
[INFO] [stdout]     |         ^              ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 201 -         (dim_inv!(Time))
[INFO] [stdout] 201 +         dim_inv!(Time)
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/lib.rs:110:12
[INFO] [stdout]     |
[INFO] [stdout] 110 |         if (vel1 == vel2) {
[INFO] [stdout]     |            ^            ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 110 -         if (vel1 == vel2) {
[INFO] [stdout] 110 +         if vel1 == vel2 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/lib.rs:120:12
[INFO] [stdout]     |
[INFO] [stdout] 120 |         if (mass == mass2) {
[INFO] [stdout]     |            ^             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 120 -         if (mass == mass2) {
[INFO] [stdout] 120 +         if mass == mass2 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/lib.rs:272:19
[INFO] [stdout]     |
[INFO] [stdout] 272 |             ip!(a,(b.scale(alpha) + d)),
[INFO] [stdout]     |                   ^                  ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 272 -             ip!(a,(b.scale(alpha) + d)),
[INFO] [stdout] 272 +             ip!(a,b.scale(alpha) + d),
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the feature `generic_arg_infer` has been stable since 1.89.0 and no longer requires an attribute to enable
[INFO] [stdout]  --> src/lib.rs:3:12
[INFO] [stdout]   |
[INFO] [stdout] 3 | #![feature(generic_arg_infer)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(stable_features)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> src/lib.rs:296:13
[INFO] [stdout]     |
[INFO] [stdout] 296 |         let e = dless!((1.0, 2.0).complex());
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:214:20
[INFO] [stdout]     |
[INFO] [stdout] 214 | pub type Vector<E: TensorElement, D, const N: usize> = Tensor<E, D, 1, N, 1>;
[INFO] [stdout]     |                  --^^^^^^^^^^^^^
[INFO] [stdout]     |                  | |
[INFO] [stdout]     |                  | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                  help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout]     = note: `#[warn(type_alias_bounds)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:216:20
[INFO] [stdout]     |
[INFO] [stdout] 216 | pub type Matrix<E: TensorElement, D, const N: usize, const M: usize> = Tensor<E, D, 1, N, M>;
[INFO] [stdout]     |                  --^^^^^^^^^^^^^
[INFO] [stdout]     |                  | |
[INFO] [stdout]     |                  | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                  help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:218:18
[INFO] [stdout]     |
[INFO] [stdout] 218 | pub type Vec2<E: TensorElement, D> = Vector<E, D, 2>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:220:18
[INFO] [stdout]     |
[INFO] [stdout] 220 | pub type Vec3<E: TensorElement, D> = Vector<E, D, 3>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:222:18
[INFO] [stdout]     |
[INFO] [stdout] 222 | pub type Vec4<E: TensorElement, D> = Vector<E, D, 4>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:224:18
[INFO] [stdout]     |
[INFO] [stdout] 224 | pub type Mat2<E: TensorElement, D> = Matrix<E, D, 2, 2>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:226:18
[INFO] [stdout]     |
[INFO] [stdout] 226 | pub type Mat3<E: TensorElement, D> = Matrix<E, D, 3, 3>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]    --> src/tensor/base.rs:228:18
[INFO] [stdout]     |
[INFO] [stdout] 228 | pub type Mat4<E: TensorElement, D> = Matrix<E, D, 4, 4>;
[INFO] [stdout]     |                --^^^^^^^^^^^^^
[INFO] [stdout]     |                | |
[INFO] [stdout]     |                | will not be checked at usage sites of the type alias
[INFO] [stdout]     |                help: remove this bound
[INFO] [stdout]     |
[INFO] [stdout]     = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]             see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]     = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: bounds on generic parameters in type aliases are not enforced
[INFO] [stdout]  --> src/tensor/scalar.rs:6:20
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub type Scalar<E: TensorElement, D> = Tensor<E, D, 1, 1, 1>;
[INFO] [stdout]   |                  --^^^^^^^^^^^^^
[INFO] [stdout]   |                  | |
[INFO] [stdout]   |                  | will not be checked at usage sites of the type alias
[INFO] [stdout]   |                  help: remove this bound
[INFO] [stdout]   |
[INFO] [stdout]   = note: this is a known limitation of the type checker that may be lifted in a future edition.
[INFO] [stdout]           see issue #112792 <https://github.com/rust-lang/rust/issues/112792> for more information
[INFO] [stdout]   = help: add `#![feature(lazy_type_alias)]` to the crate attributes to enable the desired semantics
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]   --> src/tensor/fmt.rs:55:21
[INFO] [stdout]    |
[INFO] [stdout] 55 |                     write!(f, " {} ", data[idx]);
[INFO] [stdout]    |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 55 |                     let _ = write!(f, " {} ", data[idx]);
[INFO] [stdout]    |                     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.21s
[INFO] running `Command { std: "docker" "inspect" "98fc852cb51e0fcf0bcf5a4ed7af38f48e424617ad03eed82d54b88d6a6288db", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "98fc852cb51e0fcf0bcf5a4ed7af38f48e424617ad03eed82d54b88d6a6288db", kill_on_drop: false }`
[INFO] [stdout] 98fc852cb51e0fcf0bcf5a4ed7af38f48e424617ad03eed82d54b88d6a6288db
