[INFO] cloning repository https://github.com/satanson/rust_etudes [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/satanson/rust_etudes" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsatanson%2Frust_etudes", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsatanson%2Frust_etudes'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 0501fe82134be8ab3428a96b7818367e4bb95d77 [INFO] checking satanson/rust_etudes/0501fe82134be8ab3428a96b7818367e4bb95d77 against master#32cd9114712a24010b0583624dc52ac302194128 for pr-143717 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsatanson%2Frust_etudes" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/satanson/rust_etudes [INFO] finished tweaking git repo https://github.com/satanson/rust_etudes [INFO] tweaked toml for git repo https://github.com/satanson/rust_etudes written to /workspace/builds/worker-7-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/satanson/rust_etudes on toolchain 32cd9114712a24010b0583624dc52ac302194128 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+32cd9114712a24010b0583624dc52ac302194128" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/satanson/rust_etudes 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" "+32cd9114712a24010b0583624dc52ac302194128" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] warning: /workspace/builds/worker-7-tc1/source/non_proc_macro/Cargo.toml: no edition set: defaulting to the 2015 edition while the latest is 2024 [INFO] [stderr] warning: /workspace/builds/worker-7-tc1/source/my_proc_macro/Cargo.toml: no edition set: defaulting to the 2015 edition while the latest is 2024 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+32cd9114712a24010b0583624dc52ac302194128" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 787b1d8f5dabb18230f6885cb8c3ef6b80dbd86c6ad7934b119d69d5ec24be66 [INFO] running `Command { std: "docker" "start" "-a" "787b1d8f5dabb18230f6885cb8c3ef6b80dbd86c6ad7934b119d69d5ec24be66", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "787b1d8f5dabb18230f6885cb8c3ef6b80dbd86c6ad7934b119d69d5ec24be66", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "787b1d8f5dabb18230f6885cb8c3ef6b80dbd86c6ad7934b119d69d5ec24be66", kill_on_drop: false }` [INFO] [stdout] 787b1d8f5dabb18230f6885cb8c3ef6b80dbd86c6ad7934b119d69d5ec24be66 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+32cd9114712a24010b0583624dc52ac302194128" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] cfe5c37e7a40562e90bb165f1e1c0f612b79667229677bbcca86d1fbf37bb0e3 [INFO] running `Command { std: "docker" "start" "-a" "cfe5c37e7a40562e90bb165f1e1c0f612b79667229677bbcca86d1fbf37bb0e3", kill_on_drop: false }` [INFO] [stderr] warning: /opt/rustwide/workdir/my_proc_macro/Cargo.toml: no edition set: defaulting to the 2015 edition while the latest is 2024 [INFO] [stderr] warning: /opt/rustwide/workdir/non_proc_macro/Cargo.toml: no edition set: defaulting to the 2015 edition while the latest is 2024 [INFO] [stderr] Checking common v0.1.0 (/opt/rustwide/workdir/common) [INFO] [stderr] Compiling my_proc_macro v1.0.0 (/opt/rustwide/workdir/my_proc_macro) [INFO] [stderr] Checking etudes v0.1.0 (/opt/rustwide/workdir/etudes) [INFO] [stderr] Checking Longest_Substring_Without_Repeating_Characters v0.1.0 (/opt/rustwide/workdir/Longest_Substring_Without_Repeating_Characters) [INFO] [stderr] Checking n014_Longest_Common_Prefix v0.1.0 (/opt/rustwide/workdir/n014_Longest_Common_Prefix) [INFO] [stderr] Checking n028_Implement_strStr v0.1.0 (/opt/rustwide/workdir/n028_Implement_strStr) [INFO] [stderr] Checking n029_Divide_Two_Integers v0.1.0 (/opt/rustwide/workdir/n029_Divide_Two_Integers) [INFO] [stderr] Checking n030_Substring_with_Concatenation_of_All_Words v0.1.0 (/opt/rustwide/workdir/n030_Substring_with_Concatenation_of_All_Words) [INFO] [stderr] Checking n038_Count_and_Say v0.1.0 (/opt/rustwide/workdir/n038_Count_and_Say) [INFO] [stderr] Checking n046_Permutations v0.1.0 (/opt/rustwide/workdir/n046_Permutations) [INFO] [stderr] Checking n015_3Sum v0.1.0 (/opt/rustwide/workdir/n015_3Sum) [INFO] [stderr] Checking conditional_compiling v0.1.0 (/opt/rustwide/workdir/conditional_compiling) [INFO] [stderr] Checking n027_Remove_Element v0.1.0 (/opt/rustwide/workdir/n027_Remove_Element) [INFO] [stderr] Checking n033_Search_in_Rotated_Sorted_Array v0.1.0 (/opt/rustwide/workdir/n033_Search_in_Rotated_Sorted_Array) [INFO] [stderr] Checking n035_Search_Insert_Position v0.1.0 (/opt/rustwide/workdir/n035_Search_Insert_Position) [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> etudes/src/util/mod.rs:153:11 [INFO] [stdout] | [INFO] [stdout] 153 | let a: &TraitA = &StructA {}; [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn` [INFO] [stdout] | [INFO] [stdout] 153 | let a: &dyn TraitA = &StructA {}; [INFO] [stdout] | +++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s1` [INFO] [stdout] --> Longest_Substring_Without_Repeating_Characters/src/main.rs:44:7 [INFO] [stdout] | [INFO] [stdout] 44 | let s1 = "abcdefg"; [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s1` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s2` [INFO] [stdout] --> Longest_Substring_Without_Repeating_Characters/src/main.rs:45:7 [INFO] [stdout] | [INFO] [stdout] 45 | let s2 = "aaaaaaa"; [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] --> Longest_Substring_Without_Repeating_Characters/src/main.rs:46:7 [INFO] [stdout] | [INFO] [stdout] 46 | let s3 = "abcdaabc"; [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s3` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> common/src/lib.rs:62:12 [INFO] [stdout] | [INFO] [stdout] 62 | '1'...'9' => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> etudes/src/util/mod.rs:124:7 [INFO] [stdout] | [INFO] [stdout] 124 | let mut a = Wrapper(&s); [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: `a` [INFO] [stdout] --> etudes/src/util/mod.rs:153:7 [INFO] [stdout] | [INFO] [stdout] 153 | let a: &TraitA = &StructA {}; [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `TraitB` is never used [INFO] [stdout] --> etudes/src/util/mod.rs:144:7 [INFO] [stdout] | [INFO] [stdout] 144 | trait TraitB: Sized {} [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `L` should have a snake case name [INFO] [stdout] --> n030_Substring_with_Concatenation_of_All_Words/src/main.rs:16:9 [INFO] [stdout] | [INFO] [stdout] 16 | let L = l * m; [INFO] [stdout] | ^ help: convert the identifier to snake case: `l` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> n046_Permutations/src/main.rs:39:18 [INFO] [stdout] | [INFO] [stdout] 39 | xs[i] %= (i+1); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 39 - xs[i] %= (i+1); [INFO] [stdout] 39 + xs[i] %= i+1; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> n046_Permutations/src/main.rs:39:18 [INFO] [stdout] | [INFO] [stdout] 39 | xs[i] %= (i+1); [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 39 - xs[i] %= (i+1); [INFO] [stdout] 39 + xs[i] %= i+1; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> n038_Count_and_Say/src/main.rs:11:10 [INFO] [stdout] | [INFO] [stdout] 11 | let (mut a, mut b) = (&mut s, &mut s2); [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: variable does not need to be mutable [INFO] [stdout] --> n038_Count_and_Say/src/main.rs:11:17 [INFO] [stdout] | [INFO] [stdout] 11 | let (mut a, mut b) = (&mut s, &mut s2); [INFO] [stdout] | ----^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking n013_Roman_to_Integer v0.1.0 (/opt/rustwide/workdir/n013_Roman_to_Integer) [INFO] [stderr] Checking n026_Remove_Duplicates_from_Sorted_Array v0.1.0 (/opt/rustwide/workdir/n026_Remove_Duplicates_from_Sorted_Array) [INFO] [stderr] Checking n039_Combination_Sum v0.1.0 (/opt/rustwide/workdir/n039_Combination_Sum) [INFO] [stderr] Checking Reverse_Integer v0.1.0 (/opt/rustwide/workdir/Reverse_Integer) [INFO] [stderr] Checking n016_3Sum_Closest v0.1.0 (/opt/rustwide/workdir/n016_3Sum_Closest) [INFO] [stderr] Checking n045_Jump_Game_II v0.1.0 (/opt/rustwide/workdir/n045_Jump_Game_II) [INFO] [stderr] Checking n041_First_Missing_Positive v0.1.0 (/opt/rustwide/workdir/n041_First_Missing_Positive) [INFO] [stderr] Checking Median_of_Two_Sorted_Arrays v0.1.0 (/opt/rustwide/workdir/Median_of_Two_Sorted_Arrays) [INFO] [stderr] Checking String_to_Integer v0.1.0 (/opt/rustwide/workdir/String_to_Integer) [INFO] [stdout] warning: variable `max_i` is assigned to, but never used [INFO] [stdout] --> n041_First_Missing_Positive/src/main.rs:6:25 [INFO] [stdout] | [INFO] [stdout] 6 | let (mut min_i, mut max_i) = (0usize, 0usize); [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: consider using `_max_i` instead [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `max_i` is never read [INFO] [stdout] --> n041_First_Missing_Positive/src/main.rs:14:9 [INFO] [stdout] | [INFO] [stdout] 14 | max_i = i; [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable statement [INFO] [stdout] --> n026_Remove_Duplicates_from_Sorted_Array/src/main.rs:25:5 [INFO] [stdout] | [INFO] [stdout] 24 | return (i+1) as i32; [INFO] [stdout] | ------------------- any code following this expression is unreachable [INFO] [stdout] 25 | return 0; [INFO] [stdout] | ^^^^^^^^^ unreachable statement [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking n036_Valid_Sudoku v0.1.0 (/opt/rustwide/workdir/n036_Valid_Sudoku) [INFO] [stderr] Checking n021_Merge_Two_Sorted_Lists v0.1.0 (/opt/rustwide/workdir/n021_Merge_Two_Sorted_Lists) [INFO] [stderr] Checking n019_Remove_Nth_Node_From_End_of_List v0.1.0 (/opt/rustwide/workdir/n019_Remove_Nth_Node_From_End_of_List) [INFO] [stdout] warning: value assigned to `i` is never read [INFO] [stdout] --> n013_Roman_to_Integer/src/main.rs:98:7 [INFO] [stdout] | [INFO] [stdout] 98 | i += advance; [INFO] [stdout] | ^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking n025_Reverse_Nodes_in_k_Group v0.1.0 (/opt/rustwide/workdir/n025_Reverse_Nodes_in_k_Group) [INFO] [stderr] Checking n023_Merge_k_Sorted_Lists v0.1.0 (/opt/rustwide/workdir/n023_Merge_k_Sorted_Lists) [INFO] [stderr] Checking n024_Swap_Nodes_in_Pairs v0.1.0 (/opt/rustwide/workdir/n024_Swap_Nodes_in_Pairs) [INFO] [stderr] Checking n037_Sudoku_Solver v0.1.0 (/opt/rustwide/workdir/n037_Sudoku_Solver) [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> n036_Valid_Sudoku/src/main.rs:13:12 [INFO] [stdout] | [INFO] [stdout] 13 | '1'...'9' => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> n038_Count_and_Say/src/main.rs:11:10 [INFO] [stdout] | [INFO] [stdout] 11 | let (mut a, mut b) = (&mut s, &mut s2); [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: variable does not need to be mutable [INFO] [stdout] --> n038_Count_and_Say/src/main.rs:11:17 [INFO] [stdout] | [INFO] [stdout] 11 | let (mut a, mut b) = (&mut s, &mut s2); [INFO] [stdout] | ----^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b0` [INFO] [stdout] --> n036_Valid_Sudoku/src/main.rs:79:7 [INFO] [stdout] | [INFO] [stdout] 79 | let b0: Vec> = sudoku::sudoku_from(b0); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b0` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b1` [INFO] [stdout] --> n036_Valid_Sudoku/src/main.rs:92:7 [INFO] [stdout] | [INFO] [stdout] 92 | let b1: Vec> = sudoku::sudoku_from(b1); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b2` [INFO] [stdout] --> n036_Valid_Sudoku/src/main.rs:106:7 [INFO] [stdout] | [INFO] [stdout] 106 | let b2: Vec> = sudoku::sudoku_from(b2); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b3` [INFO] [stdout] --> n036_Valid_Sudoku/src/main.rs:118:7 [INFO] [stdout] | [INFO] [stdout] 118 | let b3 = b3.iter().map(|&x|x.iter().map(|x|*x).collect::>()).collect::>>(); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b3` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_max` is never used [INFO] [stdout] --> Reverse_Integer/src/main.rs:45:11 [INFO] [stdout] | [INFO] [stdout] 45 | const i32_max: i32 = std::i32::MAX; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_min` is never used [INFO] [stdout] --> Reverse_Integer/src/main.rs:46:11 [INFO] [stdout] | [INFO] [stdout] 46 | const i32_min: i32 = std::i32::MIN; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking non_proc_macro v0.1.0 (/opt/rustwide/workdir/non_proc_macro) [INFO] [stdout] warning: comparison is useless due to type limits [INFO] [stdout] --> Median_of_Two_Sorted_Arrays/src/main.rs:11:16 [INFO] [stdout] | [INFO] [stdout] 11 | assert_eq!(0 <= k && k < a_len + b_len, true); [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_comparisons)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_max` should have an upper case name [INFO] [stdout] --> Reverse_Integer/src/main.rs:6:11 [INFO] [stdout] | [INFO] [stdout] 6 | const i32_max: i32 = std::i32::MAX; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_upper_case_globals)]` on by default [INFO] [stdout] help: convert the identifier to upper case [INFO] [stdout] | [INFO] [stdout] 6 - const i32_max: i32 = std::i32::MAX; [INFO] [stdout] 6 + const I32_MAX: i32 = std::i32::MAX; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_min` should have an upper case name [INFO] [stdout] --> Reverse_Integer/src/main.rs:26:11 [INFO] [stdout] | [INFO] [stdout] 26 | const i32_min: i32 = std::i32::MIN; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] help: convert the identifier to upper case [INFO] [stdout] | [INFO] [stdout] 26 - const i32_min: i32 = std::i32::MIN; [INFO] [stdout] 26 + const I32_MIN: i32 = std::i32::MIN; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_max` should have an upper case name [INFO] [stdout] --> Reverse_Integer/src/main.rs:45:11 [INFO] [stdout] | [INFO] [stdout] 45 | const i32_max: i32 = std::i32::MAX; [INFO] [stdout] | ^^^^^^^ help: convert the identifier to upper case: `I32_MAX` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_min` should have an upper case name [INFO] [stdout] --> Reverse_Integer/src/main.rs:46:11 [INFO] [stdout] | [INFO] [stdout] 46 | const i32_min: i32 = std::i32::MIN; [INFO] [stdout] | ^^^^^^^ help: convert the identifier to upper case: `I32_MIN` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `l` [INFO] [stdout] --> n019_Remove_Nth_Node_From_End_of_List/src/main.rs:38:7 [INFO] [stdout] | [INFO] [stdout] 38 | let l = ListNode::from(vec!(1,3,4,5,2)); [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_l` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking n050_Pow_x_n v0.1.0 (/opt/rustwide/workdir/n050_Pow_x_n) [INFO] [stderr] Checking n032_Longest_Valid_Parentheses v0.1.0 (/opt/rustwide/workdir/n032_Longest_Valid_Parentheses) [INFO] [stdout] tk=pub [INFO] [stdout] tk=struct [INFO] [stdout] tk=AAA_struct [INFO] [stdout] tk={ #[aaa_helper] pub a:i32 } [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> n036_Valid_Sudoku/src/main.rs:13:12 [INFO] [stdout] | [INFO] [stdout] 13 | '1'...'9' => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking n040_Combination_Sum_II v0.1.0 (/opt/rustwide/workdir/n040_Combination_Sum_II) [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:72:18 [INFO] [stdout] | [INFO] [stdout] 72 | '0'...'9' => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::BinaryHeap` [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:81:11 [INFO] [stdout] | [INFO] [stdout] 81 | use std::collections::BinaryHeap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b0` [INFO] [stdout] --> n036_Valid_Sudoku/src/main.rs:79:7 [INFO] [stdout] | [INFO] [stdout] 79 | let b0: Vec> = sudoku::sudoku_from(b0); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b0` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b1` [INFO] [stdout] --> n036_Valid_Sudoku/src/main.rs:92:7 [INFO] [stdout] | [INFO] [stdout] 92 | let b1: Vec> = sudoku::sudoku_from(b1); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b2` [INFO] [stdout] --> n036_Valid_Sudoku/src/main.rs:106:7 [INFO] [stdout] | [INFO] [stdout] 106 | let b2: Vec> = sudoku::sudoku_from(b2); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b2` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b3` [INFO] [stdout] --> n036_Valid_Sudoku/src/main.rs:118:7 [INFO] [stdout] | [INFO] [stdout] 118 | let b3 = b3.iter().map(|&x|x.iter().map(|x|*x).collect::>()).collect::>>(); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b3` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] tk=pub [INFO] [stdout] tk=struct [INFO] [stdout] tk=AAA_struct [INFO] [stdout] tk={ #[aaa_helper] pub a:i32 } [INFO] [stdout] warning: unused variable: `l` [INFO] [stdout] --> n019_Remove_Nth_Node_From_End_of_List/src/main.rs:38:7 [INFO] [stdout] | [INFO] [stdout] 38 | let l = ListNode::from(vec!(1,3,4,5,2)); [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_l` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `AAA_struct` should have an upper camel case name [INFO] [stdout] --> non_proc_macro/src/util.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 51 | pub struct AAA_struct{ [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to upper camel case: `AaaStruct` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking n049_Group_Anagrams v0.1.0 (/opt/rustwide/workdir/n049_Group_Anagrams) [INFO] [stderr] Checking n017_Letter_Combinations_of_a_Phone_Number v0.1.0 (/opt/rustwide/workdir/n017_Letter_Combinations_of_a_Phone_Number) [INFO] [stdout] warning: type `AAA_struct` should have an upper camel case name [INFO] [stdout] --> non_proc_macro/src/util.rs:51:12 [INFO] [stdout] | [INFO] [stdout] 51 | pub struct AAA_struct{ [INFO] [stdout] | ^^^^^^^^^^ help: convert the identifier to upper camel case: `AaaStruct` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:72:18 [INFO] [stdout] | [INFO] [stdout] 72 | '0'...'9' => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::collections::BinaryHeap` [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:81:11 [INFO] [stdout] | [INFO] [stdout] 81 | use std::collections::BinaryHeap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `k` [INFO] [stdout] --> n032_Longest_Valid_Parentheses/src/main.rs:18:17 [INFO] [stdout] | [INFO] [stdout] 18 | (Some(&(k, 'M')), ')') => { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_k` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking n042_Trapping_Rain_Water v0.1.0 (/opt/rustwide/workdir/n042_Trapping_Rain_Water) [INFO] [stdout] warning: struct `Buzz` is never constructed [INFO] [stdout] --> non_proc_macro/src/util.rs:12:8 [INFO] [stdout] | [INFO] [stdout] 12 | struct Buzz; [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> n032_Longest_Valid_Parentheses/src/main.rs:12:15 [INFO] [stdout] | [INFO] [stdout] 12 | let mut tmp = i + 1 - j; [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: variable does not need to be mutable [INFO] [stdout] --> n032_Longest_Valid_Parentheses/src/main.rs:23:19 [INFO] [stdout] | [INFO] [stdout] 23 | let mut tmp = i + 1 - l; [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking n051_N_Queens v0.1.0 (/opt/rustwide/workdir/n051_N_Queens) [INFO] [stderr] Checking n018_4Sum v0.1.0 (/opt/rustwide/workdir/n018_4Sum) [INFO] [stderr] Checking ZigZag_Conversion v0.1.0 (/opt/rustwide/workdir/ZigZag_Conversion) [INFO] [stderr] Checking add_two_numbers v0.1.0 (/opt/rustwide/workdir/add_two_numbers) [INFO] [stderr] Checking n022_Generate_Parentheses v0.1.0 (/opt/rustwide/workdir/n022_Generate_Parentheses) [INFO] [stdout] warning: unused variable: `b0` [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:197:11 [INFO] [stdout] | [INFO] [stdout] 197 | let mut b0 = sudoku_from(b0); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b0` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b0` [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:197:11 [INFO] [stdout] | [INFO] [stdout] 197 | let mut b0 = sudoku_from(b0); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b0` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b1` [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:198:11 [INFO] [stdout] | [INFO] [stdout] 198 | let mut b1 = sudoku_from(b1); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `b1` [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:198:11 [INFO] [stdout] | [INFO] [stdout] 198 | let mut b1 = sudoku_from(b1); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_b1` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:197:7 [INFO] [stdout] | [INFO] [stdout] 197 | let mut b0 = sudoku_from(b0); [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: variable does not need to be mutable [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:198:7 [INFO] [stdout] | [INFO] [stdout] 198 | let mut b1 = sudoku_from(b1); [INFO] [stdout] | ----^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0412]: cannot find type `Pair` in this scope [INFO] [stdout] --> n051_N_Queens/src/main.rs:6:21 [INFO] [stdout] | [INFO] [stdout] 6 | alternatives: Vec [INFO] [stdout] | ^^^^ not found in this scope [INFO] [stdout] | [INFO] [stdout] help: you might be missing a type parameter [INFO] [stdout] | [INFO] [stdout] 4 | struct StkElm { [INFO] [stdout] | ++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:197:7 [INFO] [stdout] | [INFO] [stdout] 197 | let mut b0 = sudoku_from(b0); [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: variable does not need to be mutable [INFO] [stdout] --> n037_Sudoku_Solver/src/main.rs:198:7 [INFO] [stdout] | [INFO] [stdout] 198 | let mut b1 = sudoku_from(b1); [INFO] [stdout] | ----^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `thread` and `time` [INFO] [stdout] --> n018_4Sum/src/main.rs:1:11 [INFO] [stdout] | [INFO] [stdout] 1 | use std::{thread,time}; [INFO] [stdout] | ^^^^^^ ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking n047_Permutations_II v0.1.0 (/opt/rustwide/workdir/n047_Permutations_II) [INFO] [stdout] warning: constant `i32_max` is never used [INFO] [stdout] --> Reverse_Integer/src/main.rs:45:11 [INFO] [stdout] | [INFO] [stdout] 45 | const i32_max: i32 = std::i32::MAX; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_min` is never used [INFO] [stdout] --> Reverse_Integer/src/main.rs:46:11 [INFO] [stdout] | [INFO] [stdout] 46 | const i32_min: i32 = std::i32::MIN; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_max` should have an upper case name [INFO] [stdout] --> Reverse_Integer/src/main.rs:6:11 [INFO] [stdout] | [INFO] [stdout] 6 | const i32_max: i32 = std::i32::MAX; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_upper_case_globals)]` on by default [INFO] [stdout] help: convert the identifier to upper case [INFO] [stdout] | [INFO] [stdout] 6 - const i32_max: i32 = std::i32::MAX; [INFO] [stdout] 6 + const I32_MAX: i32 = std::i32::MAX; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_min` should have an upper case name [INFO] [stdout] --> Reverse_Integer/src/main.rs:26:11 [INFO] [stdout] | [INFO] [stdout] 26 | const i32_min: i32 = std::i32::MIN; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] | [INFO] [stdout] help: convert the identifier to upper case [INFO] [stdout] | [INFO] [stdout] 26 - const i32_min: i32 = std::i32::MIN; [INFO] [stdout] 26 + const I32_MIN: i32 = std::i32::MIN; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_max` should have an upper case name [INFO] [stdout] --> Reverse_Integer/src/main.rs:45:11 [INFO] [stdout] | [INFO] [stdout] 45 | const i32_max: i32 = std::i32::MAX; [INFO] [stdout] | ^^^^^^^ help: convert the identifier to upper case: `I32_MAX` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `i32_min` should have an upper case name [INFO] [stdout] --> Reverse_Integer/src/main.rs:46:11 [INFO] [stdout] | [INFO] [stdout] 46 | const i32_min: i32 = std::i32::MIN; [INFO] [stdout] | ^^^^^^^ help: convert the identifier to upper case: `I32_MIN` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] For more information about this error, try `rustc --explain E0412`. [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s1` [INFO] [stdout] --> ZigZag_Conversion/src/main.rs:59:7 [INFO] [stdout] | [INFO] [stdout] 59 | let s1 = String::from("PAYPALISHIRING"); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s1` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s1` [INFO] [stdout] --> ZigZag_Conversion/src/main.rs:59:7 [INFO] [stdout] | [INFO] [stdout] 59 | let s1 = String::from("PAYPALISHIRING"); [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s1` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: could not compile `n051_N_Queens` (bin "n051_N_Queens" test) due to 1 previous error [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stdout] warning: unused variable: `k` [INFO] [stdout] --> n032_Longest_Valid_Parentheses/src/main.rs:18:17 [INFO] [stdout] | [INFO] [stdout] 18 | (Some(&(k, 'M')), ')') => { [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_k` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> n032_Longest_Valid_Parentheses/src/main.rs:12:15 [INFO] [stdout] | [INFO] [stdout] 12 | let mut tmp = i + 1 - j; [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: variable does not need to be mutable [INFO] [stdout] --> n032_Longest_Valid_Parentheses/src/main.rs:23:19 [INFO] [stdout] | [INFO] [stdout] 23 | let mut tmp = i + 1 - l; [INFO] [stdout] | ----^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `thread` and `time` [INFO] [stdout] --> n018_4Sum/src/main.rs:1:11 [INFO] [stdout] | [INFO] [stdout] 1 | use std::{thread,time}; [INFO] [stdout] | ^^^^^^ ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> add_two_numbers/src/main.rs:9:6 [INFO] [stdout] | [INFO] [stdout] 7 | impl ListNode { [INFO] [stdout] | ------------- associated function in this implementation [INFO] [stdout] 8 | #[inline] [INFO] [stdout] 9 | fn new(val: i32) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `vec2List` should have a snake case name [INFO] [stdout] --> add_two_numbers/src/main.rs:71:4 [INFO] [stdout] | [INFO] [stdout] 71 | fn vec2List(vals: Vec) -> Option> { [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to snake case: `vec2_list` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> etudes/src/util/mod.rs:153:11 [INFO] [stdout] | [INFO] [stdout] 153 | let a: &TraitA = &StructA {}; [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021! [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn` [INFO] [stdout] | [INFO] [stdout] 153 | let a: &dyn TraitA = &StructA {}; [INFO] [stdout] | +++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s1` [INFO] [stdout] --> Longest_Substring_Without_Repeating_Characters/src/main.rs:44:7 [INFO] [stdout] | [INFO] [stdout] 44 | let s1 = "abcdefg"; [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s1` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `s2` [INFO] [stdout] --> Longest_Substring_Without_Repeating_Characters/src/main.rs:45:7 [INFO] [stdout] | [INFO] [stdout] 45 | let s2 = "aaaaaaa"; [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] --> Longest_Substring_Without_Repeating_Characters/src/main.rs:46:7 [INFO] [stdout] | [INFO] [stdout] 46 | let s3 = "abcdaabc"; [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_s3` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> etudes/src/util/mod.rs:124:7 [INFO] [stdout] | [INFO] [stdout] 124 | let mut a = Wrapper(&s); [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: `a` [INFO] [stdout] --> etudes/src/util/mod.rs:153:7 [INFO] [stdout] | [INFO] [stdout] 153 | let a: &TraitA = &StructA {}; [INFO] [stdout] | ^ help: if this is intentional, prefix it with an underscore: `_a` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `TraitB` is never used [INFO] [stdout] --> etudes/src/util/mod.rs:144:7 [INFO] [stdout] | [INFO] [stdout] 144 | trait TraitB: Sized {} [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "cfe5c37e7a40562e90bb165f1e1c0f612b79667229677bbcca86d1fbf37bb0e3", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cfe5c37e7a40562e90bb165f1e1c0f612b79667229677bbcca86d1fbf37bb0e3", kill_on_drop: false }` [INFO] [stdout] cfe5c37e7a40562e90bb165f1e1c0f612b79667229677bbcca86d1fbf37bb0e3