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