[INFO] cloning repository https://github.com/stavenko/my-keyboard
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/stavenko/my-keyboard" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fstavenko%2Fmy-keyboard", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fstavenko%2Fmy-keyboard'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] ecf7ee69f4beb18b37f803b65a4f19b9f45cc913
[INFO] checking stavenko/my-keyboard against master#3139ff09e9d07f7700f8d15ed25a231e29c43627 for pr-121848-3
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fstavenko%2Fmy-keyboard" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/stavenko/my-keyboard on toolchain 3139ff09e9d07f7700f8d15ed25a231e29c43627
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+3139ff09e9d07f7700f8d15ed25a231e29c43627" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/stavenko/my-keyboard
[INFO] finished tweaking git repo https://github.com/stavenko/my-keyboard
[INFO] tweaked toml for git repo https://github.com/stavenko/my-keyboard written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] crate git repo https://github.com/stavenko/my-keyboard 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" "+3139ff09e9d07f7700f8d15ed25a231e29c43627" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded rust_decimal_macros v1.34.2
[INFO] [stderr]   Downloaded stl_io v0.7.0
[INFO] [stderr]   Downloaded bytecheck_derive v0.6.11
[INFO] [stderr]   Downloaded nalgebra-macros v0.2.1
[INFO] [stderr]   Downloaded ptr_meta_derive v0.1.4
[INFO] [stderr]   Downloaded ptr_meta v0.1.4
[INFO] [stderr]   Downloaded seahash v4.1.0
[INFO] [stderr]   Downloaded seq-macro v0.3.5
[INFO] [stderr]   Downloaded bytecheck v0.6.11
[INFO] [stderr]   Downloaded rend v0.4.1
[INFO] [stderr]   Downloaded either v1.12.0
[INFO] [stderr]   Downloaded rkyv_derive v0.7.43
[INFO] [stderr]   Downloaded simdutf8 v0.1.4
[INFO] [stderr]   Downloaded rustc-serialize v0.3.25
[INFO] [stderr]   Downloaded cdt v0.1.0
[INFO] [stderr]   Downloaded cc v1.0.98
[INFO] [stderr]   Downloaded geometry-predicates v0.3.0
[INFO] [stderr]   Downloaded serde_json v1.0.112
[INFO] [stderr]   Downloaded wide v0.7.14
[INFO] [stderr]   Downloaded clap_builder v4.4.11
[INFO] [stderr]   Downloaded winnow v0.5.35
[INFO] [stderr]   Downloaded rust_decimal v1.35.0
[INFO] [stderr]   Downloaded simba v0.8.1
[INFO] [stderr]   Downloaded borsh v1.3.1
[INFO] [stderr]   Downloaded rkyv v0.7.43
[INFO] [stderr]   Downloaded syn v2.0.66
[INFO] [stderr]   Downloaded clap v4.4.11
[INFO] [stderr]   Downloaded rstar v0.12.0
[INFO] [stderr]   Downloaded bytemuck v1.14.1
[INFO] [stderr]   Downloaded proc-macro2 v1.0.84
[INFO] [stderr]   Downloaded nalgebra v0.32.3
[INFO] [stderr]   Downloaded ord_subset v3.1.1
[INFO] [stderr]   Downloaded borsh-derive v1.3.1
[INFO] [stderr]   Downloaded decimal v2.1.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:923055f121b5182466d55868a8b05e67af8ba4a3a3f6bad814e953ca3cd3ac2a" "/opt/rustwide/cargo-home/bin/cargo" "+3139ff09e9d07f7700f8d15ed25a231e29c43627" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 55a2fed8804aac1cfc22d8af0ed81f6c23eabc2b0ff3b8b73a52a5c711017f57
[INFO] running `Command { std: "docker" "start" "-a" "55a2fed8804aac1cfc22d8af0ed81f6c23eabc2b0ff3b8b73a52a5c711017f57", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "55a2fed8804aac1cfc22d8af0ed81f6c23eabc2b0ff3b8b73a52a5c711017f57", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "55a2fed8804aac1cfc22d8af0ed81f6c23eabc2b0ff3b8b73a52a5c711017f57", kill_on_drop: false }`
[INFO] [stdout] 55a2fed8804aac1cfc22d8af0ed81f6c23eabc2b0ff3b8b73a52a5c711017f57
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:923055f121b5182466d55868a8b05e67af8ba4a3a3f6bad814e953ca3cd3ac2a" "/opt/rustwide/cargo-home/bin/cargo" "+3139ff09e9d07f7700f8d15ed25a231e29c43627" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] fc6ba9f9814c1cece4da5e23881e1946ce8ef67b30bf8f2f20d114cf59a3225d
[INFO] running `Command { std: "docker" "start" "-a" "fc6ba9f9814c1cece4da5e23881e1946ce8ef67b30bf8f2f20d114cf59a3225d", kill_on_drop: false }`
[INFO] [stderr]    Compiling libm v0.2.8
[INFO] [stderr]    Compiling proc-macro2 v1.0.84
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling serde v1.0.196
[INFO] [stderr]    Compiling cc v1.0.98
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]     Checking bytemuck v1.14.1
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]     Checking utf8parse v0.2.1
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]    Compiling matrixmultiply v0.3.8
[INFO] [stderr]     Checking ord_subset v3.1.1
[INFO] [stderr]    Compiling rust_decimal v1.35.0
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]     Checking anstyle-parse v0.2.3
[INFO] [stderr]     Checking anstyle-query v1.0.2
[INFO] [stderr]     Checking colorchoice v1.0.0
[INFO] [stderr]     Checking anstyle v1.0.4
[INFO] [stderr]    Compiling heapless v0.8.0
[INFO] [stderr]     Checking safe_arch v0.7.1
[INFO] [stderr]    Compiling thiserror v1.0.56
[INFO] [stderr]     Checking rustc-serialize v0.3.25
[INFO] [stderr]    Compiling typenum v1.17.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking hash32 v0.3.1
[INFO] [stderr]     Checking rawpointer v0.2.1
[INFO] [stderr]     Checking stable_deref_trait v1.2.0
[INFO] [stderr]     Checking anstream v0.6.11
[INFO] [stderr]    Compiling arrayvec v0.7.4
[INFO] [stderr]     Checking clap_lex v0.6.0
[INFO] [stderr]    Compiling anyhow v1.0.79
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking clap_builder v4.4.11
[INFO] [stderr]     Checking wide v0.7.14
[INFO] [stderr]     Checking either v1.12.0
[INFO] [stderr]     Checking geometry-predicates v0.3.0
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking uuid v1.8.0
[INFO] [stderr]    Compiling seq-macro v0.3.5
[INFO] [stderr]     Checking itertools v0.12.1
[INFO] [stderr]    Compiling quote v1.0.35
[INFO] [stderr]     Checking tap v1.0.1
[INFO] [stderr]     Checking assert_matches v1.5.0
[INFO] [stderr]    Compiling syn v2.0.66
[INFO] [stderr]    Compiling decimal v2.1.0
[INFO] [stderr]     Checking num-complex v0.4.4
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking float-cmp v0.9.0
[INFO] [stderr]     Checking rstar v0.12.0
[INFO] [stderr]     Checking stl_io v0.7.0
[INFO] [stderr]    Compiling rust_decimal_macros v1.34.2
[INFO] [stderr]     Checking simba v0.8.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.56
[INFO] [stderr]    Compiling clap_derive v4.4.7
[INFO] [stderr]    Compiling nalgebra-macros v0.2.1
[INFO] [stderr]     Checking cdt v0.1.0
[INFO] [stderr]     Checking clap v4.4.11
[INFO] [stderr]     Checking nalgebra v0.32.3
[INFO] [stderr]     Checking geometry v0.1.0 (/opt/rustwide/workdir/geometry)
[INFO] [stdout] warning: unused import: `ComplexField`
[INFO] [stdout]  --> geometry/src/indexes/aabb.rs:1:16
[INFO] [stdout]   |
[INFO] [stdout] 1 | use nalgebra::{ComplexField, Vector3};
[INFO] [stdout]   |                ^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt::format`
[INFO] [stdout]  --> geometry/src/indexes/geo_index/index.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fmt::format;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AABB`
[INFO] [stdout]   --> geometry/src/indexes/geo_index/index.rs:14:20
[INFO] [stdout]    |
[INFO] [stdout] 14 | use rstar::{RTree, AABB};
[INFO] [stdout]    |                    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashMap`
[INFO] [stdout]  --> geometry/src/indexes/geo_index/mesh.rs:2:19
[INFO] [stdout]   |
[INFO] [stdout] 2 |     collections::{HashMap, HashSet},
[INFO] [stdout]   |                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `geo_index::poly::Side`, `planar::polygon::Polygon`, and `vertex_index::PtId`
[INFO] [stdout]   --> geometry/src/indexes/geo_index/mesh.rs:13:15
[INFO] [stdout]    |
[INFO] [stdout] 13 |     indexes::{geo_index::poly::Side, vertex_index::PtId},
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 14 |     planar::polygon::Polygon,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `format` and `path::Path`
[INFO] [stdout]  --> geometry/src/indexes/geo_index/poly.rs:3:17
[INFO] [stdout]   |
[INFO] [stdout] 3 |     fmt::{self, format},
[INFO] [stdout]   |                 ^^^^^^
[INFO] [stdout] 4 |     path::Path,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `primitives_relation`
[INFO] [stdout]  --> geometry/src/indexes/octree.rs:1:34
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::{indexes::aabb::Aabb, primitives_relation};
[INFO] [stdout]   |                                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Bounded` and `Zero`
[INFO] [stdout]  --> geometry/src/indexes/octree.rs:4:18
[INFO] [stdout]   |
[INFO] [stdout] 4 | use num_traits::{Bounded, Zero};
[INFO] [stdout]   |                  ^^^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ComplexField`
[INFO] [stdout]  --> geometry/src/indexes/aabb.rs:1:16
[INFO] [stdout]   |
[INFO] [stdout] 1 | use nalgebra::{ComplexField, Vector3};
[INFO] [stdout]   |                ^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt::format`
[INFO] [stdout]  --> geometry/src/indexes/geo_index/index.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fmt::format;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AABB`
[INFO] [stdout]   --> geometry/src/indexes/geo_index/index.rs:14:20
[INFO] [stdout]    |
[INFO] [stdout] 14 | use rstar::{RTree, AABB};
[INFO] [stdout]    |                    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashMap`
[INFO] [stdout]  --> geometry/src/indexes/geo_index/mesh.rs:2:19
[INFO] [stdout]   |
[INFO] [stdout] 2 |     collections::{HashMap, HashSet},
[INFO] [stdout]   |                   ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `geo_index::poly::Side`, `planar::polygon::Polygon`, and `vertex_index::PtId`
[INFO] [stdout]   --> geometry/src/indexes/geo_index/mesh.rs:13:15
[INFO] [stdout]    |
[INFO] [stdout] 13 |     indexes::{geo_index::poly::Side, vertex_index::PtId},
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 14 |     planar::polygon::Polygon,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `format` and `path::Path`
[INFO] [stdout]  --> geometry/src/indexes/geo_index/poly.rs:3:17
[INFO] [stdout]   |
[INFO] [stdout] 3 |     fmt::{self, format},
[INFO] [stdout]   |                 ^^^^^^
[INFO] [stdout] 4 |     path::Path,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `primitives_relation`
[INFO] [stdout]  --> geometry/src/indexes/octree.rs:1:34
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::{indexes::aabb::Aabb, primitives_relation};
[INFO] [stdout]   |                                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Bounded` and `Zero`
[INFO] [stdout]  --> geometry/src/indexes/octree.rs:4:18
[INFO] [stdout]   |
[INFO] [stdout] 4 | use num_traits::{Bounded, Zero};
[INFO] [stdout]   |                  ^^^^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]    --> geometry/src/decimal.rs:270:19
[INFO] [stdout]     |
[INFO] [stdout] 270 |     fn powi(self, n: i32) -> Self {
[INFO] [stdout]     |                   ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]    --> geometry/src/decimal.rs:270:19
[INFO] [stdout]     |
[INFO] [stdout] 270 |     fn powi(self, n: i32) -> Self {
[INFO] [stdout]     |                   ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> geometry/src/indexes/aabb.rs:121:13
[INFO] [stdout]     |
[INFO] [stdout] 121 |         for i in 0..3 {
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_created`
[INFO] [stdout]    --> geometry/src/indexes/geo_index/index.rs:318:30
[INFO] [stdout]     |
[INFO] [stdout] 318 |             .map(|(child_id, is_created)| {
[INFO] [stdout]     |                              ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_created`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> geometry/src/indexes/aabb.rs:121:13
[INFO] [stdout]     |
[INFO] [stdout] 121 |         for i in 0..3 {
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_created`
[INFO] [stdout]    --> geometry/src/indexes/geo_index/index.rs:318:30
[INFO] [stdout]     |
[INFO] [stdout] 318 |             .map(|(child_id, is_created)| {
[INFO] [stdout]     |                              ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_created`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tool_ribs`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1621:13
[INFO] [stdout]      |
[INFO] [stdout] 1621 |         let tool_ribs = self.polygons[&tool_id]
[INFO] [stdout]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tool_ribs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `src_ribs`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1628:17
[INFO] [stdout]      |
[INFO] [stdout] 1628 |             let src_ribs = self.polygons[src_id]
[INFO] [stdout]      |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_src_ribs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1943:49
[INFO] [stdout]      |
[INFO] [stdout] 1943 | ...                   if let Some(b) = self.poly_split_debug.get(&poly_id).cloned() {
[INFO] [stdout]      |                                   ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1968:49
[INFO] [stdout]      |
[INFO] [stdout] 1968 | ...                   if let Some(b) = self.poly_split_debug.get(&poly_id).cloned() {
[INFO] [stdout]      |                                   ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1606:13
[INFO] [stdout]      |
[INFO] [stdout] 1606 |         let mut tool_aabb = self.polygons[&tool_id].aabb;
[INFO] [stdout]      |             ----^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tool_ribs`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1621:13
[INFO] [stdout]      |
[INFO] [stdout] 1621 |         let tool_ribs = self.polygons[&tool_id]
[INFO] [stdout]      |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tool_ribs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `src_ribs`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1628:17
[INFO] [stdout]      |
[INFO] [stdout] 1628 |             let src_ribs = self.polygons[src_id]
[INFO] [stdout]      |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_src_ribs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1943:49
[INFO] [stdout]      |
[INFO] [stdout] 1943 | ...                   if let Some(b) = self.poly_split_debug.get(&poly_id).cloned() {
[INFO] [stdout]      |                                   ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1968:49
[INFO] [stdout]      |
[INFO] [stdout] 1968 | ...                   if let Some(b) = self.poly_split_debug.get(&poly_id).cloned() {
[INFO] [stdout]      |                                   ^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1606:13
[INFO] [stdout]      |
[INFO] [stdout] 1606 |         let mut tool_aabb = self.polygons[&tool_id].aabb;
[INFO] [stdout]      |             ----^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rib_id`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:2791:29
[INFO] [stdout]      |
[INFO] [stdout] 2791 |                 if let Some(rib_id) = both_pt_ribs.first().and_then(|rib_id| {
[INFO] [stdout]      |                             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_rib_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sr`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:2937:22
[INFO] [stdout]      |
[INFO] [stdout] 2937 |             .filter(|sr| {
[INFO] [stdout]      |                      ^^ help: if this is intentional, prefix it with an underscore: `_sr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rib_id`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:2791:29
[INFO] [stdout]      |
[INFO] [stdout] 2791 |                 if let Some(rib_id) = both_pt_ribs.first().and_then(|rib_id| {
[INFO] [stdout]      |                             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_rib_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sr`
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:2937:22
[INFO] [stdout]      |
[INFO] [stdout] 2937 |             .filter(|sr| {
[INFO] [stdout]      |                      ^^ help: if this is intentional, prefix it with an underscore: `_sr`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> geometry/src/shapes/cylinder.rs:126:14
[INFO] [stdout]     |
[INFO] [stdout] 126 |         for (i, p) in self.render().into_iter().enumerate() {
[INFO] [stdout]     |              ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1378:8
[INFO] [stdout]      |
[INFO] [stdout] 72   | impl GeoIndex {
[INFO] [stdout]      | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1378 |     fn load_segment(&self, seg: &Seg) -> Segment {
[INFO] [stdout]      |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1504 |     pub(crate) fn get_mesh_vertices(&self, tool: MeshId) -> HashSet<PtId> {
[INFO] [stdout]      |                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2087 |     fn find_ribs_on_same_line(&self, rib_id: RibId, poly_id: PolyId) -> Vec<RibId> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2110 |     fn split_ribs_on_same_line(&mut self, one_rib: RibId, other_rib: RibId) -> Vec<RibId> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2264 |     pub(crate) fn mesh_borders(&self, mesh_id: MeshId) -> Vec<Vec<Seg>> {
[INFO] [stdout]      |                   ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2288 |     pub(crate) fn collect_split_chains(&self, mesh_id: MeshId, tool: MeshId) -> Vec<Vec<Seg>> {
[INFO] [stdout]      |                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2325 |     pub(crate) fn collect_common_chains(&self, mesh_id: MeshId, tool: MeshId) -> Vec<Vec<Seg>> {
[INFO] [stdout]      |                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2506 |     fn get_polygon_root(&self, poly_id: PolyId) -> Option<PolyId> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `polygons`, `get_mesh_polygons_for_rib`, `get_poly_ref`, `get_rib_ref`, and `center` are never used
[INFO] [stdout]   --> geometry/src/indexes/geo_index/mesh.rs:51:19
[INFO] [stdout]    |
[INFO] [stdout] 50 | impl<'a> MeshRef<'a> {
[INFO] [stdout]    | -------------------- methods in this implementation
[INFO] [stdout] 51 |     pub(crate) fn polygons(&self) -> impl Iterator<Item = PolyRef<'a>> + 'a {
[INFO] [stdout]    |                   ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 55 |     pub(crate) fn get_mesh_polygons_for_rib(&self, rib: RibId) -> Vec<PolyId> {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     pub(crate) fn get_poly_ref(&self, poly1: PolyId) -> PolyRef<'a> {
[INFO] [stdout]    |                   ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 80 |     pub(crate) fn get_rib_ref(&self, rib: RibId) -> RibRef<'a> {
[INFO] [stdout]    |                   ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 87 |     pub(crate) fn center(&self) -> Vector3<Dec> {
[INFO] [stdout]    |                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `len` and `set_aabb` are never used
[INFO] [stdout]    --> geometry/src/indexes/octree.rs:223:8
[INFO] [stdout]     |
[INFO] [stdout] 55  | impl<T: Clone> Octree<T> {
[INFO] [stdout]     | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 223 |     fn len(&self) -> usize {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 285 |     pub(crate) fn set_aabb(&mut self, aabb: Aabb) {
[INFO] [stdout]     |                   ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_initial_bb` is never used
[INFO] [stdout]   --> geometry/src/indexes/vertex_index.rs:85:19
[INFO] [stdout]    |
[INFO] [stdout] 35 | impl VertexIndex {
[INFO] [stdout]    | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 85 |     pub(crate) fn set_initial_bb(&mut self, aabb: super::aabb::Aabb) {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_intersection_params_seg_ref` is never used
[INFO] [stdout]   --> geometry/src/linear/line.rs:15:19
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl Line {
[INFO] [stdout]    | --------- method in this implementation
[INFO] [stdout] 15 |     pub(crate) fn get_intersection_params_seg_ref(&self, to: &SegRef<'_>) -> Option<(Dec, Dec)> {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 24 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> geometry/src/shapes/cylinder.rs:126:14
[INFO] [stdout]     |
[INFO] [stdout] 126 |         for (i, p) in self.render().into_iter().enumerate() {
[INFO] [stdout]     |              ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]     --> geometry/src/indexes/geo_index/index.rs:1378:8
[INFO] [stdout]      |
[INFO] [stdout] 72   | impl GeoIndex {
[INFO] [stdout]      | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1378 |     fn load_segment(&self, seg: &Seg) -> Segment {
[INFO] [stdout]      |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1504 |     pub(crate) fn get_mesh_vertices(&self, tool: MeshId) -> HashSet<PtId> {
[INFO] [stdout]      |                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2087 |     fn find_ribs_on_same_line(&self, rib_id: RibId, poly_id: PolyId) -> Vec<RibId> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2110 |     fn split_ribs_on_same_line(&mut self, one_rib: RibId, other_rib: RibId) -> Vec<RibId> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2264 |     pub(crate) fn mesh_borders(&self, mesh_id: MeshId) -> Vec<Vec<Seg>> {
[INFO] [stdout]      |                   ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2288 |     pub(crate) fn collect_split_chains(&self, mesh_id: MeshId, tool: MeshId) -> Vec<Vec<Seg>> {
[INFO] [stdout]      |                   ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2325 |     pub(crate) fn collect_common_chains(&self, mesh_id: MeshId, tool: MeshId) -> Vec<Vec<Seg>> {
[INFO] [stdout]      |                   ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2506 |     fn get_polygon_root(&self, poly_id: PolyId) -> Option<PolyId> {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `polygons`, `get_mesh_polygons_for_rib`, `get_poly_ref`, `get_rib_ref`, and `center` are never used
[INFO] [stdout]   --> geometry/src/indexes/geo_index/mesh.rs:51:19
[INFO] [stdout]    |
[INFO] [stdout] 50 | impl<'a> MeshRef<'a> {
[INFO] [stdout]    | -------------------- methods in this implementation
[INFO] [stdout] 51 |     pub(crate) fn polygons(&self) -> impl Iterator<Item = PolyRef<'a>> + 'a {
[INFO] [stdout]    |                   ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 55 |     pub(crate) fn get_mesh_polygons_for_rib(&self, rib: RibId) -> Vec<PolyId> {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     pub(crate) fn get_poly_ref(&self, poly1: PolyId) -> PolyRef<'a> {
[INFO] [stdout]    |                   ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 80 |     pub(crate) fn get_rib_ref(&self, rib: RibId) -> RibRef<'a> {
[INFO] [stdout]    |                   ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 87 |     pub(crate) fn center(&self) -> Vector3<Dec> {
[INFO] [stdout]    |                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `len` and `set_aabb` are never used
[INFO] [stdout]    --> geometry/src/indexes/octree.rs:223:8
[INFO] [stdout]     |
[INFO] [stdout] 55  | impl<T: Clone> Octree<T> {
[INFO] [stdout]     | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 223 |     fn len(&self) -> usize {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 285 |     pub(crate) fn set_aabb(&mut self, aabb: Aabb) {
[INFO] [stdout]     |                   ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_initial_bb` is never used
[INFO] [stdout]   --> geometry/src/indexes/vertex_index.rs:85:19
[INFO] [stdout]    |
[INFO] [stdout] 35 | impl VertexIndex {
[INFO] [stdout]    | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 85 |     pub(crate) fn set_initial_bb(&mut self, aabb: super::aabb::Aabb) {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_intersection_params_seg_ref` is never used
[INFO] [stdout]   --> geometry/src/linear/line.rs:15:19
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl Line {
[INFO] [stdout]    | --------- method in this implementation
[INFO] [stdout] 15 |     pub(crate) fn get_intersection_params_seg_ref(&self, to: &SegRef<'_>) -> Option<(Dec, Dec)> {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 24 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking keyboard v0.1.0 (/opt/rustwide/workdir/keyboard)
[INFO] [stdout] warning: unused import: `OpenOptions`
[INFO] [stdout]  --> geometry/examples/booleans/main.rs:3:16
[INFO] [stdout]   |
[INFO] [stdout] 3 |     fs::{self, OpenOptions},
[INFO] [stdout]   |                ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> geometry/examples/booleans/main.rs:19:14
[INFO] [stdout]    |
[INFO] [stdout] 19 |     origin::{self, Origin},
[INFO] [stdout]    |              ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Inv`
[INFO] [stdout]   --> geometry/examples/booleans/main.rs:26:18
[INFO] [stdout]    |
[INFO] [stdout] 26 | use num_traits::{Inv, One};
[INFO] [stdout]    |                  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> keyboard/src/bolt_point.rs:2:15
[INFO] [stdout]   |
[INFO] [stdout] 2 |     decimal::{self, Dec},
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `primitive`
[INFO] [stdout]  --> keyboard/src/buttons/chok_hotswap.rs:1:33
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{collections::HashSet, primitive};
[INFO] [stdout]   |                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `hyper_path::length` and `self`
[INFO] [stdout]  --> keyboard/src/buttons/chok_hotswap.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     hyper_path::length,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 7 |     indexes::geo_index::{
[INFO] [stdout] 8 |         index::{self, GeoIndex, PolygonFilter},
[INFO] [stdout]   |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ButtonMountKind` and `button::ButtonMount`
[INFO] [stdout]   --> keyboard/src/buttons/chok_hotswap.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::{button::ButtonMount, ButtonMountKind};
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `itertools::Itertools`
[INFO] [stdout]  --> keyboard/src/keyboard_builder.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use itertools::Itertools;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `borrow::Cow` and `iter::FilterMap`
[INFO] [stdout]  --> keyboard/src/keyboard_config.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 |     borrow::Cow,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 3 |     collections::{HashMap, HashSet},
[INFO] [stdout] 4 |     iter::FilterMap,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `poly::PolyId` and `self`
[INFO] [stdout]   --> keyboard/src/keyboard_config.rs:22:17
[INFO] [stdout]    |
[INFO] [stdout] 22 |         index::{self, GeoIndex, PolygonFilter},
[INFO] [stdout]    |                 ^^^^
[INFO] [stdout] 23 |         mesh::MeshId,
[INFO] [stdout] 24 |         poly::PolyId,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `bolt_point::BoltPoint` and `hole::Hole`
[INFO] [stdout]   --> keyboard/src/keyboard_config.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     bolt_point::BoltPoint, button_collections::ButtonsCollection, hole::Hole,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^                                         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> keyboard/src/bolt_point.rs:2:15
[INFO] [stdout]   |
[INFO] [stdout] 2 |     decimal::{self, Dec},
[INFO] [stdout]   |               ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `primitive`
[INFO] [stdout]  --> keyboard/src/buttons/chok_hotswap.rs:1:33
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::{collections::HashSet, primitive};
[INFO] [stdout]   |                                 ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `hyper_path::length` and `self`
[INFO] [stdout]  --> keyboard/src/buttons/chok_hotswap.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     hyper_path::length,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 7 |     indexes::geo_index::{
[INFO] [stdout] 8 |         index::{self, GeoIndex, PolygonFilter},
[INFO] [stdout]   |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ButtonMountKind` and `button::ButtonMount`
[INFO] [stdout]   --> keyboard/src/buttons/chok_hotswap.rs:19:13
[INFO] [stdout]    |
[INFO] [stdout] 19 | use crate::{button::ButtonMount, ButtonMountKind};
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `itertools::Itertools`
[INFO] [stdout]  --> keyboard/src/keyboard_builder.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use itertools::Itertools;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `borrow::Cow` and `iter::FilterMap`
[INFO] [stdout]  --> keyboard/src/keyboard_config.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 |     borrow::Cow,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 3 |     collections::{HashMap, HashSet},
[INFO] [stdout] 4 |     iter::FilterMap,
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `poly::PolyId` and `self`
[INFO] [stdout]   --> keyboard/src/keyboard_config.rs:22:17
[INFO] [stdout]    |
[INFO] [stdout] 22 |         index::{self, GeoIndex, PolygonFilter},
[INFO] [stdout]    |                 ^^^^
[INFO] [stdout] 23 |         mesh::MeshId,
[INFO] [stdout] 24 |         poly::PolyId,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `bolt_point::BoltPoint` and `hole::Hole`
[INFO] [stdout]   --> keyboard/src/keyboard_config.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     bolt_point::BoltPoint, button_collections::ButtonsCollection, hole::Hole,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^                                         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `smal`
[INFO] [stdout]    --> geometry/examples/booleans/main.rs:185:9
[INFO] [stdout]     |
[INFO] [stdout] 185 |     let smal = index.create_new_mesh_and_set_as_default();
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_smal`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min`
[INFO] [stdout]    --> geometry/examples/booleans/main.rs:410:9
[INFO] [stdout]     |
[INFO] [stdout] 410 |     let min = Dec::from(dec!(0.1));
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_min`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `mmin`
[INFO] [stdout]    --> geometry/examples/booleans/main.rs:411:9
[INFO] [stdout]     |
[INFO] [stdout] 411 |     let mmin = Dec::from(dec!(0.005));
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_mmin`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `part`
[INFO] [stdout]    --> geometry/examples/booleans/main.rs:489:9
[INFO] [stdout]     |
[INFO] [stdout] 489 |     let part = glue_mesh_to_mesh(lock, bed, &mut index)?;
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_part`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `bigger_by_smaller` is never used
[INFO] [stdout]   --> geometry/examples/booleans/main.rs:35:4
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn bigger_by_smaller(file_root: PathBuf) -> anyhow::Result<String> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `overlap_in_center` is never used
[INFO] [stdout]   --> geometry/examples/booleans/main.rs:56:4
[INFO] [stdout]    |
[INFO] [stdout] 56 | fn overlap_in_center(file_root: PathBuf) -> anyhow::Result<String> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `overlap_touching_edge` is never used
[INFO] [stdout]   --> geometry/examples/booleans/main.rs:97:4
[INFO] [stdout]    |
[INFO] [stdout] 97 | fn overlap_touching_edge(file_root: PathBuf) -> anyhow::Result<String> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `complex_cut` is never used
[INFO] [stdout]    --> geometry/examples/booleans/main.rs:193:4
[INFO] [stdout]     |
[INFO] [stdout] 193 | fn complex_cut(file_root: PathBuf) -> anyhow::Result<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_holes` is never used
[INFO] [stdout]    --> geometry/examples/booleans/main.rs:274:4
[INFO] [stdout]     |
[INFO] [stdout] 274 | fn apply_holes(
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `some_interesting_mesh` is never used
[INFO] [stdout]    --> geometry/examples/booleans/main.rs:303:4
[INFO] [stdout]     |
[INFO] [stdout] 303 | fn some_interesting_mesh(index: &mut GeoIndex) -> anyhow::Result<MeshId> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `some_other_interesting_mesh` is never used
[INFO] [stdout]    --> geometry/examples/booleans/main.rs:330:4
[INFO] [stdout]     |
[INFO] [stdout] 330 | fn some_other_interesting_mesh(index: &mut GeoIndex) -> anyhow::Result<MeshId> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `glue_mesh_to_mesh` is never used
[INFO] [stdout]    --> geometry/examples/booleans/main.rs:403:4
[INFO] [stdout]     |
[INFO] [stdout] 403 | fn glue_mesh_to_mesh(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `glueing_two_meshes` is never used
[INFO] [stdout]    --> geometry/examples/booleans/main.rs:468:4
[INFO] [stdout]     |
[INFO] [stdout] 468 | fn glueing_two_meshes(file_root: PathBuf) -> anyhow::Result<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 16 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `hw_hole`
[INFO] [stdout]    --> keyboard/src/buttons/chok_hotswap.rs:303:13
[INFO] [stdout]     |
[INFO] [stdout] 303 |         let hw_hole = self.hotswap_hole(index)?;
[INFO] [stdout]     |             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_hw_hole`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `hw_hole`
[INFO] [stdout]    --> keyboard/src/buttons/chok_hotswap.rs:303:13
[INFO] [stdout]     |
[INFO] [stdout] 303 |         let hw_hole = self.hotswap_hole(index)?;
[INFO] [stdout]     |             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_hw_hole`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> keyboard/src/keyboard_config.rs:590:29
[INFO] [stdout]     |
[INFO] [stdout] 590 |     pub fn pcb_mount(&self, index: &mut GeoIndex) -> anyhow::Result<MeshId> {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]    --> keyboard/src/keyboard_config.rs:590:29
[INFO] [stdout]     |
[INFO] [stdout] 590 |     pub fn pcb_mount(&self, index: &mut GeoIndex) -> anyhow::Result<MeshId> {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NutBuilder` is never constructed
[INFO] [stdout]   --> keyboard/src/bolt_builder.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct NutBuilder {}
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `depth` and `bottom_mesh_button_holes_depth` are never read
[INFO] [stdout]   --> keyboard/src/buttons/chok_hotswap.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct ChokHotswap {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 22 |     depth: Dec,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     bottom_mesh_button_holes_depth: Dec,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `OuterSurface` and `Both` are never constructed
[INFO] [stdout]   --> keyboard/src/keyboard_config.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub enum MaterialAddition {
[INFO] [stdout]    |          ---------------- variants in this enum
[INFO] [stdout] 45 |     InnerSurface,
[INFO] [stdout] 46 |     OuterSurface,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 47 |     Both,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MaterialAddition` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NutBuilder` is never constructed
[INFO] [stdout]   --> keyboard/src/bolt_builder.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct NutBuilder {}
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `depth` and `bottom_mesh_button_holes_depth` are never read
[INFO] [stdout]   --> keyboard/src/buttons/chok_hotswap.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct ChokHotswap {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 22 |     depth: Dec,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     bottom_mesh_button_holes_depth: Dec,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `OuterSurface` and `Both` are never constructed
[INFO] [stdout]   --> keyboard/src/keyboard_config.rs:46:5
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub enum MaterialAddition {
[INFO] [stdout]    |          ---------------- variants in this enum
[INFO] [stdout] 45 |     InnerSurface,
[INFO] [stdout] 46 |     OuterSurface,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 47 |     Both,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MaterialAddition` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 13 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 13 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking ergoton v0.1.0 (/opt/rustwide/workdir/ergoton)
[INFO] [stderr]     Checking chok-hotswap v0.1.0 (/opt/rustwide/workdir/chok-hotswap)
[INFO] [stderr]     Checking stand v0.1.0 (/opt/rustwide/workdir/stand)
[INFO] [stderr]     Checking smol v0.1.0 (/opt/rustwide/workdir/smol)
[INFO] [stdout] warning: unused import: `std::fs::OpenOptions`
[INFO] [stdout]  --> ergoton/src/main.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fs::OpenOptions;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> ergoton/src/main.rs:20:20
[INFO] [stdout]    |
[INFO] [stdout] 20 |     chok_hotswap::{self, ChokHotswap},
[INFO] [stdout]    |                    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::OpenOptions`
[INFO] [stdout]  --> ergoton/src/main.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fs::OpenOptions;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> ergoton/src/main.rs:20:20
[INFO] [stdout]    |
[INFO] [stdout] 20 |     chok_hotswap::{self, ChokHotswap},
[INFO] [stdout]    |                    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]  --> chok-hotswap/src/chok_hotswap.rs:7:28
[INFO] [stdout]   |
[INFO] [stdout] 7 |     pub fn top_mesh(&self, index: &mut GeoIndex) -> anyhow::Result<()> {
[INFO] [stdout]   |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]   --> chok-hotswap/src/chok_hotswap.rs:11:31
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub fn bottom_mesh(&self, index: &mut GeoIndex) -> anyhow::Result<()> {
[INFO] [stdout]    |                               ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]  --> chok-hotswap/src/chok_hotswap.rs:7:28
[INFO] [stdout]   |
[INFO] [stdout] 7 |     pub fn top_mesh(&self, index: &mut GeoIndex) -> anyhow::Result<()> {
[INFO] [stdout]   |                            ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `index`
[INFO] [stdout]   --> chok-hotswap/src/chok_hotswap.rs:11:31
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub fn bottom_mesh(&self, index: &mut GeoIndex) -> anyhow::Result<()> {
[INFO] [stdout]    |                               ^^^^^ help: if this is intentional, prefix it with an underscore: `_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 2 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 2 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `keyboard`
[INFO] [stdout]   --> ergoton/src/main.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let keyboard = RightKeyboardConfig::build()
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_keyboard`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `xy`
[INFO] [stdout]    --> ergoton/src/main.rs:383:9
[INFO] [stdout]     |
[INFO] [stdout] 383 |     let xy = PolygonBasis {
[INFO] [stdout]     |         ^^ help: if this is intentional, prefix it with an underscore: `_xy`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `xz`
[INFO] [stdout]    --> ergoton/src/main.rs:388:9
[INFO] [stdout]     |
[INFO] [stdout] 388 |     let xz = PolygonBasis {
[INFO] [stdout]     |         ^^ help: if this is intentional, prefix it with an underscore: `_xz`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `yz`
[INFO] [stdout]    --> ergoton/src/main.rs:394:9
[INFO] [stdout]     |
[INFO] [stdout] 394 |     let yz = PolygonBasis {
[INFO] [stdout]     |         ^^ help: if this is intentional, prefix it with an underscore: `_yz`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> ergoton/src/main.rs:366:9
[INFO] [stdout]     |
[INFO] [stdout] 366 |     let mut chok_hotswap_top = GeoIndex::new(Aabb::from_points(&[
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `keyboard`
[INFO] [stdout]   --> ergoton/src/main.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let keyboard = RightKeyboardConfig::build()
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_keyboard`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `xy`
[INFO] [stdout]    --> ergoton/src/main.rs:383:9
[INFO] [stdout]     |
[INFO] [stdout] 383 |     let xy = PolygonBasis {
[INFO] [stdout]     |         ^^ help: if this is intentional, prefix it with an underscore: `_xy`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `xz`
[INFO] [stdout]    --> ergoton/src/main.rs:388:9
[INFO] [stdout]     |
[INFO] [stdout] 388 |     let xz = PolygonBasis {
[INFO] [stdout]     |         ^^ help: if this is intentional, prefix it with an underscore: `_xz`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `yz`
[INFO] [stdout]    --> ergoton/src/main.rs:394:9
[INFO] [stdout]     |
[INFO] [stdout] 394 |     let yz = PolygonBasis {
[INFO] [stdout]     |         ^^ help: if this is intentional, prefix it with an underscore: `_yz`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 7 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> ergoton/src/main.rs:366:9
[INFO] [stdout]     |
[INFO] [stdout] 366 |     let mut chok_hotswap_top = GeoIndex::new(Aabb::from_points(&[
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 7 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 11.02s
[INFO] running `Command { std: "docker" "inspect" "fc6ba9f9814c1cece4da5e23881e1946ce8ef67b30bf8f2f20d114cf59a3225d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fc6ba9f9814c1cece4da5e23881e1946ce8ef67b30bf8f2f20d114cf59a3225d", kill_on_drop: false }`
[INFO] [stdout] fc6ba9f9814c1cece4da5e23881e1946ce8ef67b30bf8f2f20d114cf59a3225d
[INFO] checking stavenko/my-keyboard against try#a2cff3b7a9661c90ec0d581d3f3a69bb97c11138 for pr-121848-3
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fstavenko%2Fmy-keyboard" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/stavenko/my-keyboard on toolchain a2cff3b7a9661c90ec0d581d3f3a69bb97c11138
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+a2cff3b7a9661c90ec0d581d3f3a69bb97c11138" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/stavenko/my-keyboard
[INFO] finished tweaking git repo https://github.com/stavenko/my-keyboard
[INFO] tweaked toml for git repo https://github.com/stavenko/my-keyboard written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] crate git repo https://github.com/stavenko/my-keyboard 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" "+a2cff3b7a9661c90ec0d581d3f3a69bb97c11138" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/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:923055f121b5182466d55868a8b05e67af8ba4a3a3f6bad814e953ca3cd3ac2a" "/opt/rustwide/cargo-home/bin/cargo" "+a2cff3b7a9661c90ec0d581d3f3a69bb97c11138" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 267e548de96e5d68d8de44b00c3e8c0ebffa507bd1442e671201dd8d22089064
[INFO] running `Command { std: "docker" "start" "-a" "267e548de96e5d68d8de44b00c3e8c0ebffa507bd1442e671201dd8d22089064", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "267e548de96e5d68d8de44b00c3e8c0ebffa507bd1442e671201dd8d22089064", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "267e548de96e5d68d8de44b00c3e8c0ebffa507bd1442e671201dd8d22089064", kill_on_drop: false }`
[INFO] [stdout] 267e548de96e5d68d8de44b00c3e8c0ebffa507bd1442e671201dd8d22089064
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/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:923055f121b5182466d55868a8b05e67af8ba4a3a3f6bad814e953ca3cd3ac2a" "/opt/rustwide/cargo-home/bin/cargo" "+a2cff3b7a9661c90ec0d581d3f3a69bb97c11138" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b351de4007fc6c8456338d0644742bb53796d9dcdcb2c907c177396d074e2926
[INFO] running `Command { std: "docker" "start" "-a" "b351de4007fc6c8456338d0644742bb53796d9dcdcb2c907c177396d074e2926", kill_on_drop: false }`
[INFO] [stderr]    Compiling libm v0.2.8
[INFO] [stderr]    Compiling proc-macro2 v1.0.84
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling serde v1.0.196
[INFO] [stderr]    Compiling cc v1.0.98
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]     Checking bytemuck v1.14.1
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking utf8parse v0.2.1
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]    Compiling matrixmultiply v0.3.8
[INFO] [stderr]     Checking ord_subset v3.1.1
[INFO] [stderr]     Checking anstyle v1.0.4
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]     Checking anstyle-parse v0.2.3
[INFO] [stderr]     Checking rustc-serialize v0.3.25
[INFO] [stderr]    Compiling rust_decimal v1.35.0
[INFO] [stderr]    Compiling thiserror v1.0.56
[INFO] [stderr]     Checking safe_arch v0.7.1
[INFO] [stderr]     Checking colorchoice v1.0.0
[INFO] [stderr]     Checking anstyle-query v1.0.2
[INFO] [stderr]    Compiling heapless v0.8.0
[INFO] [stderr]    Compiling typenum v1.17.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking hash32 v0.3.1
[INFO] [stderr]     Checking anstream v0.6.11
[INFO] [stderr]    Compiling anyhow v1.0.79
[INFO] [stderr]    Compiling arrayvec v0.7.4
[INFO] [stderr]     Checking rawpointer v0.2.1
[INFO] [stderr]     Checking stable_deref_trait v1.2.0
[INFO] [stderr]     Checking clap_lex v0.6.0
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking wide v0.7.14
[INFO] [stderr]     Checking clap_builder v4.4.11
[INFO] [stderr]     Checking either v1.12.0
[INFO] [stderr]     Checking geometry-predicates v0.3.0
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking uuid v1.8.0
[INFO] [stderr]    Compiling quote v1.0.35
[INFO] [stderr]     Checking itertools v0.12.1
[INFO] [stderr]     Checking assert_matches v1.5.0
[INFO] [stderr]    Compiling seq-macro v0.3.5
[INFO] [stderr]     Checking tap v1.0.1
[INFO] [stderr]    Compiling syn v2.0.66
[INFO] [stderr]    Compiling decimal v2.1.0
[INFO] [stderr]     Checking num-complex v0.4.4
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking float-cmp v0.9.0
[INFO] [stderr]     Checking rstar v0.12.0
[INFO] [stderr]     Checking stl_io v0.7.0
[INFO] [stderr]    Compiling rust_decimal_macros v1.34.2
[INFO] [stderr]     Checking simba v0.8.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.56
[INFO] [stderr]    Compiling clap_derive v4.4.7
[INFO] [stderr]    Compiling nalgebra-macros v0.2.1
[INFO] [stderr]     Checking cdt v0.1.0
[INFO] [stderr]     Checking clap v4.4.11
[INFO] [stderr]     Checking nalgebra v0.32.3
[ERROR] error running command: no output for 300 seconds
[INFO] running `Command { std: "docker" "inspect" "b351de4007fc6c8456338d0644742bb53796d9dcdcb2c907c177396d074e2926", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b351de4007fc6c8456338d0644742bb53796d9dcdcb2c907c177396d074e2926", kill_on_drop: false }`
[INFO] [stdout] b351de4007fc6c8456338d0644742bb53796d9dcdcb2c907c177396d074e2926
