Nov 28 11:06:26.388 INFO checking ShaunApps/cryptopals-challenges against master#0b9f19dff1347e29bf4362ab5a8fab84b43023b5 for pr-56074 Nov 28 11:06:26.388 INFO running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-56074/worker-2/master#0b9f19dff1347e29bf4362ab5a8fab84b43023b5:/target:rw,Z" "-v" "/mnt/big/crater/work/local/test-source/worker-2/pr-56074/master#0b9f19dff1347e29bf4362ab5a8fab84b43023b5:/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 +0b9f19dff1347e29bf4362ab5a8fab84b43023b5-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 28 11:06:26.727 INFO [stdout] 1d4a3bc3acbd846caa493983682693d76f02dd4260a80ed46b0cbb8d7487be7f Nov 28 11:06:26.729 INFO running `"docker" "start" "-a" "1d4a3bc3acbd846caa493983682693d76f02dd4260a80ed46b0cbb8d7487be7f"` Nov 28 11:06:27.480 INFO [stderr] usermod: no changes Nov 28 11:06:27.656 INFO [stderr] Checking cryptopals v0.1.0 (/source) Nov 28 11:06:28.677 INFO [stderr] warning: unused import: `hex` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:4:5 Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] 4 | use hex; Nov 28 11:06:28.677 INFO [stderr] | ^^^ Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] = note: #[warn(unused_imports)] on by default Nov 28 11:06:28.677 INFO [stderr] Nov 28 11:06:28.677 INFO [stderr] warning: unused import: `std::io` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:7:5 Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] 7 | use std::io; Nov 28 11:06:28.677 INFO [stderr] | ^^^^^^^ Nov 28 11:06:28.677 INFO [stderr] Nov 28 11:06:28.677 INFO [stderr] warning: unused import: `std::io::BufRead` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:9:5 Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] 9 | use std::io::BufRead; Nov 28 11:06:28.677 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 28 11:06:28.677 INFO [stderr] Nov 28 11:06:28.677 INFO [stderr] warning: unused import: `std::io::BufReader` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:10:5 Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] 10 | use std::io::BufReader; Nov 28 11:06:28.677 INFO [stderr] | ^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.677 INFO [stderr] Nov 28 11:06:28.677 INFO [stderr] warning: unused import: `std::path::Path` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:11:5 Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] 11 | use std::path::Path; Nov 28 11:06:28.677 INFO [stderr] | ^^^^^^^^^^^^^^^ Nov 28 11:06:28.677 INFO [stderr] Nov 28 11:06:28.677 INFO [stderr] warning: unused import: `std::str` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:12:5 Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] 12 | use std::str; Nov 28 11:06:28.677 INFO [stderr] | ^^^^^^^^ Nov 28 11:06:28.677 INFO [stderr] Nov 28 11:06:28.677 INFO [stderr] warning: unused import: `base64` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:1:5 Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] 1 | use base64; Nov 28 11:06:28.677 INFO [stderr] | ^^^^^^ Nov 28 11:06:28.677 INFO [stderr] Nov 28 11:06:28.677 INFO [stderr] warning: unused import: `rand::prelude::*` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:4:5 Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] 4 | use rand::prelude::*; Nov 28 11:06:28.677 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 28 11:06:28.677 INFO [stderr] Nov 28 11:06:28.677 INFO [stderr] warning: unused imports: `OsRng`, `Rng` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:5:12 Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] 5 | use rand::{OsRng, Rng}; Nov 28 11:06:28.677 INFO [stderr] | ^^^^^ ^^^ Nov 28 11:06:28.677 INFO [stderr] Nov 28 11:06:28.677 INFO [stderr] warning: unused import: `std::fs::File` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:6:5 Nov 28 11:06:28.677 INFO [stderr] | Nov 28 11:06:28.677 INFO [stderr] 6 | use std::fs::File; Nov 28 11:06:28.677 INFO [stderr] | ^^^^^^^^^^^^^ Nov 28 11:06:28.677 INFO [stderr] Nov 28 11:06:28.677 INFO [stderr] warning: unused import: `std::io::prelude::*` Nov 28 11:06:28.677 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:7:5 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 7 | use std::io::prelude::*; Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.678 INFO [stderr] warning: unused import: `std::io::BufRead` Nov 28 11:06:28.678 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:8:5 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 8 | use std::io::BufRead; Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.678 INFO [stderr] warning: unused import: `std::io::BufReader` Nov 28 11:06:28.678 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:9:5 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 9 | use std::io::BufReader; Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.678 INFO [stderr] warning: unused import: `std::str` Nov 28 11:06:28.678 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:10:5 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 10 | use std::str; Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^^^ Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.678 INFO [stderr] warning: unused import: `std::path::Path` Nov 28 11:06:28.678 INFO [stderr] --> src/challenge_set_1/detect_single_char_xor.rs:5:5 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 5 | use std::path::Path; Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^^^^^^^^^^ Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.678 INFO [stderr] warning: unused import: `base64` Nov 28 11:06:28.678 INFO [stderr] --> src/challenge_set_1/fixed_XOR.rs:1:5 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 1 | use base64; Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^ Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.678 INFO [stderr] warning: unused import: `std::str::from_utf8` Nov 28 11:06:28.678 INFO [stderr] --> src/challenge_set_1/repeating_key_xor.rs:2:5 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 2 | use std::str::from_utf8; Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.678 INFO [stderr] warning: unnecessary parentheses around `if` condition Nov 28 11:06:28.678 INFO [stderr] --> src/challenge_set_1/repeating_key_xor.rs:11:12 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 11 | if ((index + 1) == key.as_bytes().len()) { Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] = note: #[warn(unused_parens)] on by default Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.678 INFO [stderr] warning: unused import: `base64` Nov 28 11:06:28.678 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:1:5 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 1 | use base64; Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^ Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.678 INFO [stderr] warning: unused import: `challenge_set_1::detect_single_char_xor::detect_sing_char_xor` Nov 28 11:06:28.678 INFO [stderr] --> src/main.rs:8:5 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 8 | use challenge_set_1::detect_single_char_xor::detect_sing_char_xor; Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.678 INFO [stderr] warning: unused import: `challenge_set_1::single_byte_xor_cipher::single_byte_xor_cipher` Nov 28 11:06:28.678 INFO [stderr] --> src/main.rs:10:5 Nov 28 11:06:28.678 INFO [stderr] | Nov 28 11:06:28.678 INFO [stderr] 10 | use challenge_set_1::single_byte_xor_cipher::single_byte_xor_cipher; Nov 28 11:06:28.678 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.678 INFO [stderr] Nov 28 11:06:28.812 INFO [stderr] warning: variable `phrase` is assigned to, but never used Nov 28 11:06:28.812 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:24:13 Nov 28 11:06:28.812 INFO [stderr] | Nov 28 11:06:28.812 INFO [stderr] 24 | let mut phrase: String = "".to_string(); Nov 28 11:06:28.812 INFO [stderr] | ^^^^^^ Nov 28 11:06:28.812 INFO [stderr] | Nov 28 11:06:28.812 INFO [stderr] = note: #[warn(unused_variables)] on by default Nov 28 11:06:28.812 INFO [stderr] = note: consider using `_phrase` instead Nov 28 11:06:28.813 INFO [stderr] Nov 28 11:06:28.813 INFO [stderr] warning: value assigned to `phrase` is never read Nov 28 11:06:28.813 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:33:13 Nov 28 11:06:28.813 INFO [stderr] | Nov 28 11:06:28.813 INFO [stderr] 33 | phrase = match thing { Nov 28 11:06:28.813 INFO [stderr] | ^^^^^^ Nov 28 11:06:28.813 INFO [stderr] | Nov 28 11:06:28.813 INFO [stderr] = note: #[warn(unused_assignments)] on by default Nov 28 11:06:28.813 INFO [stderr] Nov 28 11:06:28.813 INFO [stderr] warning: unused variable: `error` Nov 28 11:06:28.813 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:35:21 Nov 28 11:06:28.813 INFO [stderr] | Nov 28 11:06:28.813 INFO [stderr] 35 | Err(error) => String::from(""), Nov 28 11:06:28.813 INFO [stderr] | ^^^^^ help: consider using `_error` instead Nov 28 11:06:28.813 INFO [stderr] Nov 28 11:06:28.813 INFO [stderr] warning: unused variable: `value` Nov 28 11:06:28.813 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:84:15 Nov 28 11:06:28.813 INFO [stderr] | Nov 28 11:06:28.813 INFO [stderr] 84 | for (key, value) in key_map.iter() { Nov 28 11:06:28.813 INFO [stderr] | ^^^^^ help: consider using `_value` instead Nov 28 11:06:28.813 INFO [stderr] Nov 28 11:06:28.813 INFO [stderr] warning: unused variable: `e` Nov 28 11:06:28.813 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:44:13 Nov 28 11:06:28.813 INFO [stderr] | Nov 28 11:06:28.813 INFO [stderr] 44 | Err(e) => String::from(""), Nov 28 11:06:28.813 INFO [stderr] | ^ help: consider using `_e` instead Nov 28 11:06:28.813 INFO [stderr] Nov 28 11:06:28.813 INFO [stderr] warning: unused variable: `length` Nov 28 11:06:28.813 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:57:9 Nov 28 11:06:28.813 INFO [stderr] | Nov 28 11:06:28.813 INFO [stderr] 57 | let length = data_as_bytes.len(); Nov 28 11:06:28.813 INFO [stderr] | ^^^^^^ help: consider using `_length` instead Nov 28 11:06:28.813 INFO [stderr] Nov 28 11:06:28.813 INFO [stderr] warning: unused variable: `error` Nov 28 11:06:28.813 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:78:21 Nov 28 11:06:28.813 INFO [stderr] | Nov 28 11:06:28.813 INFO [stderr] 78 | Err(error) => String::from(""), Nov 28 11:06:28.813 INFO [stderr] | ^^^^^ help: consider using `_error` instead Nov 28 11:06:28.813 INFO [stderr] Nov 28 11:06:28.869 INFO [stderr] warning: function is never used: `solve_blocks` Nov 28 11:06:28.869 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:14:1 Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] 14 | fn solve_blocks(blocks: Vec>) -> Vec { Nov 28 11:06:28.869 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] = note: #[warn(dead_code)] on by default Nov 28 11:06:28.869 INFO [stderr] Nov 28 11:06:28.869 INFO [stderr] warning: function is never used: `break_ciphertext_into_blocks` Nov 28 11:06:28.869 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:42:1 Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] 42 | fn break_ciphertext_into_blocks(keysize: u8) -> Vec> { Nov 28 11:06:28.869 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.869 INFO [stderr] Nov 28 11:06:28.869 INFO [stderr] warning: function is never used: `find_smallest_KEYSIZE` Nov 28 11:06:28.869 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:76:1 Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] 76 | fn find_smallest_KEYSIZE() -> Vec { Nov 28 11:06:28.869 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.869 INFO [stderr] Nov 28 11:06:28.869 INFO [stderr] warning: function is never used: `normalized_KEYSIZE` Nov 28 11:06:28.869 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:96:1 Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] 96 | fn normalized_KEYSIZE(key_guess: u8) -> f64 { Nov 28 11:06:28.869 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.869 INFO [stderr] Nov 28 11:06:28.869 INFO [stderr] warning: function is never used: `decrypt` Nov 28 11:06:28.869 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:13:1 Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] 13 | / fn decrypt( Nov 28 11:06:28.869 INFO [stderr] 14 | | encrypted_data: &[u8], Nov 28 11:06:28.869 INFO [stderr] 15 | | key: &[u8], Nov 28 11:06:28.869 INFO [stderr] 16 | | ) -> Result, symmetriccipher::SymmetricCipherError> { Nov 28 11:06:28.869 INFO [stderr] ... | Nov 28 11:06:28.869 INFO [stderr] 39 | | Ok(final_result) Nov 28 11:06:28.869 INFO [stderr] 40 | | } Nov 28 11:06:28.869 INFO [stderr] | |_^ Nov 28 11:06:28.869 INFO [stderr] Nov 28 11:06:28.869 INFO [stderr] warning: function `find_smallest_KEYSIZE` should have a snake case name such as `find_smallest_keysize` Nov 28 11:06:28.869 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:76:1 Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] 76 | / fn find_smallest_KEYSIZE() -> Vec { Nov 28 11:06:28.869 INFO [stderr] 77 | | let mut key_map: HashMap = HashMap::new(); Nov 28 11:06:28.869 INFO [stderr] 78 | | Nov 28 11:06:28.869 INFO [stderr] 79 | | for i in 1..=40 { Nov 28 11:06:28.869 INFO [stderr] ... | Nov 28 11:06:28.869 INFO [stderr] 92 | | vec![value1, value2, value3] Nov 28 11:06:28.869 INFO [stderr] 93 | | } Nov 28 11:06:28.869 INFO [stderr] | |_^ Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] = note: #[warn(non_snake_case)] on by default Nov 28 11:06:28.869 INFO [stderr] Nov 28 11:06:28.869 INFO [stderr] warning: function `normalized_KEYSIZE` should have a snake case name such as `normalized_keysize` Nov 28 11:06:28.869 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:96:1 Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] 96 | / fn normalized_KEYSIZE(key_guess: u8) -> f64 { Nov 28 11:06:28.869 INFO [stderr] 97 | | let mut f = File::open("1_challenge_6.txt").unwrap(); Nov 28 11:06:28.869 INFO [stderr] 98 | | Nov 28 11:06:28.869 INFO [stderr] 99 | | let mut contents = String::new(); Nov 28 11:06:28.869 INFO [stderr] ... | Nov 28 11:06:28.869 INFO [stderr] 114 | | final_distance / pairs as f64 Nov 28 11:06:28.869 INFO [stderr] 115 | | } Nov 28 11:06:28.869 INFO [stderr] | |_^ Nov 28 11:06:28.869 INFO [stderr] Nov 28 11:06:28.869 INFO [stderr] warning: module `fixed_XOR` should have a snake case name such as `fixed_xor` Nov 28 11:06:28.869 INFO [stderr] --> src/challenge_set_1/mod.rs:7:1 Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] 7 | pub mod fixed_XOR; Nov 28 11:06:28.869 INFO [stderr] | ^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.869 INFO [stderr] Nov 28 11:06:28.869 INFO [stderr] warning: function `fixed_XOR` should have a snake case name such as `fixed_xor` Nov 28 11:06:28.869 INFO [stderr] --> src/challenge_set_1/fixed_XOR.rs:19:1 Nov 28 11:06:28.869 INFO [stderr] | Nov 28 11:06:28.869 INFO [stderr] 19 | / pub fn fixed_XOR(data_1: &str, data_2: &str) -> String { Nov 28 11:06:28.869 INFO [stderr] 20 | | let one = hex::decode(data_1).unwrap(); Nov 28 11:06:28.869 INFO [stderr] 21 | | let two = hex::decode(data_2).unwrap(); Nov 28 11:06:28.869 INFO [stderr] 22 | | let xor = BytesXOR(one) ^ BytesXOR(two); Nov 28 11:06:28.869 INFO [stderr] 23 | | hex::encode(xor.0) Nov 28 11:06:28.869 INFO [stderr] 24 | | } Nov 28 11:06:28.869 INFO [stderr] | |_^ Nov 28 11:06:28.869 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `hex` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:4:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 4 | use hex; Nov 28 11:06:28.961 INFO [stderr] | ^^^ Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] = note: #[warn(unused_imports)] on by default Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `std::io` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:7:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 7 | use std::io; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `std::io::BufRead` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:9:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 9 | use std::io::BufRead; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `std::io::BufReader` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:10:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 10 | use std::io::BufReader; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `std::path::Path` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:11:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 11 | use std::path::Path; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^^^^^^^^^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `rand::prelude::*` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:4:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 4 | use rand::prelude::*; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused imports: `OsRng`, `Rng` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:5:12 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 5 | use rand::{OsRng, Rng}; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^ ^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `std::io::prelude::*` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:7:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 7 | use std::io::prelude::*; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `std::io::BufRead` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:8:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 8 | use std::io::BufRead; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^^^^^^^^^^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `std::str` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:10:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 10 | use std::str; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `std::path::Path` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/detect_single_char_xor.rs:5:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 5 | use std::path::Path; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^^^^^^^^^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `base64` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/fixed_XOR.rs:1:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.961 INFO [stderr] 1 | use base64; Nov 28 11:06:28.961 INFO [stderr] | ^^^^^^ Nov 28 11:06:28.961 INFO [stderr] Nov 28 11:06:28.961 INFO [stderr] warning: unused import: `std::str::from_utf8` Nov 28 11:06:28.961 INFO [stderr] --> src/challenge_set_1/repeating_key_xor.rs:2:5 Nov 28 11:06:28.961 INFO [stderr] | Nov 28 11:06:28.962 INFO [stderr] 2 | use std::str::from_utf8; Nov 28 11:06:28.962 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.962 INFO [stderr] Nov 28 11:06:28.962 INFO [stderr] warning: unnecessary parentheses around `if` condition Nov 28 11:06:28.962 INFO [stderr] --> src/challenge_set_1/repeating_key_xor.rs:11:12 Nov 28 11:06:28.962 INFO [stderr] | Nov 28 11:06:28.962 INFO [stderr] 11 | if ((index + 1) == key.as_bytes().len()) { Nov 28 11:06:28.962 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses Nov 28 11:06:28.962 INFO [stderr] | Nov 28 11:06:28.962 INFO [stderr] = note: #[warn(unused_parens)] on by default Nov 28 11:06:28.962 INFO [stderr] Nov 28 11:06:28.962 INFO [stderr] warning: unused import: `base64` Nov 28 11:06:28.962 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:1:5 Nov 28 11:06:28.962 INFO [stderr] | Nov 28 11:06:28.962 INFO [stderr] 1 | use base64; Nov 28 11:06:28.962 INFO [stderr] | ^^^^^^ Nov 28 11:06:28.962 INFO [stderr] Nov 28 11:06:28.962 INFO [stderr] warning: unused import: `super::*` Nov 28 11:06:28.962 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:88:9 Nov 28 11:06:28.962 INFO [stderr] | Nov 28 11:06:28.962 INFO [stderr] 88 | use super::*; Nov 28 11:06:28.962 INFO [stderr] | ^^^^^^^^ Nov 28 11:06:28.962 INFO [stderr] Nov 28 11:06:28.962 INFO [stderr] warning: unused import: `challenge_set_1::detect_single_char_xor::detect_sing_char_xor` Nov 28 11:06:28.962 INFO [stderr] --> src/main.rs:8:5 Nov 28 11:06:28.962 INFO [stderr] | Nov 28 11:06:28.962 INFO [stderr] 8 | use challenge_set_1::detect_single_char_xor::detect_sing_char_xor; Nov 28 11:06:28.962 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.962 INFO [stderr] Nov 28 11:06:28.962 INFO [stderr] warning: unused import: `challenge_set_1::single_byte_xor_cipher::single_byte_xor_cipher` Nov 28 11:06:28.962 INFO [stderr] --> src/main.rs:10:5 Nov 28 11:06:28.962 INFO [stderr] | Nov 28 11:06:28.962 INFO [stderr] 10 | use challenge_set_1::single_byte_xor_cipher::single_byte_xor_cipher; Nov 28 11:06:28.962 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Nov 28 11:06:28.962 INFO [stderr] Nov 28 11:06:29.113 INFO [stderr] warning: variable `phrase` is assigned to, but never used Nov 28 11:06:29.113 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:24:13 Nov 28 11:06:29.113 INFO [stderr] | Nov 28 11:06:29.113 INFO [stderr] 24 | let mut phrase: String = "".to_string(); Nov 28 11:06:29.113 INFO [stderr] | ^^^^^^ Nov 28 11:06:29.113 INFO [stderr] | Nov 28 11:06:29.113 INFO [stderr] = note: #[warn(unused_variables)] on by default Nov 28 11:06:29.113 INFO [stderr] = note: consider using `_phrase` instead Nov 28 11:06:29.113 INFO [stderr] Nov 28 11:06:29.113 INFO [stderr] warning: value assigned to `phrase` is never read Nov 28 11:06:29.113 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:33:13 Nov 28 11:06:29.113 INFO [stderr] | Nov 28 11:06:29.113 INFO [stderr] 33 | phrase = match thing { Nov 28 11:06:29.113 INFO [stderr] | ^^^^^^ Nov 28 11:06:29.113 INFO [stderr] | Nov 28 11:06:29.113 INFO [stderr] = note: #[warn(unused_assignments)] on by default Nov 28 11:06:29.113 INFO [stderr] Nov 28 11:06:29.113 INFO [stderr] warning: unused variable: `error` Nov 28 11:06:29.113 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:35:21 Nov 28 11:06:29.113 INFO [stderr] | Nov 28 11:06:29.113 INFO [stderr] 35 | Err(error) => String::from(""), Nov 28 11:06:29.113 INFO [stderr] | ^^^^^ help: consider using `_error` instead Nov 28 11:06:29.113 INFO [stderr] Nov 28 11:06:29.113 INFO [stderr] warning: unused variable: `value` Nov 28 11:06:29.113 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:84:15 Nov 28 11:06:29.113 INFO [stderr] | Nov 28 11:06:29.113 INFO [stderr] 84 | for (key, value) in key_map.iter() { Nov 28 11:06:29.113 INFO [stderr] | ^^^^^ help: consider using `_value` instead Nov 28 11:06:29.113 INFO [stderr] Nov 28 11:06:29.113 INFO [stderr] warning: unused variable: `e` Nov 28 11:06:29.113 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:44:13 Nov 28 11:06:29.113 INFO [stderr] | Nov 28 11:06:29.113 INFO [stderr] 44 | Err(e) => String::from(""), Nov 28 11:06:29.113 INFO [stderr] | ^ help: consider using `_e` instead Nov 28 11:06:29.113 INFO [stderr] Nov 28 11:06:29.113 INFO [stderr] warning: unused variable: `length` Nov 28 11:06:29.113 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:57:9 Nov 28 11:06:29.113 INFO [stderr] | Nov 28 11:06:29.113 INFO [stderr] 57 | let length = data_as_bytes.len(); Nov 28 11:06:29.113 INFO [stderr] | ^^^^^^ help: consider using `_length` instead Nov 28 11:06:29.113 INFO [stderr] Nov 28 11:06:29.114 INFO [stderr] warning: unused variable: `error` Nov 28 11:06:29.114 INFO [stderr] --> src/challenge_set_1/single_byte_xor_cipher.rs:78:21 Nov 28 11:06:29.114 INFO [stderr] | Nov 28 11:06:29.114 INFO [stderr] 78 | Err(error) => String::from(""), Nov 28 11:06:29.114 INFO [stderr] | ^^^^^ help: consider using `_error` instead Nov 28 11:06:29.114 INFO [stderr] Nov 28 11:06:29.156 INFO [stderr] warning: variable does not need to be mutable Nov 28 11:06:29.156 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:48:13 Nov 28 11:06:29.156 INFO [stderr] | Nov 28 11:06:29.156 INFO [stderr] 48 | let mut f = File::open("1_challenge_7.txt").unwrap(); Nov 28 11:06:29.156 INFO [stderr] | ----^ Nov 28 11:06:29.156 INFO [stderr] | | Nov 28 11:06:29.156 INFO [stderr] | help: remove this `mut` Nov 28 11:06:29.156 INFO [stderr] | Nov 28 11:06:29.156 INFO [stderr] = note: #[warn(unused_mut)] on by default Nov 28 11:06:29.156 INFO [stderr] Nov 28 11:06:29.156 INFO [stderr] warning: variable does not need to be mutable Nov 28 11:06:29.156 INFO [stderr] --> src/challenge_set_1/challenge_7.rs:49:13 Nov 28 11:06:29.156 INFO [stderr] | Nov 28 11:06:29.156 INFO [stderr] 49 | let mut buf_reader = BufReader::new(f); Nov 28 11:06:29.156 INFO [stderr] | ----^^^^^^^^^^ Nov 28 11:06:29.156 INFO [stderr] | | Nov 28 11:06:29.156 INFO [stderr] | help: remove this `mut` Nov 28 11:06:29.156 INFO [stderr] Nov 28 11:06:29.180 INFO [stderr] warning: function `find_smallest_KEYSIZE` should have a snake case name such as `find_smallest_keysize` Nov 28 11:06:29.180 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:76:1 Nov 28 11:06:29.180 INFO [stderr] | Nov 28 11:06:29.180 INFO [stderr] 76 | / fn find_smallest_KEYSIZE() -> Vec { Nov 28 11:06:29.180 INFO [stderr] 77 | | let mut key_map: HashMap = HashMap::new(); Nov 28 11:06:29.180 INFO [stderr] 78 | | Nov 28 11:06:29.180 INFO [stderr] 79 | | for i in 1..=40 { Nov 28 11:06:29.180 INFO [stderr] ... | Nov 28 11:06:29.180 INFO [stderr] 92 | | vec![value1, value2, value3] Nov 28 11:06:29.180 INFO [stderr] 93 | | } Nov 28 11:06:29.180 INFO [stderr] | |_^ Nov 28 11:06:29.180 INFO [stderr] | Nov 28 11:06:29.180 INFO [stderr] = note: #[warn(non_snake_case)] on by default Nov 28 11:06:29.180 INFO [stderr] Nov 28 11:06:29.180 INFO [stderr] warning: function `normalized_KEYSIZE` should have a snake case name such as `normalized_keysize` Nov 28 11:06:29.180 INFO [stderr] --> src/challenge_set_1/break_repeating_key_xor.rs:96:1 Nov 28 11:06:29.180 INFO [stderr] | Nov 28 11:06:29.180 INFO [stderr] 96 | / fn normalized_KEYSIZE(key_guess: u8) -> f64 { Nov 28 11:06:29.180 INFO [stderr] 97 | | let mut f = File::open("1_challenge_6.txt").unwrap(); Nov 28 11:06:29.180 INFO [stderr] 98 | | Nov 28 11:06:29.180 INFO [stderr] 99 | | let mut contents = String::new(); Nov 28 11:06:29.180 INFO [stderr] ... | Nov 28 11:06:29.180 INFO [stderr] 114 | | final_distance / pairs as f64 Nov 28 11:06:29.180 INFO [stderr] 115 | | } Nov 28 11:06:29.180 INFO [stderr] | |_^ Nov 28 11:06:29.180 INFO [stderr] Nov 28 11:06:29.196 INFO [stderr] warning: module `fixed_XOR` should have a snake case name such as `fixed_xor` Nov 28 11:06:29.196 INFO [stderr] --> src/challenge_set_1/mod.rs:7:1 Nov 28 11:06:29.196 INFO [stderr] | Nov 28 11:06:29.196 INFO [stderr] 7 | pub mod fixed_XOR; Nov 28 11:06:29.196 INFO [stderr] | ^^^^^^^^^^^^^^^^^^ Nov 28 11:06:29.196 INFO [stderr] Nov 28 11:06:29.196 INFO [stderr] warning: function `fixed_XOR` should have a snake case name such as `fixed_xor` Nov 28 11:06:29.196 INFO [stderr] --> src/challenge_set_1/fixed_XOR.rs:19:1 Nov 28 11:06:29.196 INFO [stderr] | Nov 28 11:06:29.196 INFO [stderr] 19 | / pub fn fixed_XOR(data_1: &str, data_2: &str) -> String { Nov 28 11:06:29.196 INFO [stderr] 20 | | let one = hex::decode(data_1).unwrap(); Nov 28 11:06:29.196 INFO [stderr] 21 | | let two = hex::decode(data_2).unwrap(); Nov 28 11:06:29.196 INFO [stderr] 22 | | let xor = BytesXOR(one) ^ BytesXOR(two); Nov 28 11:06:29.196 INFO [stderr] 23 | | hex::encode(xor.0) Nov 28 11:06:29.196 INFO [stderr] 24 | | } Nov 28 11:06:29.196 INFO [stderr] | |_^ Nov 28 11:06:29.196 INFO [stderr] Nov 28 11:06:29.196 INFO [stderr] warning: function `test_fixed_XOR` should have a snake case name such as `test_fixed_xor` Nov 28 11:06:29.196 INFO [stderr] --> src/challenge_set_1/fixed_XOR.rs:31:5 Nov 28 11:06:29.196 INFO [stderr] | Nov 28 11:06:29.197 INFO [stderr] 31 | / fn test_fixed_XOR() { Nov 28 11:06:29.197 INFO [stderr] 32 | | let data_1 = "1c0111001f010100061a024b53535009181c"; Nov 28 11:06:29.197 INFO [stderr] 33 | | let data_2 = "686974207468652062756c6c277320657965"; Nov 28 11:06:29.197 INFO [stderr] 34 | | assert_eq!( Nov 28 11:06:29.197 INFO [stderr] ... | Nov 28 11:06:29.197 INFO [stderr] 37 | | ); Nov 28 11:06:29.197 INFO [stderr] 38 | | } Nov 28 11:06:29.197 INFO [stderr] | |_____^ Nov 28 11:06:29.197 INFO [stderr] Nov 28 11:06:29.228 INFO [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1.72s Nov 28 11:06:29.232 INFO [stderr] su: No module specific data is present Nov 28 11:06:29.532 INFO running `"docker" "inspect" "1d4a3bc3acbd846caa493983682693d76f02dd4260a80ed46b0cbb8d7487be7f"` Nov 28 11:06:29.802 INFO running `"docker" "rm" "-f" "1d4a3bc3acbd846caa493983682693d76f02dd4260a80ed46b0cbb8d7487be7f"` Nov 28 11:06:29.947 INFO [stdout] 1d4a3bc3acbd846caa493983682693d76f02dd4260a80ed46b0cbb8d7487be7f