[INFO] cloning repository https://github.com/jeraldgan/rust-primer [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/jeraldgan/rust-primer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjeraldgan%2Frust-primer", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjeraldgan%2Frust-primer'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 8722a96df067afa7439b1de35ff57b32ad9c3f66 [INFO] checking jeraldgan/rust-primer against try#45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4 for pr-83744 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fjeraldgan%2Frust-primer" "/workspace/builds/worker-0/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-0/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/jeraldgan/rust-primer on toolchain 45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/jeraldgan/rust-primer [INFO] finished tweaking git repo https://github.com/jeraldgan/rust-primer [INFO] tweaked toml for git repo https://github.com/jeraldgan/rust-primer written to /workspace/builds/worker-0/source/Cargo.toml [INFO] crate git repo https://github.com/jeraldgan/rust-primer already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] error: the lock file /workspace/builds/worker-0/source/Cargo.lock needs to be updated but --locked was passed to prevent this [INFO] [stderr] If you want to try to generate the lock file without accessing the network, use the --offline flag. [INFO] the lockfile is outdated, regenerating it [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }` [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0/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:20528e8c29e4536546f0102ce88568b16ea7538393a33fcca951030f7af10457" "/opt/rustwide/cargo-home/bin/cargo" "+45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 1a5b5722247274cbb96bb040d1600e8a60c84229da87889b9edbdee137966e61 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "1a5b5722247274cbb96bb040d1600e8a60c84229da87889b9edbdee137966e61", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "1a5b5722247274cbb96bb040d1600e8a60c84229da87889b9edbdee137966e61", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1a5b5722247274cbb96bb040d1600e8a60c84229da87889b9edbdee137966e61", kill_on_drop: false }` [INFO] [stdout] 1a5b5722247274cbb96bb040d1600e8a60c84229da87889b9edbdee137966e61 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0/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" "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:20528e8c29e4536546f0102ce88568b16ea7538393a33fcca951030f7af10457" "/opt/rustwide/cargo-home/bin/cargo" "+45d8b6e68beee1c9c1ce92ae258a7e02f8f13aa4" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] e89a06302f2f39b1f4de6994a44334a2310656c9cfc52ead4edde29aea4bf9a7 [INFO] running `Command { std: "docker" "start" "-a" "e89a06302f2f39b1f4de6994a44334a2310656c9cfc52ead4edde29aea4bf9a7", kill_on_drop: false }` [INFO] [stderr] Compiling syn v1.0.69 [INFO] [stderr] Compiling libc v0.2.93 [INFO] [stderr] Checking itoa v0.4.7 [INFO] [stderr] Checking os_str_bytes v2.4.0 [INFO] [stderr] Checking demo v0.1.0 (/opt/rustwide/workdir/02-basics/demo) [INFO] [stderr] Checking exercise-libraries v0.1.0 (/opt/rustwide/workdir/07-external-libraries/exercise) [INFO] [stderr] Checking solution-generics v0.1.0 (/opt/rustwide/workdir/04-generics-traits/solution) [INFO] [stderr] Checking solution-structs v0.1.0 (/opt/rustwide/workdir/03-structs-lifetimes/solution) [INFO] [stderr] Checking exercise-generics v0.1.0 (/opt/rustwide/workdir/04-generics-traits/exercise) [INFO] [stderr] Checking demo-strings v0.1.0 (/opt/rustwide/workdir/06-strings/demo) [INFO] [stderr] Checking demo-stuff v0.1.0 (/opt/rustwide/workdir/01-hello/demo) [INFO] [stderr] Checking demo-match v0.1.0 (/opt/rustwide/workdir/05-match-result/demo) [INFO] [stderr] Checking solution-match v0.1.0 (/opt/rustwide/workdir/05-match-result/solution) [INFO] [stdout] error: expected identifier, found `?` [INFO] [stdout] --> 04-generics-traits/exercise/src/main.rs:24:37 [INFO] [stdout] | [INFO] [stdout] 24 | let mut map: HashMap<&str, ???> = HashMap::new(); [INFO] [stdout] | -------- ^ expected identifier [INFO] [stdout] | | | [INFO] [stdout] | | help: use `=` if you meant to assign [INFO] [stdout] | while parsing the type for `mut map` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: expected one of `!`, `.`, `::`, `;`, `?`, `{`, or an operator, found `,` [INFO] [stdout] --> 04-generics-traits/exercise/src/main.rs:24:34 [INFO] [stdout] | [INFO] [stdout] 24 | let mut map: HashMap<&str, ???> = HashMap::new(); [INFO] [stdout] | ^ expected one of 7 possible tokens [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> 04-generics-traits/exercise/src/main.rs:4:9 [INFO] [stdout] | [INFO] [stdout] 4 | use std::collections::HashMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: aborting due to 2 previous errors; 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: could not compile `exercise-generics` [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stdout] warning: unnecessary trailing semicolon [INFO] [stdout] --> 04-generics-traits/solution/src/main.rs:21:10 [INFO] [stdout] | [INFO] [stdout] 21 | }; [INFO] [stdout] | ^ help: remove this semicolon [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(redundant_semicolons)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary trailing semicolon [INFO] [stdout] --> 04-generics-traits/solution/src/main.rs:39:10 [INFO] [stdout] | [INFO] [stdout] 39 | }; [INFO] [stdout] | ^ help: remove this semicolon [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s2` [INFO] [stdout] --> 06-strings/demo/src/main.rs:7:9 [INFO] [stdout] | [INFO] [stdout] 7 | let s2: String = String::from_str(s).unwrap(); // s could be invalid bytes for a String [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s2` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s2` [INFO] [stdout] --> 06-strings/demo/src/main.rs:8:9 [INFO] [stdout] | [INFO] [stdout] 8 | let s2: String = s.to_owned(); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s3` [INFO] [stdout] --> 06-strings/demo/src/main.rs:17:9 [INFO] [stdout] | [INFO] [stdout] 17 | let s3: &str = s2.as_str(); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s3` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: expected one of `!` or `::`, found `:` [INFO] [stdout] --> 07-external-libraries/exercise/src/main.rs:21:6 [INFO] [stdout] | [INFO] [stdout] 21 | https://docs.serde.rs/serde_json/#parsing-json-as-strongly-typed-data-structures [INFO] [stdout] | ^ expected one of `!` or `::` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::process` [INFO] [stdout] --> 05-match-result/demo/src/main.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::process; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary trailing semicolon [INFO] [stdout] --> 05-match-result/demo/src/main.rs:7:6 [INFO] [stdout] | [INFO] [stdout] 7 | }; [INFO] [stdout] | ^ help: remove this semicolon [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(redundant_semicolons)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: aborting due to previous error [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 3 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `super::*` [INFO] [stdout] --> 05-match-result/solution/src/main.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 21 | use super::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `super::*` [INFO] [stdout] --> 03-structs-lifetimes/solution/src/shapes/circle.rs:16:9 [INFO] [stdout] | [INFO] [stdout] 16 | use super::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `super::*` [INFO] [stdout] --> 03-structs-lifetimes/solution/src/shapes/rectangle.rs:13:9 [INFO] [stdout] | [INFO] [stdout] 13 | use super::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `super::*` [INFO] [stdout] --> 03-structs-lifetimes/solution/src/main.rs:17:9 [INFO] [stdout] | [INFO] [stdout] 17 | use super::*; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 2 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: irrefutable `if let` pattern [INFO] [stdout] --> 05-match-result/demo/src/main.rs:104:5 [INFO] [stdout] | [INFO] [stdout] 104 | / if let x = Some(wrapper) { [INFO] [stdout] 105 | | dbg!(x); [INFO] [stdout] 106 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(irrefutable_let_patterns)]` on by default [INFO] [stdout] = note: this pattern will always match, so the `if let` is useless [INFO] [stdout] = help: consider replacing the `if let` with a `let` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s2` [INFO] [stdout] --> 06-strings/demo/src/main.rs:7:9 [INFO] [stdout] | [INFO] [stdout] 7 | let s2: String = String::from_str(s).unwrap(); // s could be invalid bytes for a String [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s2` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `Bunny` [INFO] [stdout] --> 05-match-result/solution/src/main.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | Bunny, [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `x` [INFO] [stdout] --> 05-match-result/demo/src/main.rs:5:9 [INFO] [stdout] | [INFO] [stdout] 5 | x: f64, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `y` [INFO] [stdout] --> 05-match-result/demo/src/main.rs:6:9 [INFO] [stdout] | [INFO] [stdout] 6 | y: f64, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `LineTo` [INFO] [stdout] --> 05-match-result/demo/src/main.rs:16:9 [INFO] [stdout] | [INFO] [stdout] 16 | LineTo { x: f64, y: f64 }, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `LineBetween` [INFO] [stdout] --> 05-match-result/demo/src/main.rs:17:9 [INFO] [stdout] | [INFO] [stdout] 17 | LineBetween((Point, Point)), [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `Clear` [INFO] [stdout] --> 05-match-result/demo/src/main.rs:18:9 [INFO] [stdout] | [INFO] [stdout] 18 | Clear, [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant is never constructed: `Teapot` [INFO] [stdout] --> 05-match-result/solution/src/main.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | Teapot, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `parse_value` [INFO] [stdout] --> 05-match-result/solution/src/main.rs:11:4 [INFO] [stdout] | [INFO] [stdout] 11 | fn parse_value(input: &str) -> Option { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s2` [INFO] [stdout] --> 06-strings/demo/src/main.rs:8:9 [INFO] [stdout] | [INFO] [stdout] 8 | let s2: String = s.to_owned(); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s3` [INFO] [stdout] --> 06-strings/demo/src/main.rs:17:9 [INFO] [stdout] | [INFO] [stdout] 17 | let s3: &str = s2.as_str(); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s3` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 8 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 3 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 3 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 4 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: build failed [INFO] running `Command { std: "docker" "inspect" "e89a06302f2f39b1f4de6994a44334a2310656c9cfc52ead4edde29aea4bf9a7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e89a06302f2f39b1f4de6994a44334a2310656c9cfc52ead4edde29aea4bf9a7", kill_on_drop: false }` [INFO] [stdout] e89a06302f2f39b1f4de6994a44334a2310656c9cfc52ead4edde29aea4bf9a7