[INFO] cloning repository https://github.com/scttnlsn/cryptopals [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/scttnlsn/cryptopals" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fscttnlsn%2Fcryptopals", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fscttnlsn%2Fcryptopals'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] ac621b988f35a676e4f1528ed9ed85071a1accc5 [INFO] checking scttnlsn/cryptopals against master#7702ae16a23407cdd909ff9174294563ae1f4ba3 for pr-97183 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fscttnlsn%2Fcryptopals" "/workspace/builds/worker-1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-1/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/scttnlsn/cryptopals on toolchain 7702ae16a23407cdd909ff9174294563ae1f4ba3 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+7702ae16a23407cdd909ff9174294563ae1f4ba3" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/scttnlsn/cryptopals [INFO] finished tweaking git repo https://github.com/scttnlsn/cryptopals [INFO] tweaked toml for git repo https://github.com/scttnlsn/cryptopals written to /workspace/builds/worker-1/source/Cargo.toml [INFO] crate git repo https://github.com/scttnlsn/cryptopals already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+7702ae16a23407cdd909ff9174294563ae1f4ba3" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:ac0d0aa6ec8ed129e241004a6179c99fa0d2616f50ba759c5b60bd26d0fafa02" "/opt/rustwide/cargo-home/bin/cargo" "+7702ae16a23407cdd909ff9174294563ae1f4ba3" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 7c3485969f83eeaa481b2f95e26a333bfd79318fd9b66b1e3b3d3999d3a0d37e [INFO] running `Command { std: "docker" "start" "-a" "7c3485969f83eeaa481b2f95e26a333bfd79318fd9b66b1e3b3d3999d3a0d37e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "7c3485969f83eeaa481b2f95e26a333bfd79318fd9b66b1e3b3d3999d3a0d37e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "7c3485969f83eeaa481b2f95e26a333bfd79318fd9b66b1e3b3d3999d3a0d37e", kill_on_drop: false }` [INFO] [stdout] 7c3485969f83eeaa481b2f95e26a333bfd79318fd9b66b1e3b3d3999d3a0d37e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:ac0d0aa6ec8ed129e241004a6179c99fa0d2616f50ba759c5b60bd26d0fafa02" "/opt/rustwide/cargo-home/bin/cargo" "+7702ae16a23407cdd909ff9174294563ae1f4ba3" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 187731e8e3f8ce33e5e497ddb1b3fd53b216f8be8a12c7680dacbc5b057fd51e [INFO] running `Command { std: "docker" "start" "-a" "187731e8e3f8ce33e5e497ddb1b3fd53b216f8be8a12c7680dacbc5b057fd51e", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.62 [INFO] [stderr] Compiling cc v1.0.45 [INFO] [stderr] Checking cfg-if v0.1.10 [INFO] [stderr] Compiling proc-macro2 v1.0.6 [INFO] [stderr] Compiling unicode-xid v0.2.0 [INFO] [stderr] Checking lazy_static v1.4.0 [INFO] [stderr] Compiling pkg-config v0.3.16 [INFO] [stderr] Compiling getrandom v0.1.12 [INFO] [stderr] Compiling syn v1.0.5 [INFO] [stderr] Compiling autocfg v0.1.6 [INFO] [stderr] Compiling memchr v2.2.1 [INFO] [stderr] Compiling bitflags v1.2.0 [INFO] [stderr] Compiling failure_derive v0.1.6 [INFO] [stderr] Checking ppv-lite86 v0.2.5 [INFO] [stderr] Compiling byteorder v1.3.2 [INFO] [stderr] Checking foreign-types-shared v0.1.1 [INFO] [stderr] Checking rustc-demangle v0.1.16 [INFO] [stderr] Compiling openssl v0.10.24 [INFO] [stderr] Checking regex-syntax v0.6.12 [INFO] [stderr] Checking either v1.5.3 [INFO] [stderr] Checking foreign-types v0.3.2 [INFO] [stderr] Checking thread_local v0.3.6 [INFO] [stderr] Checking itertools v0.8.0 [INFO] [stderr] Checking c2-chacha v0.2.2 [INFO] [stderr] Compiling backtrace-sys v0.1.32 [INFO] [stderr] Compiling openssl-sys v0.9.49 [INFO] [stderr] Checking aho-corasick v0.7.6 [INFO] [stderr] Compiling quote v1.0.2 [INFO] [stderr] Checking base64 v0.10.1 [INFO] [stderr] Checking rand_core v0.5.1 [INFO] [stderr] Checking rand_chacha v0.2.1 [INFO] [stderr] Checking rand v0.7.2 [INFO] [stderr] Checking backtrace v0.3.40 [INFO] [stderr] Checking regex v1.3.1 [INFO] [stderr] Compiling synstructure v0.12.1 [INFO] [stderr] Checking failure v0.1.6 [INFO] [stderr] Checking cryptopals v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: constant `BLOCKSIZE` is never used [INFO] [stdout] --> src/aes.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | pub const BLOCKSIZE: usize = 16; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variants `ECB` and `CBC` are never constructed [INFO] [stdout] --> src/aes.rs:12:5 [INFO] [stdout] | [INFO] [stdout] 11 | pub enum EncMode { [INFO] [stdout] | ------- variants in this enum [INFO] [stdout] 12 | ECB, [INFO] [stdout] | ^^^ [INFO] [stdout] 13 | CBC, [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `EncMode` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `PaddingError` is never constructed [INFO] [stdout] --> src/aes.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 17 | pub enum Error { [INFO] [stdout] | ----- variant in this enum [INFO] [stdout] ... [INFO] [stdout] 23 | PaddingError, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Error` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `pkcs7_pad` is never used [INFO] [stdout] --> src/aes.rs:32:8 [INFO] [stdout] | [INFO] [stdout] 32 | pub fn pkcs7_pad(byte_array: &ByteArray, blocksize: usize) -> ByteArray { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `pkcs7_unpad` is never used [INFO] [stdout] --> src/aes.rs:39:8 [INFO] [stdout] | [INFO] [stdout] 39 | pub fn pkcs7_unpad(byte_array: &ByteArray) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `ecb_cipher` is never used [INFO] [stdout] --> src/aes.rs:67:8 [INFO] [stdout] | [INFO] [stdout] 67 | pub fn ecb_cipher(mode: Mode, key: &[u8], data: &[u8]) -> Result { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `encrypt_ecb` is never used [INFO] [stdout] --> src/aes.rs:81:8 [INFO] [stdout] | [INFO] [stdout] 81 | pub fn encrypt_ecb(data: &ByteArray, key: &[u8]) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `decrypt_ecb` is never used [INFO] [stdout] --> src/aes.rs:87:8 [INFO] [stdout] | [INFO] [stdout] 87 | pub fn decrypt_ecb(data: &ByteArray, key: &[u8]) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `decrypt_cbc` is never used [INFO] [stdout] --> src/aes.rs:92:8 [INFO] [stdout] | [INFO] [stdout] 92 | pub fn decrypt_cbc(data: &ByteArray, key: &[u8], iv: ByteArray) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `encrypt_cbc` is never used [INFO] [stdout] --> src/aes.rs:105:8 [INFO] [stdout] | [INFO] [stdout] 105 | pub fn encrypt_cbc(data: &ByteArray, key: &[u8], iv: ByteArray) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/aes.rs:125:12 [INFO] [stdout] | [INFO] [stdout] 125 | pub fn new() -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `encrypt` is never used [INFO] [stdout] --> src/aes.rs:132:12 [INFO] [stdout] | [INFO] [stdout] 132 | pub fn encrypt(&self, data: &ByteArray) -> Result { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `decrypt` is never used [INFO] [stdout] --> src/aes.rs:137:12 [INFO] [stdout] | [INFO] [stdout] 137 | pub fn decrypt(&self, ciphertext: &ByteArray) -> Result { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `check_padding` is never used [INFO] [stdout] --> src/aes.rs:142:12 [INFO] [stdout] | [INFO] [stdout] 142 | pub fn check_padding(&self, ciphertext: &ByteArray) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `random_bytes` is never used [INFO] [stdout] --> src/aes.rs:148:8 [INFO] [stdout] | [INFO] [stdout] 148 | pub fn random_bytes(n: usize) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `random_key` is never used [INFO] [stdout] --> src/aes.rs:152:8 [INFO] [stdout] | [INFO] [stdout] 152 | pub fn random_key() -> Vec { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `unique_blocks` is never used [INFO] [stdout] --> src/aes.rs:156:4 [INFO] [stdout] | [INFO] [stdout] 156 | fn unique_blocks(data: &ByteArray) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `detect_mode` is never used [INFO] [stdout] --> src/aes.rs:163:4 [INFO] [stdout] | [INFO] [stdout] 163 | fn detect_mode(data: &ByteArray) -> EncMode { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `data`, `key` and `prefix` are never read [INFO] [stdout] --> src/aes.rs:184:5 [INFO] [stdout] | [INFO] [stdout] 183 | pub struct Oracle<'a> { [INFO] [stdout] | ------ fields in this struct [INFO] [stdout] 184 | data: &'a ByteArray, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 185 | key: Vec, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 186 | prefix: ByteArray, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Oracle` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/aes.rs:190:12 [INFO] [stdout] | [INFO] [stdout] 190 | pub fn new(data: &'a ByteArray) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new_prefixed` is never used [INFO] [stdout] --> src/aes.rs:198:12 [INFO] [stdout] | [INFO] [stdout] 198 | pub fn new_prefixed(data: &'a ByteArray, n: usize) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `encrypt` is never used [INFO] [stdout] --> src/aes.rs:206:12 [INFO] [stdout] | [INFO] [stdout] 206 | pub fn encrypt(&self, input: &ByteArray) -> Result { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `detect_blocksize` is never used [INFO] [stdout] --> src/aes.rs:214:4 [INFO] [stdout] | [INFO] [stdout] 214 | fn detect_blocksize(data: &ByteArray) -> Result, Error> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `detect_data_len` is never used [INFO] [stdout] --> src/aes.rs:232:4 [INFO] [stdout] | [INFO] [stdout] 232 | fn detect_data_len(oracle: &Oracle) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `detect_prefix_len` is never used [INFO] [stdout] --> src/aes.rs:249:8 [INFO] [stdout] | [INFO] [stdout] 249 | pub fn detect_prefix_len(oracle: &Oracle) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `crack_ecb` is never used [INFO] [stdout] --> src/aes.rs:267:8 [INFO] [stdout] | [INFO] [stdout] 267 | pub fn crack_ecb(oracle: &Oracle) -> Result { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `crack_cbc` is never used [INFO] [stdout] --> src/aes.rs:304:4 [INFO] [stdout] | [INFO] [stdout] 304 | fn crack_cbc(cbc: &CBC, ciphertext: &ByteArray) -> Result { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/aes.rs:379:12 [INFO] [stdout] | [INFO] [stdout] 379 | pub fn new(input: &str, cbc: &'a CBC) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `decrypt` is never used [INFO] [stdout] --> src/aes.rs:389:12 [INFO] [stdout] | [INFO] [stdout] 389 | pub fn decrypt(ciphertext: &ByteArray, cbc: &'a CBC) -> Result { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `encrypt` is never used [INFO] [stdout] --> src/aes.rs:398:12 [INFO] [stdout] | [INFO] [stdout] 398 | pub fn encrypt(&self) -> Result { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `is_admin` is never used [INFO] [stdout] --> src/aes.rs:403:12 [INFO] [stdout] | [INFO] [stdout] 403 | pub fn is_admin(&self) -> bool { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `encrypted`, `decrypted`, `key` and `score` are never read [INFO] [stdout] --> src/cipher.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 6 | pub struct Score<'a> { [INFO] [stdout] | ----- fields in this struct [INFO] [stdout] 7 | encrypted: &'a ByteArray, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 8 | decrypted: ByteArray, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] 9 | key: ByteArray, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 10 | score: f64, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Score` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `letter_freq` is never used [INFO] [stdout] --> src/cipher.rs:13:8 [INFO] [stdout] | [INFO] [stdout] 13 | pub fn letter_freq(c: char) -> f64 { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `english_score` is never used [INFO] [stdout] --> src/cipher.rs:46:4 [INFO] [stdout] | [INFO] [stdout] 46 | fn english_score(s: &str) -> f64 { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_key` is never used [INFO] [stdout] --> src/cipher.rs:54:8 [INFO] [stdout] | [INFO] [stdout] 54 | pub fn find_key(encrypted: &ByteArray) -> Score { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `encrypt` is never used [INFO] [stdout] --> src/cipher.rs:72:8 [INFO] [stdout] | [INFO] [stdout] 72 | pub fn encrypt(decrypted: &ByteArray, key: &str) -> ByteArray { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `keysize` is never used [INFO] [stdout] --> src/cipher.rs:80:8 [INFO] [stdout] | [INFO] [stdout] 80 | pub fn keysize(ciphertext: &ByteArray) -> usize { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_key_of_size` is never used [INFO] [stdout] --> src/cipher.rs:114:8 [INFO] [stdout] | [INFO] [stdout] 114 | pub fn find_key_of_size(ciphertext: &ByteArray, keysize: usize) -> ByteArray { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CTR` is never constructed [INFO] [stdout] --> src/ctr.rs:6:8 [INFO] [stdout] | [INFO] [stdout] 6 | struct CTR { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/ctr.rs:12:12 [INFO] [stdout] | [INFO] [stdout] 12 | pub fn new(key: Vec, nonce: Vec) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `cipher` is never used [INFO] [stdout] --> src/ctr.rs:19:12 [INFO] [stdout] | [INFO] [stdout] 19 | pub fn cipher(&self, data: &ByteArray) -> Result { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `nonce_bytes` is never used [INFO] [stdout] --> src/ctr.rs:37:8 [INFO] [stdout] | [INFO] [stdout] 37 | fn nonce_bytes(&self, counter: u32) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `crack_fixed_nonce_subst` is never used [INFO] [stdout] --> src/ctr.rs:53:4 [INFO] [stdout] | [INFO] [stdout] 53 | fn crack_fixed_nonce_subst(ciphertexts: &Vec) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `crack_fixed_nonce_stat` is never used [INFO] [stdout] --> src/ctr.rs:100:4 [INFO] [stdout] | [INFO] [stdout] 100 | fn crack_fixed_nonce_stat(ciphertexts: &Vec) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `from_bytes` is never used [INFO] [stdout] --> src/encoding.rs:17:12 [INFO] [stdout] | [INFO] [stdout] 17 | pub fn from_bytes(bytes: Vec) -> ByteArray { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `from_hex` is never used [INFO] [stdout] --> src/encoding.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 21 | pub fn from_hex(hex: &str) -> Option { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `from_base64` is never used [INFO] [stdout] --> src/encoding.rs:44:12 [INFO] [stdout] | [INFO] [stdout] 44 | pub fn from_base64(s: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `from_string` is never used [INFO] [stdout] --> src/encoding.rs:49:12 [INFO] [stdout] | [INFO] [stdout] 49 | pub fn from_string(s: &str) -> ByteArray { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `len` is never used [INFO] [stdout] --> src/encoding.rs:54:12 [INFO] [stdout] | [INFO] [stdout] 54 | pub fn len(&self) -> usize { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `bytes` is never used [INFO] [stdout] --> src/encoding.rs:58:12 [INFO] [stdout] | [INFO] [stdout] 58 | pub fn bytes(&self) -> Vec { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `string` is never used [INFO] [stdout] --> src/encoding.rs:63:12 [INFO] [stdout] | [INFO] [stdout] 63 | pub fn string(&self) -> String { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `hex` is never used [INFO] [stdout] --> src/encoding.rs:67:12 [INFO] [stdout] | [INFO] [stdout] 67 | pub fn hex(&self) -> String { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `base64` is never used [INFO] [stdout] --> src/encoding.rs:86:12 [INFO] [stdout] | [INFO] [stdout] 86 | pub fn base64(&self) -> String { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `xor` is never used [INFO] [stdout] --> src/encoding.rs:117:12 [INFO] [stdout] | [INFO] [stdout] 117 | pub fn xor(&self, other: &ByteArray) -> ByteArray { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `hamming_distance` is never used [INFO] [stdout] --> src/encoding.rs:122:12 [INFO] [stdout] | [INFO] [stdout] 122 | pub fn hamming_distance(&self, other: &ByteArray) -> u32 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `prefix` is never used [INFO] [stdout] --> src/encoding.rs:136:12 [INFO] [stdout] | [INFO] [stdout] 136 | pub fn prefix(&self, prefix: &ByteArray) -> ByteArray { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `profile_for` is never used [INFO] [stdout] --> src/profile.rs:4:4 [INFO] [stdout] | [INFO] [stdout] 4 | fn profile_for(email: &str) -> String { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `encrypt_profile` is never used [INFO] [stdout] --> src/profile.rs:8:4 [INFO] [stdout] | [INFO] [stdout] 8 | fn encrypt_profile(profile: &str, key: &[u8]) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `decrypt_profile` is never used [INFO] [stdout] --> src/profile.rs:13:4 [INFO] [stdout] | [INFO] [stdout] 13 | fn decrypt_profile(encrypted: &ByteArray, key: &[u8]) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 59 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `encrypted` is never read [INFO] [stdout] --> src/cipher.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 6 | pub struct Score<'a> { [INFO] [stdout] | ----- field in this struct [INFO] [stdout] 7 | encrypted: &'a ByteArray, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] = note: `Score` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 1 warning emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 8.66s [INFO] running `Command { std: "docker" "inspect" "187731e8e3f8ce33e5e497ddb1b3fd53b216f8be8a12c7680dacbc5b057fd51e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "187731e8e3f8ce33e5e497ddb1b3fd53b216f8be8a12c7680dacbc5b057fd51e", kill_on_drop: false }` [INFO] [stdout] 187731e8e3f8ce33e5e497ddb1b3fd53b216f8be8a12c7680dacbc5b057fd51e