[INFO] cloning repository https://github.com/gyng/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/gyng/rust-primer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgyng%2Frust-primer", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgyng%2Frust-primer'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] ed24db7d18d5c614ab80a44a1f34288f101769b0 [INFO] checking gyng/rust-primer against try#3bb2879ea9e58d65b875f9a98df44f4a43ce2597 for pr-85387 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fgyng%2Frust-primer" "/workspace/builds/worker-10/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-10/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/gyng/rust-primer on toolchain 3bb2879ea9e58d65b875f9a98df44f4a43ce2597 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+3bb2879ea9e58d65b875f9a98df44f4a43ce2597" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/gyng/rust-primer [INFO] finished tweaking git repo https://github.com/gyng/rust-primer [INFO] tweaked toml for git repo https://github.com/gyng/rust-primer written to /workspace/builds/worker-10/source/Cargo.toml [INFO] crate git repo https://github.com/gyng/rust-primer already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+3bb2879ea9e58d65b875f9a98df44f4a43ce2597" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/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" "+3bb2879ea9e58d65b875f9a98df44f4a43ce2597" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] dcf6e41bb827bbf6b431a3b7d469100a609a8d6ce5b28ca5be6fc6092f00649e [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" "dcf6e41bb827bbf6b431a3b7d469100a609a8d6ce5b28ca5be6fc6092f00649e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "dcf6e41bb827bbf6b431a3b7d469100a609a8d6ce5b28ca5be6fc6092f00649e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "dcf6e41bb827bbf6b431a3b7d469100a609a8d6ce5b28ca5be6fc6092f00649e", kill_on_drop: false }` [INFO] [stdout] dcf6e41bb827bbf6b431a3b7d469100a609a8d6ce5b28ca5be6fc6092f00649e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-10/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" "+3bb2879ea9e58d65b875f9a98df44f4a43ce2597" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] c24f67269a3d4b975f2d7aedcf069ad77a91fd9b41e0982642f27f24a1a26daf [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" "c24f67269a3d4b975f2d7aedcf069ad77a91fd9b41e0982642f27f24a1a26daf", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.24 [INFO] [stderr] Compiling unicode-xid v0.2.1 [INFO] [stderr] Compiling syn v1.0.65 [INFO] [stderr] Compiling autocfg v1.0.1 [INFO] [stderr] Compiling libc v0.2.91 [INFO] [stderr] Compiling ryu v1.0.5 [INFO] [stderr] Compiling bitflags v1.2.1 [INFO] [stderr] Compiling unicode-segmentation v1.7.1 [INFO] [stderr] Checking unicode-width v0.1.8 [INFO] [stderr] Checking hashbrown v0.9.1 [INFO] [stderr] Checking lazy_static v1.4.0 [INFO] [stderr] Checking itoa v0.4.7 [INFO] [stderr] Checking vec_map v0.8.2 [INFO] [stderr] Checking os_str_bytes v2.4.0 [INFO] [stderr] Checking solution-generics v0.1.0 (/opt/rustwide/workdir/04-generics-traits/solution) [INFO] [stderr] Checking demo-structs v0.1.0 (/opt/rustwide/workdir/03-structs-lifetimes/demo) [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] [stderr] Checking demo-match v0.1.0 (/opt/rustwide/workdir/05-match-result/demo) [INFO] [stdout] warning: 2 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking exercise-hello v0.1.0 (/opt/rustwide/workdir/01-hello/exercise) [INFO] [stdout] warning: associated function is never used: `new` [INFO] [stdout] --> 03-structs-lifetimes/demo/src/main.rs:18:8 [INFO] [stdout] | [INFO] [stdout] 18 | fn new(width: u32, height: u32) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `double_area_rect_reference` [INFO] [stdout] --> 03-structs-lifetimes/demo/src/main.rs:73:4 [INFO] [stdout] | [INFO] [stdout] 73 | fn double_area_rect_reference(rect: &Rectangle) -> u32 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 2 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking demo-generics v0.1.0 (/opt/rustwide/workdir/04-generics-traits/demo) [INFO] [stderr] Checking exercise-libraries v0.1.0 (/opt/rustwide/workdir/07-external-libraries/exercise) [INFO] [stderr] Checking demo-strings v0.1.0 (/opt/rustwide/workdir/06-strings/demo) [INFO] [stderr] Checking exercise-generics v0.1.0 (/opt/rustwide/workdir/04-generics-traits/exercise) [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] warning: unused import: `std::collections::HashMap` [INFO] [stdout] --> 04-generics-traits/solution/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] 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] 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] error: aborting due to previous error [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: could not compile `exercise-libraries` [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: 1 warning emitted [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] warning: 3 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] 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: 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: 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] warning: 8 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 3 warnings emitted [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] warning: unnecessary trailing semicolon [INFO] [stdout] --> 04-generics-traits/exercise/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/exercise/src/main.rs:39:10 [INFO] [stdout] | [INFO] [stdout] 39 | }; [INFO] [stdout] | ^ help: remove this semicolon [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0046]: not all trait items implemented, missing: `get_weight` [INFO] [stdout] --> 04-generics-traits/exercise/src/main.rs:52:9 [INFO] [stdout] | [INFO] [stdout] 38 | fn get_weight(&self) -> i32; [INFO] [stdout] | ---------------------------- `get_weight` from trait [INFO] [stdout] ... [INFO] [stdout] 52 | impl HasWeight for Cow {} [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ missing `get_weight` in implementation [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0046]: not all trait items implemented, missing: `get_weight` [INFO] [stdout] --> 04-generics-traits/exercise/src/main.rs:54:9 [INFO] [stdout] | [INFO] [stdout] 38 | fn get_weight(&self) -> i32; [INFO] [stdout] | ---------------------------- `get_weight` from trait [INFO] [stdout] ... [INFO] [stdout] 54 | impl HasWeight for Cat {} [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ missing `get_weight` in implementation [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0061]: this function takes 0 arguments but 1 argument was supplied [INFO] [stdout] --> 04-generics-traits/exercise/src/main.rs:60:13 [INFO] [stdout] | [INFO] [stdout] 60 | get_weight(Cow { [INFO] [stdout] | _____________^^^^^^^^^^_- [INFO] [stdout] | | | [INFO] [stdout] | | expected 0 arguments [INFO] [stdout] 61 | | meat_weight: 1, [INFO] [stdout] 62 | | milk_weight: 5 [INFO] [stdout] 63 | | }), [INFO] [stdout] | |_____________- supplied 1 argument [INFO] [stdout] | [INFO] [stdout] note: function defined here [INFO] [stdout] --> 04-generics-traits/exercise/src/main.rs:57:12 [INFO] [stdout] | [INFO] [stdout] 57 | fn get_weight() -> i32 {} [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0061]: this function takes 0 arguments but 1 argument was supplied [INFO] [stdout] --> 04-generics-traits/exercise/src/main.rs:66:20 [INFO] [stdout] | [INFO] [stdout] 66 | assert_eq!(get_weight(Cat { furballs: 3 }), 3); [INFO] [stdout] | ^^^^^^^^^^ ------------------- supplied 1 argument [INFO] [stdout] | | [INFO] [stdout] | expected 0 arguments [INFO] [stdout] | [INFO] [stdout] note: function defined here [INFO] [stdout] --> 04-generics-traits/exercise/src/main.rs:57:12 [INFO] [stdout] | [INFO] [stdout] 57 | fn get_weight() -> i32 {} [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0308]: mismatched types [INFO] [stdout] --> 04-generics-traits/exercise/src/main.rs:57:28 [INFO] [stdout] | [INFO] [stdout] 57 | fn get_weight() -> i32 {} [INFO] [stdout] | ---------- ^^^ expected `i32`, found `()` [INFO] [stdout] | | [INFO] [stdout] | implicitly returns `()` as its body has no tail or `return` expression [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: aborting due to 7 previous errors; 3 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] Some errors have detailed explanations: E0046, E0061, E0308. [INFO] [stdout] [INFO] [stdout] For more information about an error, try `rustc --explain E0046`. [INFO] [stdout] [INFO] [stderr] error: build failed [INFO] running `Command { std: "docker" "inspect" "c24f67269a3d4b975f2d7aedcf069ad77a91fd9b41e0982642f27f24a1a26daf", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c24f67269a3d4b975f2d7aedcf069ad77a91fd9b41e0982642f27f24a1a26daf", kill_on_drop: false }` [INFO] [stdout] c24f67269a3d4b975f2d7aedcf069ad77a91fd9b41e0982642f27f24a1a26daf