Nov 30 08:38:39.401 INFO checking ShaunApps/cryptopals-challenges against try#32252761328f59ccfadb1bafb8148c685bc830b3 for pr-56323 Nov 30 08:38:39.401 INFO running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-56323/worker-5/try#32252761328f59ccfadb1bafb8148c685bc830b3:/target:rw,Z" "-v" "/mnt/big/crater/work/local/test-source/worker-5/pr-56323/try#32252761328f59ccfadb1bafb8148c685bc830b3:/source:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/source" "-e" "USER_ID=1000" "-e" "CMD=cargo +32252761328f59ccfadb1bafb8148c685bc830b3-alt check --frozen --all --all-targets" "-e" "CARGO_TARGET_DIR=/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/cargo-home" "-e" "RUSTUP_HOME=/rustup-home" "-m" "1536M" "--network" "none" "crater"` Nov 30 08:38:39.688 INFO [stdout] cbaee4a5834e07717bae85f3c154e6e7eb9ffaf8c1ad9f7196769a030ff73921 Nov 30 08:38:39.688 INFO running `"docker" "start" "-a" "cbaee4a5834e07717bae85f3c154e6e7eb9ffaf8c1ad9f7196769a030ff73921"` Nov 30 08:38:40.512 INFO [stderr] usermod: no changes Nov 30 08:38:40.587 INFO [stderr] Checking cryptopals v0.1.0 (/source) Nov 30 08:38:41.889 INFO [stderr] warning: unused import: `hex` Nov 30 08:38:41.889 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:4:5 Nov 30 08:38:41.889 INFO [stderr] | Nov 30 08:38:41.889 INFO [stderr] 4 | use hex; Nov 30 08:38:41.889 INFO [stderr] | ^^^ Nov 30 08:38:41.889 INFO [stderr] | Nov 30 08:38:41.889 INFO [stderr] = note: #[warn(unused_imports)] on by default Nov 30 08:38:41.889 INFO [stderr] Nov 30 08:38:41.896 INFO [stderr] warning: unused import: `std::io` Nov 30 08:38:41.896 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:7:5 Nov 30 08:38:41.896 INFO [stderr] | Nov 30 08:38:41.896 INFO [stderr] 7 | use std::io; Nov 30 08:38:41.896 INFO [stderr] | ^^^^^^^ Nov 30 08:38:41.896 INFO [stderr] Nov 30 08:38:41.896 INFO [stderr] warning: unused import: `std::io::BufRead` Nov 30 08:38:41.896 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:9:5 Nov 30 08:38:41.896 INFO [stderr] | Nov 30 08:38:41.896 INFO [stderr] 9 | use std::io::BufRead; Nov 30 08:38:41.896 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 30 08:38:41.896 INFO [stderr] Nov 30 08:38:41.896 INFO [stderr] warning: unused import: `std::io::BufReader` Nov 30 08:38:41.896 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:10:5 Nov 30 08:38:41.896 INFO [stderr] | Nov 30 08:38:41.896 INFO [stderr] 10 | use std::io::BufReader; Nov 30 08:38:41.896 INFO [stderr] | ^^^^^^^^^^^^^^^^^^ Nov 30 08:38:41.896 INFO [stderr] Nov 30 08:38:41.896 INFO [stderr] warning: unused import: `std::path::Path` Nov 30 08:38:41.896 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:11:5 Nov 30 08:38:41.896 INFO [stderr] | Nov 30 08:38:41.896 INFO [stderr] 11 | use std::path::Path; Nov 30 08:38:41.896 INFO [stderr] | ^^^^^^^^^^^^^^^ Nov 30 08:38:41.896 INFO [stderr] Nov 30 08:38:41.896 INFO [stderr] warning: unused import: `std::str` Nov 30 08:38:41.896 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:12:5 Nov 30 08:38:41.896 INFO [stderr] | Nov 30 08:38:41.896 INFO [stderr] 12 | use std::str; Nov 30 08:38:41.896 INFO [stderr] | ^^^^^^^^ Nov 30 08:38:41.896 INFO [stderr] Nov 30 08:38:41.896 INFO [stderr] warning: unused import: `base64` Nov 30 08:38:41.896 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:1:5 Nov 30 08:38:41.896 INFO [stderr] | Nov 30 08:38:41.896 INFO [stderr] 1 | use base64; Nov 30 08:38:41.896 INFO [stderr] | ^^^^^^ Nov 30 08:38:41.896 INFO [stderr] Nov 30 08:38:41.896 INFO [stderr] warning: unused import: `rand::prelude::*` Nov 30 08:38:41.896 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:4:5 Nov 30 08:38:41.896 INFO [stderr] | Nov 30 08:38:41.896 INFO [stderr] 4 | use rand::prelude::*; Nov 30 08:38:41.896 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 30 08:38:41.896 INFO [stderr] Nov 30 08:38:41.896 INFO [stderr] warning: unused imports: `OsRng`, `Rng` Nov 30 08:38:41.896 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:5:12 Nov 30 08:38:41.896 INFO [stderr] | Nov 30 08:38:41.896 INFO [stderr] 5 | use rand::{OsRng, Rng}; Nov 30 08:38:41.896 INFO [stderr] | ^^^^^ ^^^ Nov 30 08:38:41.896 INFO [stderr] Nov 30 08:38:41.896 INFO [stderr] warning: unused import: `std::fs::File` Nov 30 08:38:41.896 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:6:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 6 | use std::fs::File; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^^^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unused import: `std::io::prelude::*` Nov 30 08:38:41.897 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:7:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 7 | use std::io::prelude::*; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unused import: `std::io::BufRead` Nov 30 08:38:41.897 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:8:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 8 | use std::io::BufRead; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unused import: `std::io::BufReader` Nov 30 08:38:41.897 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:9:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 9 | use std::io::BufReader; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^^^^^^^^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unused import: `std::str` Nov 30 08:38:41.897 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:10:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 10 | use std::str; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unused import: `std::path::Path` Nov 30 08:38:41.897 INFO [stderr] --> src/challenge_set_1/detect_single_char_xor.rs:5:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 5 | use std::path::Path; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^^^^^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unused import: `base64` Nov 30 08:38:41.897 INFO [stderr] --> src/challenge_set_1/fixed_XOR.rs:1:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 1 | use base64; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unused import: `std::str::from_utf8` Nov 30 08:38:41.897 INFO [stderr] --> src/challenge_set_1/repeating_key_xor.rs:2:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 2 | use std::str::from_utf8; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unnecessary parentheses around `if` condition Nov 30 08:38:41.897 INFO [stderr] --> src/challenge_set_1/repeating_key_xor.rs:11:12 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 11 | if ((index + 1) == key.as_bytes().len()) { Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] = note: #[warn(unused_parens)] on by default Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unused import: `base64` Nov 30 08:38:41.897 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:1:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 1 | use base64; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unused import: `challenge_set_1::detect_single_char_xor::detect_sing_char_xor` Nov 30 08:38:41.897 INFO [stderr] --> src/main.rs:8:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 8 | use challenge_set_1::detect_single_char_xor::detect_sing_char_xor; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:41.897 INFO [stderr] warning: unused import: `challenge_set_1::single_byte_xor_cipher::single_byte_xor_cipher` Nov 30 08:38:41.897 INFO [stderr] --> src/main.rs:10:5 Nov 30 08:38:41.897 INFO [stderr] | Nov 30 08:38:41.897 INFO [stderr] 10 | use challenge_set_1::single_byte_xor_cipher::single_byte_xor_cipher; Nov 30 08:38:41.897 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:41.897 INFO [stderr] Nov 30 08:38:42.216 INFO [stderr] warning: unused import: `hex` Nov 30 08:38:42.216 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:4:5 Nov 30 08:38:42.216 INFO [stderr] | Nov 30 08:38:42.216 INFO [stderr] 4 | use hex; Nov 30 08:38:42.216 INFO [stderr] | ^^^ Nov 30 08:38:42.216 INFO [stderr] | Nov 30 08:38:42.220 INFO [stderr] = note: #[warn(unused_imports)] on by default Nov 30 08:38:42.220 INFO [stderr] Nov 30 08:38:42.220 INFO [stderr] warning: unused import: `std::io` Nov 30 08:38:42.220 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:7:5 Nov 30 08:38:42.220 INFO [stderr] | Nov 30 08:38:42.220 INFO [stderr] 7 | use std::io; Nov 30 08:38:42.220 INFO [stderr] | ^^^^^^^ Nov 30 08:38:42.220 INFO [stderr] Nov 30 08:38:42.220 INFO [stderr] warning: unused import: `std::io::BufRead` Nov 30 08:38:42.220 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:9:5 Nov 30 08:38:42.220 INFO [stderr] | Nov 30 08:38:42.220 INFO [stderr] 9 | use std::io::BufRead; Nov 30 08:38:42.220 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 30 08:38:42.220 INFO [stderr] Nov 30 08:38:42.220 INFO [stderr] warning: unused import: `std::io::BufReader` Nov 30 08:38:42.220 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:10:5 Nov 30 08:38:42.220 INFO [stderr] | Nov 30 08:38:42.220 INFO [stderr] 10 | use std::io::BufReader; Nov 30 08:38:42.220 INFO [stderr] | ^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.220 INFO [stderr] Nov 30 08:38:42.220 INFO [stderr] warning: unused import: `std::path::Path` Nov 30 08:38:42.220 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:11:5 Nov 30 08:38:42.220 INFO [stderr] | Nov 30 08:38:42.220 INFO [stderr] 11 | use std::path::Path; Nov 30 08:38:42.220 INFO [stderr] | ^^^^^^^^^^^^^^^ Nov 30 08:38:42.220 INFO [stderr] Nov 30 08:38:42.220 INFO [stderr] warning: unused import: `rand::prelude::*` Nov 30 08:38:42.220 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:4:5 Nov 30 08:38:42.220 INFO [stderr] | Nov 30 08:38:42.220 INFO [stderr] 4 | use rand::prelude::*; Nov 30 08:38:42.220 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 30 08:38:42.220 INFO [stderr] Nov 30 08:38:42.220 INFO [stderr] warning: unused imports: `OsRng`, `Rng` Nov 30 08:38:42.220 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:5:12 Nov 30 08:38:42.220 INFO [stderr] | Nov 30 08:38:42.220 INFO [stderr] 5 | use rand::{OsRng, Rng}; Nov 30 08:38:42.220 INFO [stderr] | ^^^^^ ^^^ Nov 30 08:38:42.220 INFO [stderr] Nov 30 08:38:42.220 INFO [stderr] warning: unused import: `std::io::prelude::*` Nov 30 08:38:42.220 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:7:5 Nov 30 08:38:42.220 INFO [stderr] | Nov 30 08:38:42.220 INFO [stderr] 7 | use std::io::prelude::*; Nov 30 08:38:42.220 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.220 INFO [stderr] Nov 30 08:38:42.220 INFO [stderr] warning: unused import: `std::io::BufRead` Nov 30 08:38:42.220 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:8:5 Nov 30 08:38:42.220 INFO [stderr] | Nov 30 08:38:42.220 INFO [stderr] 8 | use std::io::BufRead; Nov 30 08:38:42.220 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 30 08:38:42.220 INFO [stderr] Nov 30 08:38:42.220 INFO [stderr] warning: unused import: `std::str` Nov 30 08:38:42.220 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:10:5 Nov 30 08:38:42.220 INFO [stderr] | Nov 30 08:38:42.220 INFO [stderr] 10 | use std::str; Nov 30 08:38:42.220 INFO [stderr] | ^^^^^^^^ Nov 30 08:38:42.220 INFO [stderr] Nov 30 08:38:42.221 INFO [stderr] warning: unused import: `std::path::Path` Nov 30 08:38:42.221 INFO [stderr] --> src/challenge_set_1/detect_single_char_xor.rs:5:5 Nov 30 08:38:42.225 INFO [stderr] | Nov 30 08:38:42.225 INFO [stderr] 5 | use std::path::Path; Nov 30 08:38:42.225 INFO [stderr] | ^^^^^^^^^^^^^^^ Nov 30 08:38:42.225 INFO [stderr] Nov 30 08:38:42.225 INFO [stderr] warning: unused import: `base64` Nov 30 08:38:42.225 INFO [stderr] --> src/challenge_set_1/fixed_XOR.rs:1:5 Nov 30 08:38:42.225 INFO [stderr] | Nov 30 08:38:42.225 INFO [stderr] 1 | use base64; Nov 30 08:38:42.225 INFO [stderr] | ^^^^^^ Nov 30 08:38:42.225 INFO [stderr] Nov 30 08:38:42.225 INFO [stderr] warning: unused import: `std::str::from_utf8` Nov 30 08:38:42.225 INFO [stderr] --> src/challenge_set_1/repeating_key_xor.rs:2:5 Nov 30 08:38:42.225 INFO [stderr] | Nov 30 08:38:42.225 INFO [stderr] 2 | use std::str::from_utf8; Nov 30 08:38:42.225 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.225 INFO [stderr] Nov 30 08:38:42.225 INFO [stderr] warning: unnecessary parentheses around `if` condition Nov 30 08:38:42.225 INFO [stderr] --> src/challenge_set_1/repeating_key_xor.rs:11:12 Nov 30 08:38:42.225 INFO [stderr] | Nov 30 08:38:42.225 INFO [stderr] 11 | if ((index + 1) == key.as_bytes().len()) { Nov 30 08:38:42.225 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses Nov 30 08:38:42.225 INFO [stderr] | Nov 30 08:38:42.225 INFO [stderr] = note: #[warn(unused_parens)] on by default Nov 30 08:38:42.225 INFO [stderr] Nov 30 08:38:42.228 INFO [stderr] warning: unused import: `base64` Nov 30 08:38:42.228 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:1:5 Nov 30 08:38:42.228 INFO [stderr] | Nov 30 08:38:42.228 INFO [stderr] 1 | use base64; Nov 30 08:38:42.228 INFO [stderr] | ^^^^^^ Nov 30 08:38:42.228 INFO [stderr] Nov 30 08:38:42.228 INFO [stderr] warning: unused import: `super::*` Nov 30 08:38:42.228 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:88:9 Nov 30 08:38:42.228 INFO [stderr] | Nov 30 08:38:42.228 INFO [stderr] 88 | use super::*; Nov 30 08:38:42.228 INFO [stderr] | ^^^^^^^^ Nov 30 08:38:42.228 INFO [stderr] Nov 30 08:38:42.228 INFO [stderr] warning: unused import: `challenge_set_1::detect_single_char_xor::detect_sing_char_xor` Nov 30 08:38:42.228 INFO [stderr] --> src/main.rs:8:5 Nov 30 08:38:42.228 INFO [stderr] | Nov 30 08:38:42.228 INFO [stderr] 8 | use challenge_set_1::detect_single_char_xor::detect_sing_char_xor; Nov 30 08:38:42.228 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.228 INFO [stderr] Nov 30 08:38:42.228 INFO [stderr] warning: unused import: `challenge_set_1::single_byte_xor_cipher::single_byte_xor_cipher` Nov 30 08:38:42.228 INFO [stderr] --> src/main.rs:10:5 Nov 30 08:38:42.228 INFO [stderr] | Nov 30 08:38:42.228 INFO [stderr] 10 | use challenge_set_1::single_byte_xor_cipher::single_byte_xor_cipher; Nov 30 08:38:42.228 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.228 INFO [stderr] Nov 30 08:38:42.246 INFO [stderr] warning: variable `phrase` is assigned to, but never used Nov 30 08:38:42.246 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:24:13 Nov 30 08:38:42.246 INFO [stderr] | Nov 30 08:38:42.246 INFO [stderr] 24 | let mut phrase: String = "".to_string(); Nov 30 08:38:42.246 INFO [stderr] | ^^^^^^ Nov 30 08:38:42.246 INFO [stderr] | Nov 30 08:38:42.246 INFO [stderr] = note: #[warn(unused_variables)] on by default Nov 30 08:38:42.246 INFO [stderr] = note: consider using `_phrase` instead Nov 30 08:38:42.246 INFO [stderr] Nov 30 08:38:42.246 INFO [stderr] warning: value assigned to `phrase` is never read Nov 30 08:38:42.246 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:33:13 Nov 30 08:38:42.246 INFO [stderr] | Nov 30 08:38:42.246 INFO [stderr] 33 | phrase = match thing { Nov 30 08:38:42.246 INFO [stderr] | ^^^^^^ Nov 30 08:38:42.246 INFO [stderr] | Nov 30 08:38:42.246 INFO [stderr] = note: #[warn(unused_assignments)] on by default Nov 30 08:38:42.246 INFO [stderr] Nov 30 08:38:42.246 INFO [stderr] warning: unused variable: `error` Nov 30 08:38:42.246 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:35:21 Nov 30 08:38:42.246 INFO [stderr] | Nov 30 08:38:42.246 INFO [stderr] 35 | Err(error) => String::from(""), Nov 30 08:38:42.246 INFO [stderr] | ^^^^^ help: consider using `_error` instead Nov 30 08:38:42.246 INFO [stderr] Nov 30 08:38:42.246 INFO [stderr] warning: unused variable: `value` Nov 30 08:38:42.246 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:84:15 Nov 30 08:38:42.246 INFO [stderr] | Nov 30 08:38:42.246 INFO [stderr] 84 | for (key, value) in key_map.iter() { Nov 30 08:38:42.246 INFO [stderr] | ^^^^^ help: consider using `_value` instead Nov 30 08:38:42.246 INFO [stderr] Nov 30 08:38:42.246 INFO [stderr] warning: unused variable: `e` Nov 30 08:38:42.246 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:44:13 Nov 30 08:38:42.246 INFO [stderr] | Nov 30 08:38:42.246 INFO [stderr] 44 | Err(e) => String::from(""), Nov 30 08:38:42.246 INFO [stderr] | ^ help: consider using `_e` instead Nov 30 08:38:42.246 INFO [stderr] Nov 30 08:38:42.246 INFO [stderr] warning: unused variable: `length` Nov 30 08:38:42.246 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:57:9 Nov 30 08:38:42.246 INFO [stderr] | Nov 30 08:38:42.246 INFO [stderr] 57 | let length = data_as_bytes.len(); Nov 30 08:38:42.246 INFO [stderr] | ^^^^^^ help: consider using `_length` instead Nov 30 08:38:42.246 INFO [stderr] Nov 30 08:38:42.246 INFO [stderr] warning: unused variable: `error` Nov 30 08:38:42.246 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:78:21 Nov 30 08:38:42.246 INFO [stderr] | Nov 30 08:38:42.246 INFO [stderr] 78 | Err(error) => String::from(""), Nov 30 08:38:42.247 INFO [stderr] | ^^^^^ help: consider using `_error` instead Nov 30 08:38:42.247 INFO [stderr] Nov 30 08:38:42.336 INFO [stderr] warning: function is never used: `solve_blocks` Nov 30 08:38:42.336 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:14:1 Nov 30 08:38:42.336 INFO [stderr] | Nov 30 08:38:42.336 INFO [stderr] 14 | fn solve_blocks(blocks: Vec>) -> Vec { Nov 30 08:38:42.336 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.336 INFO [stderr] | Nov 30 08:38:42.336 INFO [stderr] = note: #[warn(dead_code)] on by default Nov 30 08:38:42.336 INFO [stderr] Nov 30 08:38:42.336 INFO [stderr] warning: function is never used: `break_ciphertext_into_blocks` Nov 30 08:38:42.336 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:42:1 Nov 30 08:38:42.336 INFO [stderr] | Nov 30 08:38:42.336 INFO [stderr] 42 | fn break_ciphertext_into_blocks(keysize: u8) -> Vec> { Nov 30 08:38:42.336 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.336 INFO [stderr] Nov 30 08:38:42.336 INFO [stderr] warning: function is never used: `find_smallest_KEYSIZE` Nov 30 08:38:42.336 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:76:1 Nov 30 08:38:42.336 INFO [stderr] | Nov 30 08:38:42.336 INFO [stderr] 76 | fn find_smallest_KEYSIZE() -> Vec { Nov 30 08:38:42.336 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.336 INFO [stderr] Nov 30 08:38:42.336 INFO [stderr] warning: function is never used: `normalized_KEYSIZE` Nov 30 08:38:42.336 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:96:1 Nov 30 08:38:42.336 INFO [stderr] | Nov 30 08:38:42.336 INFO [stderr] 96 | fn normalized_KEYSIZE(key_guess: u8) -> f64 { Nov 30 08:38:42.336 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.336 INFO [stderr] Nov 30 08:38:42.336 INFO [stderr] warning: function is never used: `decrypt` Nov 30 08:38:42.336 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:13:1 Nov 30 08:38:42.336 INFO [stderr] | Nov 30 08:38:42.336 INFO [stderr] 13 | / fn decrypt( Nov 30 08:38:42.336 INFO [stderr] 14 | | encrypted_data: &[u8], Nov 30 08:38:42.336 INFO [stderr] 15 | | key: &[u8], Nov 30 08:38:42.336 INFO [stderr] 16 | | ) -> Result, symmetriccipher::SymmetricCipherError> { Nov 30 08:38:42.336 INFO [stderr] ... | Nov 30 08:38:42.336 INFO [stderr] 39 | | Ok(final_result) Nov 30 08:38:42.336 INFO [stderr] 40 | | } Nov 30 08:38:42.336 INFO [stderr] | |_^ Nov 30 08:38:42.336 INFO [stderr] Nov 30 08:38:42.336 INFO [stderr] warning: function `find_smallest_KEYSIZE` should have a snake case name such as `find_smallest_keysize` Nov 30 08:38:42.336 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:76:1 Nov 30 08:38:42.336 INFO [stderr] | Nov 30 08:38:42.336 INFO [stderr] 76 | / fn find_smallest_KEYSIZE() -> Vec { Nov 30 08:38:42.336 INFO [stderr] 77 | | let mut key_map: HashMap = HashMap::new(); Nov 30 08:38:42.336 INFO [stderr] 78 | | Nov 30 08:38:42.336 INFO [stderr] 79 | | for i in 1..=40 { Nov 30 08:38:42.336 INFO [stderr] ... | Nov 30 08:38:42.336 INFO [stderr] 92 | | vec![value1, value2, value3] Nov 30 08:38:42.337 INFO [stderr] 93 | | } Nov 30 08:38:42.337 INFO [stderr] | |_^ Nov 30 08:38:42.337 INFO [stderr] | Nov 30 08:38:42.337 INFO [stderr] = note: #[warn(non_snake_case)] on by default Nov 30 08:38:42.337 INFO [stderr] Nov 30 08:38:42.337 INFO [stderr] warning: function `normalized_KEYSIZE` should have a snake case name such as `normalized_keysize` Nov 30 08:38:42.337 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:96:1 Nov 30 08:38:42.337 INFO [stderr] | Nov 30 08:38:42.337 INFO [stderr] 96 | / fn normalized_KEYSIZE(key_guess: u8) -> f64 { Nov 30 08:38:42.337 INFO [stderr] 97 | | let mut f = File::open("1_challenge_6.txt").unwrap(); Nov 30 08:38:42.337 INFO [stderr] 98 | | Nov 30 08:38:42.337 INFO [stderr] 99 | | let mut contents = String::new(); Nov 30 08:38:42.337 INFO [stderr] ... | Nov 30 08:38:42.337 INFO [stderr] 114 | | final_distance / pairs as f64 Nov 30 08:38:42.337 INFO [stderr] 115 | | } Nov 30 08:38:42.337 INFO [stderr] | |_^ Nov 30 08:38:42.337 INFO [stderr] Nov 30 08:38:42.337 INFO [stderr] warning: module `fixed_XOR` should have a snake case name such as `fixed_xor` Nov 30 08:38:42.337 INFO [stderr] --> src/challenge_set_1/mod.rs:7:1 Nov 30 08:38:42.337 INFO [stderr] | Nov 30 08:38:42.337 INFO [stderr] 7 | pub mod fixed_XOR; Nov 30 08:38:42.337 INFO [stderr] | ^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.337 INFO [stderr] Nov 30 08:38:42.337 INFO [stderr] warning: function `fixed_XOR` should have a snake case name such as `fixed_xor` Nov 30 08:38:42.337 INFO [stderr] --> src/challenge_set_1/fixed_XOR.rs:19:1 Nov 30 08:38:42.337 INFO [stderr] | Nov 30 08:38:42.337 INFO [stderr] 19 | / pub fn fixed_XOR(data_1: &str, data_2: &str) -> String { Nov 30 08:38:42.337 INFO [stderr] 20 | | let one = hex::decode(data_1).unwrap(); Nov 30 08:38:42.337 INFO [stderr] 21 | | let two = hex::decode(data_2).unwrap(); Nov 30 08:38:42.337 INFO [stderr] 22 | | let xor = BytesXOR(one) ^ BytesXOR(two); Nov 30 08:38:42.337 INFO [stderr] 23 | | hex::encode(xor.0) Nov 30 08:38:42.337 INFO [stderr] 24 | | } Nov 30 08:38:42.337 INFO [stderr] | |_^ Nov 30 08:38:42.337 INFO [stderr] Nov 30 08:38:42.451 INFO [stderr] warning: variable `phrase` is assigned to, but never used Nov 30 08:38:42.451 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:24:13 Nov 30 08:38:42.451 INFO [stderr] | Nov 30 08:38:42.451 INFO [stderr] 24 | let mut phrase: String = "".to_string(); Nov 30 08:38:42.451 INFO [stderr] | ^^^^^^ Nov 30 08:38:42.451 INFO [stderr] | Nov 30 08:38:42.451 INFO [stderr] = note: #[warn(unused_variables)] on by default Nov 30 08:38:42.451 INFO [stderr] = note: consider using `_phrase` instead Nov 30 08:38:42.451 INFO [stderr] Nov 30 08:38:42.451 INFO [stderr] warning: value assigned to `phrase` is never read Nov 30 08:38:42.451 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:33:13 Nov 30 08:38:42.451 INFO [stderr] | Nov 30 08:38:42.451 INFO [stderr] 33 | phrase = match thing { Nov 30 08:38:42.451 INFO [stderr] | ^^^^^^ Nov 30 08:38:42.451 INFO [stderr] | Nov 30 08:38:42.451 INFO [stderr] = note: #[warn(unused_assignments)] on by default Nov 30 08:38:42.452 INFO [stderr] Nov 30 08:38:42.452 INFO [stderr] warning: unused variable: `error` Nov 30 08:38:42.452 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:35:21 Nov 30 08:38:42.452 INFO [stderr] | Nov 30 08:38:42.452 INFO [stderr] 35 | Err(error) => String::from(""), Nov 30 08:38:42.452 INFO [stderr] | ^^^^^ help: consider using `_error` instead Nov 30 08:38:42.452 INFO [stderr] Nov 30 08:38:42.452 INFO [stderr] warning: unused variable: `value` Nov 30 08:38:42.452 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:84:15 Nov 30 08:38:42.452 INFO [stderr] | Nov 30 08:38:42.452 INFO [stderr] 84 | for (key, value) in key_map.iter() { Nov 30 08:38:42.452 INFO [stderr] | ^^^^^ help: consider using `_value` instead Nov 30 08:38:42.452 INFO [stderr] Nov 30 08:38:42.452 INFO [stderr] warning: unused variable: `e` Nov 30 08:38:42.452 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:44:13 Nov 30 08:38:42.452 INFO [stderr] | Nov 30 08:38:42.452 INFO [stderr] 44 | Err(e) => String::from(""), Nov 30 08:38:42.452 INFO [stderr] | ^ help: consider using `_e` instead Nov 30 08:38:42.452 INFO [stderr] Nov 30 08:38:42.452 INFO [stderr] warning: unused variable: `length` Nov 30 08:38:42.452 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:57:9 Nov 30 08:38:42.452 INFO [stderr] | Nov 30 08:38:42.452 INFO [stderr] 57 | let length = data_as_bytes.len(); Nov 30 08:38:42.452 INFO [stderr] | ^^^^^^ help: consider using `_length` instead Nov 30 08:38:42.452 INFO [stderr] Nov 30 08:38:42.452 INFO [stderr] warning: unused variable: `error` Nov 30 08:38:42.452 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:78:21 Nov 30 08:38:42.452 INFO [stderr] | Nov 30 08:38:42.452 INFO [stderr] 78 | Err(error) => String::from(""), Nov 30 08:38:42.452 INFO [stderr] | ^^^^^ help: consider using `_error` instead Nov 30 08:38:42.452 INFO [stderr] Nov 30 08:38:42.486 INFO [stderr] warning: variable does not need to be mutable Nov 30 08:38:42.486 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:48:13 Nov 30 08:38:42.486 INFO [stderr] | Nov 30 08:38:42.486 INFO [stderr] 48 | let mut f = File::open("1_challenge_7.txt").unwrap(); Nov 30 08:38:42.486 INFO [stderr] | ----^ Nov 30 08:38:42.486 INFO [stderr] | | Nov 30 08:38:42.486 INFO [stderr] | help: remove this `mut` Nov 30 08:38:42.486 INFO [stderr] | Nov 30 08:38:42.486 INFO [stderr] = note: #[warn(unused_mut)] on by default Nov 30 08:38:42.486 INFO [stderr] Nov 30 08:38:42.486 INFO [stderr] warning: variable does not need to be mutable Nov 30 08:38:42.486 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:49:13 Nov 30 08:38:42.486 INFO [stderr] | Nov 30 08:38:42.486 INFO [stderr] 49 | let mut buf_reader = BufReader::new(f); Nov 30 08:38:42.486 INFO [stderr] | ----^^^^^^^^^^ Nov 30 08:38:42.486 INFO [stderr] | | Nov 30 08:38:42.486 INFO [stderr] | help: remove this `mut` Nov 30 08:38:42.486 INFO [stderr] Nov 30 08:38:42.503 INFO [stderr] warning: function `find_smallest_KEYSIZE` should have a snake case name such as `find_smallest_keysize` Nov 30 08:38:42.503 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:76:1 Nov 30 08:38:42.503 INFO [stderr] | Nov 30 08:38:42.503 INFO [stderr] 76 | / fn find_smallest_KEYSIZE() -> Vec { Nov 30 08:38:42.503 INFO [stderr] 77 | | let mut key_map: HashMap = HashMap::new(); Nov 30 08:38:42.504 INFO [stderr] 78 | | Nov 30 08:38:42.504 INFO [stderr] 79 | | for i in 1..=40 { Nov 30 08:38:42.504 INFO [stderr] ... | Nov 30 08:38:42.504 INFO [stderr] 92 | | vec![value1, value2, value3] Nov 30 08:38:42.504 INFO [stderr] 93 | | } Nov 30 08:38:42.504 INFO [stderr] | |_^ Nov 30 08:38:42.504 INFO [stderr] | Nov 30 08:38:42.504 INFO [stderr] = note: #[warn(non_snake_case)] on by default Nov 30 08:38:42.504 INFO [stderr] Nov 30 08:38:42.504 INFO [stderr] warning: function `normalized_KEYSIZE` should have a snake case name such as `normalized_keysize` Nov 30 08:38:42.504 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:96:1 Nov 30 08:38:42.504 INFO [stderr] | Nov 30 08:38:42.504 INFO [stderr] 96 | / fn normalized_KEYSIZE(key_guess: u8) -> f64 { Nov 30 08:38:42.504 INFO [stderr] 97 | | let mut f = File::open("1_challenge_6.txt").unwrap(); Nov 30 08:38:42.504 INFO [stderr] 98 | | Nov 30 08:38:42.504 INFO [stderr] 99 | | let mut contents = String::new(); Nov 30 08:38:42.504 INFO [stderr] ... | Nov 30 08:38:42.504 INFO [stderr] 114 | | final_distance / pairs as f64 Nov 30 08:38:42.504 INFO [stderr] 115 | | } Nov 30 08:38:42.504 INFO [stderr] | |_^ Nov 30 08:38:42.504 INFO [stderr] Nov 30 08:38:42.506 INFO [stderr] warning: module `fixed_XOR` should have a snake case name such as `fixed_xor` Nov 30 08:38:42.506 INFO [stderr] --> src/challenge_set_1/mod.rs:7:1 Nov 30 08:38:42.506 INFO [stderr] | Nov 30 08:38:42.506 INFO [stderr] 7 | pub mod fixed_XOR; Nov 30 08:38:42.506 INFO [stderr] | ^^^^^^^^^^^^^^^^^^ Nov 30 08:38:42.506 INFO [stderr] Nov 30 08:38:42.510 INFO [stderr] warning: function `fixed_XOR` should have a snake case name such as `fixed_xor` Nov 30 08:38:42.510 INFO [stderr] --> src/challenge_set_1/fixed_XOR.rs:19:1 Nov 30 08:38:42.510 INFO [stderr] | Nov 30 08:38:42.510 INFO [stderr] 19 | / pub fn fixed_XOR(data_1: &str, data_2: &str) -> String { Nov 30 08:38:42.510 INFO [stderr] 20 | | let one = hex::decode(data_1).unwrap(); Nov 30 08:38:42.510 INFO [stderr] 21 | | let two = hex::decode(data_2).unwrap(); Nov 30 08:38:42.510 INFO [stderr] 22 | | let xor = BytesXOR(one) ^ BytesXOR(two); Nov 30 08:38:42.510 INFO [stderr] 23 | | hex::encode(xor.0) Nov 30 08:38:42.510 INFO [stderr] 24 | | } Nov 30 08:38:42.510 INFO [stderr] | |_^ Nov 30 08:38:42.510 INFO [stderr] Nov 30 08:38:42.510 INFO [stderr] warning: function `test_fixed_XOR` should have a snake case name such as `test_fixed_xor` Nov 30 08:38:42.510 INFO [stderr] --> src/challenge_set_1/fixed_XOR.rs:31:5 Nov 30 08:38:42.510 INFO [stderr] | Nov 30 08:38:42.510 INFO [stderr] 31 | / fn test_fixed_XOR() { Nov 30 08:38:42.510 INFO [stderr] 32 | | let data_1 = "1c0111001f010100061a024b53535009181c"; Nov 30 08:38:42.510 INFO [stderr] 33 | | let data_2 = "686974207468652062756c6c277320657965"; Nov 30 08:38:42.510 INFO [stderr] 34 | | assert_eq!( Nov 30 08:38:42.510 INFO [stderr] ... | Nov 30 08:38:42.510 INFO [stderr] 37 | | ); Nov 30 08:38:42.510 INFO [stderr] 38 | | } Nov 30 08:38:42.510 INFO [stderr] | |_____^ Nov 30 08:38:42.510 INFO [stderr] Nov 30 08:38:42.528 INFO [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1.99s Nov 30 08:38:42.536 INFO [stderr] su: No module specific data is present Nov 30 08:38:43.066 INFO running `"docker" "inspect" "cbaee4a5834e07717bae85f3c154e6e7eb9ffaf8c1ad9f7196769a030ff73921"` Nov 30 08:38:43.289 INFO running `"docker" "rm" "-f" "cbaee4a5834e07717bae85f3c154e6e7eb9ffaf8c1ad9f7196769a030ff73921"` Nov 30 08:38:43.496 INFO [stdout] cbaee4a5834e07717bae85f3c154e6e7eb9ffaf8c1ad9f7196769a030ff73921