[INFO] fetching crate csv-groupby 0.10.0...
[INFO] testing csv-groupby-0.10.0 against master#c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38 for pr-146098-7
[INFO] extracting crate csv-groupby 0.10.0 into /workspace/builds/worker-2-tc1/source
[INFO] started tweaking crates.io crate csv-groupby 0.10.0
[INFO] removed 0 missing tests
[INFO] finished tweaking crates.io crate csv-groupby 0.10.0
[INFO] tweaked toml for crates.io crate csv-groupby 0.10.0 written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate csv-groupby 0.10.0 on toolchain c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate csv-groupby 0.10.0 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: version requirement `0.9.0+zstd.1.5.0` for dependency `zstd` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded zstd-safe v4.1.1+zstd.1.5.0
[INFO] [stderr]   Downloaded predicates-core v1.0.2
[INFO] [stderr]   Downloaded zstd v0.9.0+zstd.1.5.0
[INFO] [stderr]   Downloaded rand_hc v0.3.1
[INFO] [stderr]   Downloaded pcre2 v0.2.3
[INFO] [stderr]   Downloaded redox_syscall v0.2.9
[INFO] [stderr]   Downloaded prettytable-rs v0.8.0
[INFO] [stderr]   Downloaded predicates-tree v1.0.2
[INFO] [stderr]   Downloaded colored v1.9.3
[INFO] [stderr]   Downloaded treeline v0.1.0
[INFO] [stderr]   Downloaded paste-impl v0.1.18
[INFO] [stderr]   Downloaded escargot v0.3.1
[INFO] [stderr]   Downloaded addr2line v0.15.2
[INFO] [stderr]   Downloaded chan v0.1.23
[INFO] [stderr]   Downloaded ignore v0.4.18
[INFO] [stderr]   Downloaded backtrace v0.3.60
[INFO] [stderr]   Downloaded flate2 v1.0.20
[INFO] [stderr]   Downloaded globset v0.4.8
[INFO] [stderr]   Downloaded bstr v0.2.16
[INFO] [stderr]   Downloaded rustc-demangle v0.1.20
[INFO] [stderr]   Downloaded cpu-time v1.0.0
[INFO] [stderr]   Downloaded crossbeam-channel v0.4.4
[INFO] [stderr]   Downloaded fs_extra v1.2.0
[INFO] [stderr]   Downloaded object v0.25.3
[INFO] [stderr]   Downloaded rand v0.8.4
[INFO] [stderr]   Downloaded assert_cmd v0.10.2
[INFO] [stderr]   Downloaded grep-cli v0.1.6
[INFO] [stderr]   Downloaded paste v0.1.18
[INFO] [stderr]   Downloaded jemallocator v0.3.2
[INFO] [stderr]   Downloaded jemalloc-ctl v0.3.3
[INFO] [stderr]   Downloaded zstd-sys v1.6.1+zstd.1.5.0
[INFO] [stderr]   Downloaded gimli v0.24.0
[INFO] [stderr]   Downloaded csv v1.1.6
[INFO] [stderr]   Downloaded jemalloc-sys v0.3.2
[INFO] [stderr]   Downloaded pcre2-sys v0.2.5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7c70caf3a70318cb51cc6064c09fb1693328950d8a6042870c8c8b852570783e
[INFO] running `Command { std: "docker" "start" "-a" "7c70caf3a70318cb51cc6064c09fb1693328950d8a6042870c8c8b852570783e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7c70caf3a70318cb51cc6064c09fb1693328950d8a6042870c8c8b852570783e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7c70caf3a70318cb51cc6064c09fb1693328950d8a6042870c8c8b852570783e", kill_on_drop: false }`
[INFO] [stdout] 7c70caf3a70318cb51cc6064c09fb1693328950d8a6042870c8c8b852570783e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6c0c53503889e9b14a2b563799aa2af831710f97f27d0415ea476528d58416f5
[INFO] running `Command { std: "docker" "start" "-a" "6c0c53503889e9b14a2b563799aa2af831710f97f27d0415ea476528d58416f5", kill_on_drop: false }`
[INFO] [stderr] warning: version requirement `0.9.0+zstd.1.5.0` for dependency `zstd` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr]    Compiling libc v0.2.97
[INFO] [stderr]    Compiling autocfg v1.0.1
[INFO] [stderr]    Compiling proc-macro2 v1.0.27
[INFO] [stderr]    Compiling unicode-xid v0.2.2
[INFO] [stderr]    Compiling syn v1.0.73
[INFO] [stderr]    Compiling lazy_static v1.4.0
[INFO] [stderr]    Compiling memchr v2.4.0
[INFO] [stderr]    Compiling cfg-if v1.0.0
[INFO] [stderr]    Compiling serde_derive v1.0.126
[INFO] [stderr]    Compiling serde v1.0.126
[INFO] [stderr]    Compiling version_check v0.9.3
[INFO] [stderr]    Compiling maybe-uninit v2.0.0
[INFO] [stderr]    Compiling ryu v1.0.5
[INFO] [stderr]    Compiling regex-automata v0.1.10
[INFO] [stderr]    Compiling regex-syntax v0.6.25
[INFO] [stderr]    Compiling log v0.4.14
[INFO] [stderr]    Compiling cfg-if v0.1.10
[INFO] [stderr]    Compiling proc-macro-hack v0.5.19
[INFO] [stderr]    Compiling itoa v0.4.7
[INFO] [stderr]    Compiling fs_extra v1.2.0
[INFO] [stderr]    Compiling unicode-width v0.1.8
[INFO] [stderr]    Compiling serde_json v1.0.64
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling num-traits v0.2.14
[INFO] [stderr]    Compiling memoffset v0.5.6
[INFO] [stderr]    Compiling miniz_oxide v0.4.4
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]    Compiling pkg-config v0.3.19
[INFO] [stderr]    Compiling once_cell v1.8.0
[INFO] [stderr]    Compiling ppv-lite86 v0.2.10
[INFO] [stderr]    Compiling scopeguard v1.1.0
[INFO] [stderr]    Compiling zstd-safe v4.1.1+zstd.1.5.0
[INFO] [stderr]    Compiling unicode-segmentation v1.7.1
[INFO] [stderr]    Compiling jobserver v0.1.22
[INFO] [stderr]    Compiling quote v1.0.9
[INFO] [stderr]    Compiling atty v0.2.14
[INFO] [stderr]    Compiling getrandom v0.2.3
[INFO] [stderr]    Compiling adler v1.0.2
[INFO] [stderr]    Compiling crossbeam-utils v0.8.5
[INFO] [stderr]    Compiling escargot v0.3.1
[INFO] [stderr]    Compiling fnv v1.0.7
[INFO] [stderr]    Compiling crc32fast v1.2.1
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]    Compiling predicates-core v1.0.2
[INFO] [stderr]    Compiling cc v1.0.68
[INFO] [stderr]    Compiling aho-corasick v0.7.18
[INFO] [stderr]    Compiling rand_core v0.6.3
[INFO] [stderr]    Compiling csv-core v0.1.10
[INFO] [stderr]    Compiling heck v0.3.3
[INFO] [stderr]    Compiling dirs v1.0.5
[INFO] [stderr]    Compiling rand v0.4.6
[INFO] [stderr]    Compiling thread_local v1.1.3
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling bitflags v1.2.1
[INFO] [stderr]    Compiling textwrap v0.11.0
[INFO] [stderr]    Compiling byteorder v1.4.3
[INFO] [stderr]    Compiling difference v2.0.0
[INFO] [stderr]    Compiling normalize-line-endings v0.3.0
[INFO] [stderr]    Compiling vec_map v0.8.2
[INFO] [stderr]    Compiling treeline v0.1.0
[INFO] [stderr]    Compiling gimli v0.24.0
[INFO] [stderr]    Compiling paste-impl v0.1.18
[INFO] [stderr]    Compiling ansi_term v0.11.0
[INFO] [stderr]    Compiling float-cmp v0.8.0
[INFO] [stderr]    Compiling strsim v0.8.0
[INFO] [stderr]    Compiling rand v0.8.4
[INFO] [stderr]    Compiling term v0.5.2
[INFO] [stderr]    Compiling predicates-tree v1.0.2
[INFO] [stderr]    Compiling crossbeam-deque v0.7.3
[INFO] [stderr]    Compiling crossbeam-channel v0.4.4
[INFO] [stderr]    Compiling clap v2.33.3
[INFO] [stderr]    Compiling rand v0.3.23
[INFO] [stderr]    Compiling paste v0.1.18
[INFO] [stderr]    Compiling crossbeam-queue v0.2.3
[INFO] [stderr]    Compiling walkdir v2.3.2
[INFO] [stderr]    Compiling object v0.25.3
[INFO] [stderr]    Compiling zstd-sys v1.6.1+zstd.1.5.0
[INFO] [stderr]    Compiling jemalloc-sys v0.3.2
[INFO] [stderr]    Compiling pcre2-sys v0.2.5
[INFO] [stderr]    Compiling backtrace v0.3.60
[INFO] [stderr]    Compiling csv-groupby v0.10.0 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling encode_unicode v0.3.6
[INFO] [stderr]    Compiling termcolor v1.1.2
[INFO] [stdout] warning: unused import: `std::thread::LocalKey`
[INFO] [stdout]  --> build.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::thread::LocalKey;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling remove_dir_all v0.5.3
[INFO] [stderr]    Compiling rustc-demangle v0.1.20
[INFO] [stderr]    Compiling either v1.6.1
[INFO] [stderr]    Compiling tempfile v3.2.0
[INFO] [stderr]    Compiling pcre2 v0.2.3
[INFO] [stderr]    Compiling crossbeam v0.7.3
[INFO] [stderr]    Compiling itertools v0.9.0
[INFO] [stderr]    Compiling chan v0.1.23
[INFO] [stderr]    Compiling flate2 v1.0.20
[INFO] [stderr]    Compiling regex v1.5.4
[INFO] [stderr]    Compiling colored v1.9.3
[INFO] [stderr]    Compiling cpu-time v1.0.0
[INFO] [stderr]    Compiling num_cpus v1.13.0
[INFO] [stderr]    Compiling smallvec v1.6.1
[INFO] [stderr]    Compiling predicates v1.0.8
[INFO] [stderr]    Compiling addr2line v0.15.2
[INFO] [stderr]    Compiling structopt-derive v0.4.14
[INFO] [stderr]    Compiling structopt v0.3.21
[INFO] [stderr]    Compiling bstr v0.2.16
[INFO] [stderr]    Compiling globset v0.4.8
[INFO] [stderr]    Compiling csv v1.1.6
[INFO] [stderr]    Compiling prettytable-rs v0.8.0
[INFO] [stderr]    Compiling ignore v0.4.18
[INFO] [stderr]    Compiling grep-cli v0.1.6
[INFO] [stderr]    Compiling assert_cmd v0.10.2
[INFO] [stderr]    Compiling zstd v0.9.0+zstd.1.5.0
[INFO] [stderr]    Compiling jemallocator v0.3.2
[INFO] [stderr]    Compiling jemalloc-ctl v0.3.3
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:315:22
[INFO] [stdout]     |
[INFO] [stdout] 315 |     pub head: Option<(u64)>,
[INFO] [stdout]     |                      ^   ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 315 -     pub head: Option<(u64)>,
[INFO] [stdout] 315 +     pub head: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:319:22
[INFO] [stdout]     |
[INFO] [stdout] 319 |     pub tail: Option<(u64)>,
[INFO] [stdout]     |                      ^   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 319 -     pub tail: Option<(u64)>,
[INFO] [stdout] 319 +     pub tail: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:331:26
[INFO] [stdout]     |
[INFO] [stdout] 331 |     pub count_le: Option<(u64)>,
[INFO] [stdout]     |                          ^   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 331 -     pub count_le: Option<(u64)>,
[INFO] [stdout] 331 +     pub count_le: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:335:26
[INFO] [stdout]     |
[INFO] [stdout] 335 |     pub count_ge: Option<(u64)>,
[INFO] [stdout]     |                          ^   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 335 -     pub count_ge: Option<(u64)>,
[INFO] [stdout] 335 +     pub count_ge: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/keysum.rs:104:16
[INFO] [stdout]     |
[INFO] [stdout] 104 |             if ( v.is_none()) {
[INFO] [stdout]     |                ^^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 104 -             if ( v.is_none()) {
[INFO] [stdout] 104 +             if v.is_none()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gettid` is never used
[INFO] [stdout]   --> src/gen.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub fn gettid() -> usize {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mem_metric` is never used
[INFO] [stdout]   --> src/gen.rs:98:4
[INFO] [stdout]    |
[INFO] [stdout] 98 | fn mem_metric<'a>(v: usize) -> (f64, &'a str) {
[INFO] [stdout]    |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sig_dig` is never used
[INFO] [stdout]    --> src/gen.rs:112:4
[INFO] [stdout]     |
[INFO] [stdout] 112 | fn sig_dig(v: f64, digits: usize) -> String {
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mem_metric_digit` is never used
[INFO] [stdout]    --> src/gen.rs:136:8
[INFO] [stdout]     |
[INFO] [stdout] 136 | pub fn mem_metric_digit(v: usize, sig: usize) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `greek` is never used
[INFO] [stdout]    --> src/gen.rs:163:8
[INFO] [stdout]     |
[INFO] [stdout] 163 | pub fn greek(v: f64) -> String {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `user_pause` is never used
[INFO] [stdout]    --> src/gen.rs:207:8
[INFO] [stdout]     |
[INFO] [stdout] 207 | pub fn user_pause() {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `IoSlicerStatus` is never constructed
[INFO] [stdout]    --> src/gen.rs:216:12
[INFO] [stdout]     |
[INFO] [stdout] 216 | pub struct IoSlicerStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/gen.rs:223:12
[INFO] [stdout]     |
[INFO] [stdout] 222 | impl IoSlicerStatus {
[INFO] [stdout]     | ------------------- associated function in this implementation
[INFO] [stdout] 223 |     pub fn new() -> IoSlicerStatus {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FileSlice` is never constructed
[INFO] [stdout]    --> src/gen.rs:233:12
[INFO] [stdout]     |
[INFO] [stdout] 233 | pub struct FileSlice {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fill_buff` is never used
[INFO] [stdout]    --> src/gen.rs:241:4
[INFO] [stdout]     |
[INFO] [stdout] 241 | fn fill_buff(handle: &mut dyn Read, buff: &mut [u8]) -> Result<usize, std::io::Error> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `io_thread_slicer` is never used
[INFO] [stdout]    --> src/gen.rs:263:8
[INFO] [stdout]     |
[INFO] [stdout] 263 | pub fn io_thread_slicer(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `caps_to_vec_strings` is never used
[INFO] [stdout]    --> src/gen.rs:379:8
[INFO] [stdout]     |
[INFO] [stdout] 379 | pub fn caps_to_vec_strings(caps: &Captures_pcre2) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `subs_from_path_buff` is never used
[INFO] [stdout]    --> src/gen.rs:389:8
[INFO] [stdout]     |
[INFO] [stdout] 389 | pub fn subs_from_path_buff(path: &PathBuf, regex: &Option<Regex_pre2>) -> (bool, Vec<String>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `per_file_thread` is never used
[INFO] [stdout]    --> src/gen.rs:402:8
[INFO] [stdout]     |
[INFO] [stdout] 402 | pub fn per_file_thread(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/keysum.rs:103:17
[INFO] [stdout]     |
[INFO] [stdout] 103 |             let mut v = self.matrix.get_mut(i);
[INFO] [stdout]     |                 ----^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `null_str`
[INFO] [stdout]    --> src/keysum.rs:140:17
[INFO] [stdout]     |
[INFO] [stdout] 140 |             let null_str = String::from("NULL");
[INFO] [stdout]     |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_null_str`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ss`
[INFO] [stdout]    --> src/keysum.rs:167:53
[INFO] [stdout]     |
[INFO] [stdout] 167 | pub fn schema_rec<T>(matrix: &mut Vec<Vec<String>>, ss: &mut String, line: &str, record: &T, rec_len: usize, map: &mut MyMap, cfg: ...
[INFO] [stdout]     |                                                     ^^ help: if this is intentional, prefix it with an underscore: `_ss`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `line`
[INFO] [stdout]    --> src/keysum.rs:167:70
[INFO] [stdout]     |
[INFO] [stdout] 167 | ...<String>>, ss: &mut String, line: &str, record: &T, rec_len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usi...
[INFO] [stdout]     |                                ^^^^ help: if this is intentional, prefix it with an underscore: `_line`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `map`
[INFO] [stdout]    --> src/keysum.rs:167:110
[INFO] [stdout]     |
[INFO] [stdout] 167 | ... record: &T, rec_len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stdout]     |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_map`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cfg`
[INFO] [stdout]    --> src/keysum.rs:167:127
[INFO] [stdout]     |
[INFO] [stdout] 167 | ...len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stdout]     |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_cfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rowcount`
[INFO] [stdout]    --> src/keysum.rs:167:141
[INFO] [stdout]     |
[INFO] [stdout] 167 | ...ut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stdout]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rowcount`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/keysum.rs:199:9
[INFO] [stdout]     |
[INFO] [stdout] 199 |     let mut lines_filtered = 0usize;
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/keysum.rs:251:9
[INFO] [stdout]     |
[INFO] [stdout] 251 |     let mut brec: &mut KeySum = {
[INFO] [stdout]     |         ----^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:496:17
[INFO] [stdout]     |
[INFO] [stdout] 496 |             let mut print_skipped = false; // for the stuff after head and before tail
[INFO] [stdout]     |                 ----^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `print_skipped`
[INFO] [stdout]    --> src/main.rs:496:17
[INFO] [stdout]     |
[INFO] [stdout] 496 |             let mut print_skipped = false; // for the stuff after head and before tail
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_print_skipped`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inner_count`
[INFO] [stdout]    --> src/main.rs:843:30
[INFO] [stdout]     |
[INFO] [stdout] 843 |             'LINE_LOOP: for (inner_count, line) in slice.split(|c| *c == b'\n').enumerate() {
[INFO] [stdout]     |                              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_inner_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:922:9
[INFO] [stdout]     |
[INFO] [stdout] 922 |     let mut csv_builder = create_csv_builder(&cfg);
[INFO] [stdout]     |         ----^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> src/main.rs:987:56
[INFO] [stdout]     |
[INFO] [stdout] 987 | ...                   csv::ErrorKind::Utf8 { ref err, pos } => {
[INFO] [stdout]     |                                              ^^^^^^^ help: try ignoring the field: `err: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `cnt_rec` is assigned to, but never used
[INFO] [stdout]    --> src/main.rs:999:21
[INFO] [stdout]     |
[INFO] [stdout] 999 |                 let mut cnt_rec = 0usize;
[INFO] [stdout]     |                     ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_cnt_rec` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]     --> src/main.rs:1021:56
[INFO] [stdout]      |
[INFO] [stdout] 1021 | ...                   csv::ErrorKind::Utf8 { ref err, pos } => {
[INFO] [stdout]      |                                              ^^^^^^^ help: try ignoring the field: `err: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `cnt_rec` is never read
[INFO] [stdout]     --> src/main.rs:1015:37
[INFO] [stdout]      |
[INFO] [stdout] 1015 | ...                   cnt_rec += 1;
[INFO] [stdout]      |                       ^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]     --> src/main.rs:1148:28
[INFO] [stdout]      |
[INFO] [stdout] 1148 |                 if let Err(e) = line {
[INFO] [stdout]      |                            ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1215:13
[INFO] [stdout]      |
[INFO] [stdout] 1215 |         let mut b = slice[pos];
[INFO] [stdout]      |             ----^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/main.rs:761:20
[INFO] [stdout]     |
[INFO] [stdout] 761 |             panic!(err_msg);
[INFO] [stdout]     |                    ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: add a "{}" format string to `Display` the message
[INFO] [stdout]     |
[INFO] [stdout] 761 |             panic!("{}", err_msg);
[INFO] [stdout]     |                    +++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/main.rs:908:20
[INFO] [stdout]     |
[INFO] [stdout] 908 |             panic!(err_msg);
[INFO] [stdout]     |                    ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout] help: add a "{}" format string to `Display` the message
[INFO] [stdout]     |
[INFO] [stdout] 908 |             panic!("{}", err_msg);
[INFO] [stdout]     |                    +++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]     --> src/main.rs:1049:20
[INFO] [stdout]      |
[INFO] [stdout] 1049 |             panic!(err_msg);
[INFO] [stdout]      |                    ^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]      = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout] help: add a "{}" format string to `Display` the message
[INFO] [stdout]      |
[INFO] [stdout] 1049 |             panic!("{}", err_msg);
[INFO] [stdout]      |                    +++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `ISO_8859` should have a snake case name
[INFO] [stdout]    --> src/cli.rs:296:9
[INFO] [stdout]     |
[INFO] [stdout] 296 |     pub ISO_8859: bool,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `iso_8859`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 55s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: fs_extra v1.2.0
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] running `Command { std: "docker" "inspect" "6c0c53503889e9b14a2b563799aa2af831710f97f27d0415ea476528d58416f5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6c0c53503889e9b14a2b563799aa2af831710f97f27d0415ea476528d58416f5", kill_on_drop: false }`
[INFO] [stdout] 6c0c53503889e9b14a2b563799aa2af831710f97f27d0415ea476528d58416f5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 322a2e670b793f876f4ebbcf6b4ec2d700a26f5130725286fb9016990785ec17
[INFO] running `Command { std: "docker" "start" "-a" "322a2e670b793f876f4ebbcf6b4ec2d700a26f5130725286fb9016990785ec17", kill_on_drop: false }`
[INFO] [stderr] warning: version requirement `0.9.0+zstd.1.5.0` for dependency `zstd` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr]    Compiling lazy_static v1.4.0
[INFO] [stderr]    Compiling cfg-if v1.0.0
[INFO] [stderr]    Compiling libc v0.2.97
[INFO] [stderr]    Compiling memchr v2.4.0
[INFO] [stderr]    Compiling cfg-if v0.1.10
[INFO] [stderr]    Compiling regex-automata v0.1.10
[INFO] [stderr]    Compiling regex-syntax v0.6.25
[INFO] [stderr]    Compiling ryu v1.0.5
[INFO] [stderr]    Compiling maybe-uninit v2.0.0
[INFO] [stderr]    Compiling serde v1.0.126
[INFO] [stderr]    Compiling itoa v0.4.7
[INFO] [stdout] warning: unused import: `std::thread::LocalKey`
[INFO] [stdout]  --> build.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::thread::LocalKey;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling log v0.4.14
[INFO] [stderr]    Compiling unicode-width v0.1.8
[INFO] [stderr]    Compiling num-traits v0.2.14
[INFO] [stderr]    Compiling memoffset v0.5.6
[INFO] [stderr]    Compiling ppv-lite86 v0.2.10
[INFO] [stderr]    Compiling once_cell v1.8.0
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling adler v1.0.2
[INFO] [stderr]    Compiling scopeguard v1.1.0
[INFO] [stderr]    Compiling predicates-core v1.0.2
[INFO] [stderr]    Compiling thread_local v1.1.3
[INFO] [stderr]    Compiling miniz_oxide v0.4.4
[INFO] [stderr]    Compiling textwrap v0.11.0
[INFO] [stderr]    Compiling normalize-line-endings v0.3.0
[INFO] [stderr]    Compiling gimli v0.24.0
[INFO] [stderr]    Compiling difference v2.0.0
[INFO] [stderr]    Compiling ansi_term v0.11.0
[INFO] [stderr]    Compiling byteorder v1.4.3
[INFO] [stderr]    Compiling aho-corasick v0.7.18
[INFO] [stderr]    Compiling csv-core v0.1.10
[INFO] [stderr]    Compiling treeline v0.1.0
[INFO] [stderr]    Compiling float-cmp v0.8.0
[INFO] [stderr]    Compiling object v0.25.3
[INFO] [stderr]    Compiling predicates-tree v1.0.2
[INFO] [stderr]    Compiling walkdir v2.3.2
[INFO] [stderr]    Compiling crossbeam-utils v0.8.5
[INFO] [stderr]    Compiling crc32fast v1.2.1
[INFO] [stderr]    Compiling paste v0.1.18
[INFO] [stderr]    Compiling either v1.6.1
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]    Compiling crossbeam-queue v0.2.3
[INFO] [stderr]    Compiling jobserver v0.1.22
[INFO] [stderr]    Compiling atty v0.2.14
[INFO] [stderr]    Compiling getrandom v0.2.3
[INFO] [stderr]    Compiling rand v0.4.6
[INFO] [stderr]    Compiling dirs v1.0.5
[INFO] [stderr]    Compiling clap v2.33.3
[INFO] [stderr]    Compiling crossbeam-deque v0.7.3
[INFO] [stderr]    Compiling term v0.5.2
[INFO] [stderr]    Compiling crossbeam-channel v0.4.4
[INFO] [stderr]    Compiling remove_dir_all v0.5.3
[INFO] [stderr]    Compiling termcolor v1.1.2
[INFO] [stderr]    Compiling encode_unicode v0.3.6
[INFO] [stderr]    Compiling cc v1.0.68
[INFO] [stderr]    Compiling rand_core v0.6.3
[INFO] [stderr]    Compiling rustc-demangle v0.1.20
[INFO] [stderr]    Compiling colored v1.9.3
[INFO] [stderr]    Compiling flate2 v1.0.20
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.4
[INFO] [stderr]    Compiling crossbeam v0.7.3
[INFO] [stderr]    Compiling cpu-time v1.0.0
[INFO] [stderr]    Compiling num_cpus v1.13.0
[INFO] [stderr]    Compiling itertools v0.9.0
[INFO] [stderr]    Compiling smallvec v1.6.1
[INFO] [stderr]    Compiling rand v0.3.23
[INFO] [stderr]    Compiling tempfile v3.2.0
[INFO] [stderr]    Compiling chan v0.1.23
[INFO] [stderr]    Compiling regex v1.5.4
[INFO] [stderr]    Compiling zstd-sys v1.6.1+zstd.1.5.0
[INFO] [stderr]    Compiling jemalloc-sys v0.3.2
[INFO] [stderr]    Compiling pcre2-sys v0.2.5
[INFO] [stderr]    Compiling backtrace v0.3.60
[INFO] [stderr]    Compiling addr2line v0.15.2
[INFO] [stderr]    Compiling pcre2 v0.2.3
[INFO] [stderr]    Compiling bstr v0.2.16
[INFO] [stderr]    Compiling serde_json v1.0.64
[INFO] [stderr]    Compiling predicates v1.0.8
[INFO] [stderr]    Compiling globset v0.4.8
[INFO] [stderr]    Compiling csv v1.1.6
[INFO] [stderr]    Compiling structopt v0.3.21
[INFO] [stderr]    Compiling grep-cli v0.1.6
[INFO] [stderr]    Compiling escargot v0.3.1
[INFO] [stderr]    Compiling ignore v0.4.18
[INFO] [stderr]    Compiling assert_cmd v0.10.2
[INFO] [stderr]    Compiling prettytable-rs v0.8.0
[INFO] [stderr]    Compiling zstd-safe v4.1.1+zstd.1.5.0
[INFO] [stderr]    Compiling zstd v0.9.0+zstd.1.5.0
[INFO] [stderr]    Compiling jemalloc-ctl v0.3.3
[INFO] [stderr]    Compiling jemallocator v0.3.2
[INFO] [stderr]    Compiling csv-groupby v0.10.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:315:22
[INFO] [stdout]     |
[INFO] [stdout] 315 |     pub head: Option<(u64)>,
[INFO] [stdout]     |                      ^   ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 315 -     pub head: Option<(u64)>,
[INFO] [stdout] 315 +     pub head: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:319:22
[INFO] [stdout]     |
[INFO] [stdout] 319 |     pub tail: Option<(u64)>,
[INFO] [stdout]     |                      ^   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 319 -     pub tail: Option<(u64)>,
[INFO] [stdout] 319 +     pub tail: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:331:26
[INFO] [stdout]     |
[INFO] [stdout] 331 |     pub count_le: Option<(u64)>,
[INFO] [stdout]     |                          ^   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 331 -     pub count_le: Option<(u64)>,
[INFO] [stdout] 331 +     pub count_le: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:335:26
[INFO] [stdout]     |
[INFO] [stdout] 335 |     pub count_ge: Option<(u64)>,
[INFO] [stdout]     |                          ^   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 335 -     pub count_ge: Option<(u64)>,
[INFO] [stdout] 335 +     pub count_ge: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/keysum.rs:104:16
[INFO] [stdout]     |
[INFO] [stdout] 104 |             if ( v.is_none()) {
[INFO] [stdout]     |                ^^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 104 -             if ( v.is_none()) {
[INFO] [stdout] 104 +             if v.is_none()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gettid` is never used
[INFO] [stdout]   --> src/gen.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub fn gettid() -> usize {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `greek` is never used
[INFO] [stdout]    --> src/gen.rs:163:8
[INFO] [stdout]     |
[INFO] [stdout] 163 | pub fn greek(v: f64) -> String {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `user_pause` is never used
[INFO] [stdout]    --> src/gen.rs:207:8
[INFO] [stdout]     |
[INFO] [stdout] 207 | pub fn user_pause() {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `IoSlicerStatus` is never constructed
[INFO] [stdout]    --> src/gen.rs:216:12
[INFO] [stdout]     |
[INFO] [stdout] 216 | pub struct IoSlicerStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/gen.rs:223:12
[INFO] [stdout]     |
[INFO] [stdout] 222 | impl IoSlicerStatus {
[INFO] [stdout]     | ------------------- associated function in this implementation
[INFO] [stdout] 223 |     pub fn new() -> IoSlicerStatus {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FileSlice` is never constructed
[INFO] [stdout]    --> src/gen.rs:233:12
[INFO] [stdout]     |
[INFO] [stdout] 233 | pub struct FileSlice {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fill_buff` is never used
[INFO] [stdout]    --> src/gen.rs:241:4
[INFO] [stdout]     |
[INFO] [stdout] 241 | fn fill_buff(handle: &mut dyn Read, buff: &mut [u8]) -> Result<usize, std::io::Error> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `io_thread_slicer` is never used
[INFO] [stdout]    --> src/gen.rs:263:8
[INFO] [stdout]     |
[INFO] [stdout] 263 | pub fn io_thread_slicer(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `caps_to_vec_strings` is never used
[INFO] [stdout]    --> src/gen.rs:379:8
[INFO] [stdout]     |
[INFO] [stdout] 379 | pub fn caps_to_vec_strings(caps: &Captures_pcre2) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `subs_from_path_buff` is never used
[INFO] [stdout]    --> src/gen.rs:389:8
[INFO] [stdout]     |
[INFO] [stdout] 389 | pub fn subs_from_path_buff(path: &PathBuf, regex: &Option<Regex_pre2>) -> (bool, Vec<String>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `per_file_thread` is never used
[INFO] [stdout]    --> src/gen.rs:402:8
[INFO] [stdout]     |
[INFO] [stdout] 402 | pub fn per_file_thread(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gettid` is never used
[INFO] [stdout]   --> src/gen.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub fn gettid() -> usize {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mem_metric` is never used
[INFO] [stdout]   --> src/gen.rs:98:4
[INFO] [stdout]    |
[INFO] [stdout] 98 | fn mem_metric<'a>(v: usize) -> (f64, &'a str) {
[INFO] [stdout]    |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sig_dig` is never used
[INFO] [stdout]    --> src/gen.rs:112:4
[INFO] [stdout]     |
[INFO] [stdout] 112 | fn sig_dig(v: f64, digits: usize) -> String {
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mem_metric_digit` is never used
[INFO] [stdout]    --> src/gen.rs:136:8
[INFO] [stdout]     |
[INFO] [stdout] 136 | pub fn mem_metric_digit(v: usize, sig: usize) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `greek` is never used
[INFO] [stdout]    --> src/gen.rs:163:8
[INFO] [stdout]     |
[INFO] [stdout] 163 | pub fn greek(v: f64) -> String {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `user_pause` is never used
[INFO] [stdout]    --> src/gen.rs:207:8
[INFO] [stdout]     |
[INFO] [stdout] 207 | pub fn user_pause() {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `IoSlicerStatus` is never constructed
[INFO] [stdout]    --> src/gen.rs:216:12
[INFO] [stdout]     |
[INFO] [stdout] 216 | pub struct IoSlicerStatus {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/gen.rs:223:12
[INFO] [stdout]     |
[INFO] [stdout] 222 | impl IoSlicerStatus {
[INFO] [stdout]     | ------------------- associated function in this implementation
[INFO] [stdout] 223 |     pub fn new() -> IoSlicerStatus {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FileSlice` is never constructed
[INFO] [stdout]    --> src/gen.rs:233:12
[INFO] [stdout]     |
[INFO] [stdout] 233 | pub struct FileSlice {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fill_buff` is never used
[INFO] [stdout]    --> src/gen.rs:241:4
[INFO] [stdout]     |
[INFO] [stdout] 241 | fn fill_buff(handle: &mut dyn Read, buff: &mut [u8]) -> Result<usize, std::io::Error> {
[INFO] [stdout]     |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `io_thread_slicer` is never used
[INFO] [stdout]    --> src/gen.rs:263:8
[INFO] [stdout]     |
[INFO] [stdout] 263 | pub fn io_thread_slicer(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `caps_to_vec_strings` is never used
[INFO] [stdout]    --> src/gen.rs:379:8
[INFO] [stdout]     |
[INFO] [stdout] 379 | pub fn caps_to_vec_strings(caps: &Captures_pcre2) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `subs_from_path_buff` is never used
[INFO] [stdout]    --> src/gen.rs:389:8
[INFO] [stdout]     |
[INFO] [stdout] 389 | pub fn subs_from_path_buff(path: &PathBuf, regex: &Option<Regex_pre2>) -> (bool, Vec<String>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `per_file_thread` is never used
[INFO] [stdout]    --> src/gen.rs:402:8
[INFO] [stdout]     |
[INFO] [stdout] 402 | pub fn per_file_thread(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:315:22
[INFO] [stdout]     |
[INFO] [stdout] 315 |     pub head: Option<(u64)>,
[INFO] [stdout]     |                      ^   ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 315 -     pub head: Option<(u64)>,
[INFO] [stdout] 315 +     pub head: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:319:22
[INFO] [stdout]     |
[INFO] [stdout] 319 |     pub tail: Option<(u64)>,
[INFO] [stdout]     |                      ^   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 319 -     pub tail: Option<(u64)>,
[INFO] [stdout] 319 +     pub tail: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:331:26
[INFO] [stdout]     |
[INFO] [stdout] 331 |     pub count_le: Option<(u64)>,
[INFO] [stdout]     |                          ^   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 331 -     pub count_le: Option<(u64)>,
[INFO] [stdout] 331 +     pub count_le: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]    --> src/cli.rs:335:26
[INFO] [stdout]     |
[INFO] [stdout] 335 |     pub count_ge: Option<(u64)>,
[INFO] [stdout]     |                          ^   ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 335 -     pub count_ge: Option<(u64)>,
[INFO] [stdout] 335 +     pub count_ge: Option<u64 >,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/keysum.rs:104:16
[INFO] [stdout]     |
[INFO] [stdout] 104 |             if ( v.is_none()) {
[INFO] [stdout]     |                ^^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 104 -             if ( v.is_none()) {
[INFO] [stdout] 104 +             if v.is_none()  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/keysum.rs:103:17
[INFO] [stdout]     |
[INFO] [stdout] 103 |             let mut v = self.matrix.get_mut(i);
[INFO] [stdout]     |                 ----^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `null_str`
[INFO] [stdout]    --> src/keysum.rs:140:17
[INFO] [stdout]     |
[INFO] [stdout] 140 |             let null_str = String::from("NULL");
[INFO] [stdout]     |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_null_str`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ss`
[INFO] [stdout]    --> src/keysum.rs:167:53
[INFO] [stdout]     |
[INFO] [stdout] 167 | pub fn schema_rec<T>(matrix: &mut Vec<Vec<String>>, ss: &mut String, line: &str, record: &T, rec_len: usize, map: &mut MyMap, cfg: ...
[INFO] [stdout]     |                                                     ^^ help: if this is intentional, prefix it with an underscore: `_ss`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `line`
[INFO] [stdout]    --> src/keysum.rs:167:70
[INFO] [stdout]     |
[INFO] [stdout] 167 | ...<String>>, ss: &mut String, line: &str, record: &T, rec_len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usi...
[INFO] [stdout]     |                                ^^^^ help: if this is intentional, prefix it with an underscore: `_line`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `map`
[INFO] [stdout]    --> src/keysum.rs:167:110
[INFO] [stdout]     |
[INFO] [stdout] 167 | ... record: &T, rec_len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stdout]     |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_map`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cfg`
[INFO] [stdout]    --> src/keysum.rs:167:127
[INFO] [stdout]     |
[INFO] [stdout] 167 | ...len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stdout]     |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_cfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rowcount`
[INFO] [stdout]    --> src/keysum.rs:167:141
[INFO] [stdout]     |
[INFO] [stdout] 167 | ...ut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stdout]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rowcount`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/keysum.rs:199:9
[INFO] [stdout]     |
[INFO] [stdout] 199 |     let mut lines_filtered = 0usize;
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/keysum.rs:251:9
[INFO] [stdout]     |
[INFO] [stdout] 251 |     let mut brec: &mut KeySum = {
[INFO] [stdout]     |         ----^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/keysum.rs:103:17
[INFO] [stdout]     |
[INFO] [stdout] 103 |             let mut v = self.matrix.get_mut(i);
[INFO] [stdout]     |                 ----^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:496:17
[INFO] [stdout]     |
[INFO] [stdout] 496 |             let mut print_skipped = false; // for the stuff after head and before tail
[INFO] [stdout]     |                 ----^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `null_str`
[INFO] [stdout]    --> src/keysum.rs:140:17
[INFO] [stdout]     |
[INFO] [stdout] 140 |             let null_str = String::from("NULL");
[INFO] [stdout]     |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_null_str`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `print_skipped`
[INFO] [stdout]    --> src/main.rs:496:17
[INFO] [stdout]     |
[INFO] [stdout] 496 |             let mut print_skipped = false; // for the stuff after head and before tail
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_print_skipped`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ss`
[INFO] [stdout]    --> src/keysum.rs:167:53
[INFO] [stdout]     |
[INFO] [stdout] 167 | pub fn schema_rec<T>(matrix: &mut Vec<Vec<String>>, ss: &mut String, line: &str, record: &T, rec_len: usize, map: &mut MyMap, cfg: ...
[INFO] [stdout]     |                                                     ^^ help: if this is intentional, prefix it with an underscore: `_ss`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `line`
[INFO] [stdout]    --> src/keysum.rs:167:70
[INFO] [stdout]     |
[INFO] [stdout] 167 | ...<String>>, ss: &mut String, line: &str, record: &T, rec_len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usi...
[INFO] [stdout]     |                                ^^^^ help: if this is intentional, prefix it with an underscore: `_line`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `map`
[INFO] [stdout]    --> src/keysum.rs:167:110
[INFO] [stdout]     |
[INFO] [stdout] 167 | ... record: &T, rec_len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stdout]     |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_map`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cfg`
[INFO] [stdout]    --> src/keysum.rs:167:127
[INFO] [stdout]     |
[INFO] [stdout] 167 | ...len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stdout]     |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_cfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rowcount`
[INFO] [stdout]    --> src/keysum.rs:167:141
[INFO] [stdout]     |
[INFO] [stdout] 167 | ...ut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stdout]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rowcount`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/keysum.rs:199:9
[INFO] [stdout]     |
[INFO] [stdout] 199 |     let mut lines_filtered = 0usize;
[INFO] [stdout]     |         ----^^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/keysum.rs:251:9
[INFO] [stdout]     |
[INFO] [stdout] 251 |     let mut brec: &mut KeySum = {
[INFO] [stdout]     |         ----^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inner_count`
[INFO] [stdout]    --> src/main.rs:843:30
[INFO] [stdout]     |
[INFO] [stdout] 843 |             'LINE_LOOP: for (inner_count, line) in slice.split(|c| *c == b'\n').enumerate() {
[INFO] [stdout]     |                              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_inner_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:922:9
[INFO] [stdout]     |
[INFO] [stdout] 922 |     let mut csv_builder = create_csv_builder(&cfg);
[INFO] [stdout]     |         ----^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> src/main.rs:987:56
[INFO] [stdout]     |
[INFO] [stdout] 987 | ...                   csv::ErrorKind::Utf8 { ref err, pos } => {
[INFO] [stdout]     |                                              ^^^^^^^ help: try ignoring the field: `err: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `cnt_rec` is assigned to, but never used
[INFO] [stdout]    --> src/main.rs:999:21
[INFO] [stdout]     |
[INFO] [stdout] 999 |                 let mut cnt_rec = 0usize;
[INFO] [stdout]     |                     ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_cnt_rec` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]     --> src/main.rs:1021:56
[INFO] [stdout]      |
[INFO] [stdout] 1021 | ...                   csv::ErrorKind::Utf8 { ref err, pos } => {
[INFO] [stdout]      |                                              ^^^^^^^ help: try ignoring the field: `err: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `cnt_rec` is never read
[INFO] [stdout]     --> src/main.rs:1015:37
[INFO] [stdout]      |
[INFO] [stdout] 1015 | ...                   cnt_rec += 1;
[INFO] [stdout]      |                       ^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]     --> src/main.rs:1148:28
[INFO] [stdout]      |
[INFO] [stdout] 1148 |                 if let Err(e) = line {
[INFO] [stdout]      |                            ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1215:13
[INFO] [stdout]      |
[INFO] [stdout] 1215 |         let mut b = slice[pos];
[INFO] [stdout]      |             ----^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/main.rs:761:20
[INFO] [stdout]     |
[INFO] [stdout] 761 |             panic!(err_msg);
[INFO] [stdout]     |                    ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: add a "{}" format string to `Display` the message
[INFO] [stdout]     |
[INFO] [stdout] 761 |             panic!("{}", err_msg);
[INFO] [stdout]     |                    +++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/main.rs:908:20
[INFO] [stdout]     |
[INFO] [stdout] 908 |             panic!(err_msg);
[INFO] [stdout]     |                    ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout] help: add a "{}" format string to `Display` the message
[INFO] [stdout]     |
[INFO] [stdout] 908 |             panic!("{}", err_msg);
[INFO] [stdout]     |                    +++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]     --> src/main.rs:1049:20
[INFO] [stdout]      |
[INFO] [stdout] 1049 |             panic!(err_msg);
[INFO] [stdout]      |                    ^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]      = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout] help: add a "{}" format string to `Display` the message
[INFO] [stdout]      |
[INFO] [stdout] 1049 |             panic!("{}", err_msg);
[INFO] [stdout]      |                    +++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `ISO_8859` should have a snake case name
[INFO] [stdout]    --> src/cli.rs:296:9
[INFO] [stdout]     |
[INFO] [stdout] 296 |     pub ISO_8859: bool,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `iso_8859`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:496:17
[INFO] [stdout]     |
[INFO] [stdout] 496 |             let mut print_skipped = false; // for the stuff after head and before tail
[INFO] [stdout]     |                 ----^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `print_skipped`
[INFO] [stdout]    --> src/main.rs:496:17
[INFO] [stdout]     |
[INFO] [stdout] 496 |             let mut print_skipped = false; // for the stuff after head and before tail
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_print_skipped`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inner_count`
[INFO] [stdout]    --> src/main.rs:843:30
[INFO] [stdout]     |
[INFO] [stdout] 843 |             'LINE_LOOP: for (inner_count, line) in slice.split(|c| *c == b'\n').enumerate() {
[INFO] [stdout]     |                              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_inner_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:922:9
[INFO] [stdout]     |
[INFO] [stdout] 922 |     let mut csv_builder = create_csv_builder(&cfg);
[INFO] [stdout]     |         ----^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> src/main.rs:987:56
[INFO] [stdout]     |
[INFO] [stdout] 987 | ...                   csv::ErrorKind::Utf8 { ref err, pos } => {
[INFO] [stdout]     |                                              ^^^^^^^ help: try ignoring the field: `err: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `cnt_rec` is assigned to, but never used
[INFO] [stdout]    --> src/main.rs:999:21
[INFO] [stdout]     |
[INFO] [stdout] 999 |                 let mut cnt_rec = 0usize;
[INFO] [stdout]     |                     ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_cnt_rec` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]     --> src/main.rs:1021:56
[INFO] [stdout]      |
[INFO] [stdout] 1021 | ...                   csv::ErrorKind::Utf8 { ref err, pos } => {
[INFO] [stdout]      |                                              ^^^^^^^ help: try ignoring the field: `err: _`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `cnt_rec` is never read
[INFO] [stdout]     --> src/main.rs:1015:37
[INFO] [stdout]      |
[INFO] [stdout] 1015 | ...                   cnt_rec += 1;
[INFO] [stdout]      |                       ^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]     --> src/main.rs:1148:28
[INFO] [stdout]      |
[INFO] [stdout] 1148 |                 if let Err(e) = line {
[INFO] [stdout]      |                            ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1215:13
[INFO] [stdout]      |
[INFO] [stdout] 1215 |         let mut b = slice[pos];
[INFO] [stdout]      |             ----^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/main.rs:761:20
[INFO] [stdout]     |
[INFO] [stdout] 761 |             panic!(err_msg);
[INFO] [stdout]     |                    ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout]     = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: add a "{}" format string to `Display` the message
[INFO] [stdout]     |
[INFO] [stdout] 761 |             panic!("{}", err_msg);
[INFO] [stdout]     |                    +++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]    --> src/main.rs:908:20
[INFO] [stdout]     |
[INFO] [stdout] 908 |             panic!(err_msg);
[INFO] [stdout]     |                    ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout] help: add a "{}" format string to `Display` the message
[INFO] [stdout]     |
[INFO] [stdout] 908 |             panic!("{}", err_msg);
[INFO] [stdout]     |                    +++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: panic message is not a string literal
[INFO] [stdout]     --> src/main.rs:1049:20
[INFO] [stdout]      |
[INFO] [stdout] 1049 |             panic!(err_msg);
[INFO] [stdout]      |                    ^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stdout]      = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stdout] help: add a "{}" format string to `Display` the message
[INFO] [stdout]      |
[INFO] [stdout] 1049 |             panic!("{}", err_msg);
[INFO] [stdout]      |                    +++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `ISO_8859` should have a snake case name
[INFO] [stdout]    --> src/cli.rs:296:9
[INFO] [stdout]     |
[INFO] [stdout] 296 |     pub ISO_8859: bool,
[INFO] [stdout]     |         ^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `iso_8859`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1m 45s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: fs_extra v1.2.0
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] running `Command { std: "docker" "inspect" "322a2e670b793f876f4ebbcf6b4ec2d700a26f5130725286fb9016990785ec17", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "322a2e670b793f876f4ebbcf6b4ec2d700a26f5130725286fb9016990785ec17", kill_on_drop: false }`
[INFO] [stdout] 322a2e670b793f876f4ebbcf6b4ec2d700a26f5130725286fb9016990785ec17
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] b789687374a57c7bf0c6d5ad89f4669dae7bf9d69e75dcdd9f0ca6291b2fbd9c
[INFO] running `Command { std: "docker" "start" "-a" "b789687374a57c7bf0c6d5ad89f4669dae7bf9d69e75dcdd9f0ca6291b2fbd9c", kill_on_drop: false }`
[INFO] [stderr] warning: version requirement `0.9.0+zstd.1.5.0` for dependency `zstd` includes semver metadata which will be ignored, removing the metadata is recommended to avoid confusion
[INFO] [stderr] warning: unused import: `std::thread::LocalKey`
[INFO] [stderr]  --> build.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use std::thread::LocalKey;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `csv-groupby` (build script) generated 1 warning
[INFO] [stderr] warning: function `gettid` is never used
[INFO] [stderr]   --> src/gen.rs:21:8
[INFO] [stderr]    |
[INFO] [stderr] 21 | pub fn gettid() -> usize {
[INFO] [stderr]    |        ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `greek` is never used
[INFO] [stderr]    --> src/gen.rs:163:8
[INFO] [stderr]     |
[INFO] [stderr] 163 | pub fn greek(v: f64) -> String {
[INFO] [stderr]     |        ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `user_pause` is never used
[INFO] [stderr]    --> src/gen.rs:207:8
[INFO] [stderr]     |
[INFO] [stderr] 207 | pub fn user_pause() {
[INFO] [stderr]     |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `IoSlicerStatus` is never constructed
[INFO] [stderr]    --> src/gen.rs:216:12
[INFO] [stderr]     |
[INFO] [stderr] 216 | pub struct IoSlicerStatus {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]    --> src/gen.rs:223:12
[INFO] [stderr]     |
[INFO] [stderr] 222 | impl IoSlicerStatus {
[INFO] [stderr]     | ------------------- associated function in this implementation
[INFO] [stderr] 223 |     pub fn new() -> IoSlicerStatus {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `FileSlice` is never constructed
[INFO] [stderr]    --> src/gen.rs:233:12
[INFO] [stderr]     |
[INFO] [stderr] 233 | pub struct FileSlice {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `fill_buff` is never used
[INFO] [stderr]    --> src/gen.rs:241:4
[INFO] [stderr]     |
[INFO] [stderr] 241 | fn fill_buff(handle: &mut dyn Read, buff: &mut [u8]) -> Result<usize, std::io::Error> {
[INFO] [stderr]     |    ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `io_thread_slicer` is never used
[INFO] [stderr]    --> src/gen.rs:263:8
[INFO] [stderr]     |
[INFO] [stderr] 263 | pub fn io_thread_slicer(
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `caps_to_vec_strings` is never used
[INFO] [stderr]    --> src/gen.rs:379:8
[INFO] [stderr]     |
[INFO] [stderr] 379 | pub fn caps_to_vec_strings(caps: &Captures_pcre2) -> Vec<String> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `subs_from_path_buff` is never used
[INFO] [stderr]    --> src/gen.rs:389:8
[INFO] [stderr]     |
[INFO] [stderr] 389 | pub fn subs_from_path_buff(path: &PathBuf, regex: &Option<Regex_pre2>) -> (bool, Vec<String>) {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `per_file_thread` is never used
[INFO] [stderr]    --> src/gen.rs:402:8
[INFO] [stderr]     |
[INFO] [stderr] 402 | pub fn per_file_thread(
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around type
[INFO] [stderr]    --> src/cli.rs:315:22
[INFO] [stderr]     |
[INFO] [stderr] 315 |     pub head: Option<(u64)>,
[INFO] [stderr]     |                      ^   ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 315 -     pub head: Option<(u64)>,
[INFO] [stderr] 315 +     pub head: Option<u64 >,
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around type
[INFO] [stderr]    --> src/cli.rs:319:22
[INFO] [stderr]     |
[INFO] [stderr] 319 |     pub tail: Option<(u64)>,
[INFO] [stderr]     |                      ^   ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 319 -     pub tail: Option<(u64)>,
[INFO] [stderr] 319 +     pub tail: Option<u64 >,
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around type
[INFO] [stderr]    --> src/cli.rs:331:26
[INFO] [stderr]     |
[INFO] [stderr] 331 |     pub count_le: Option<(u64)>,
[INFO] [stderr]     |                          ^   ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 331 -     pub count_le: Option<(u64)>,
[INFO] [stderr] 331 +     pub count_le: Option<u64 >,
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around type
[INFO] [stderr]    --> src/cli.rs:335:26
[INFO] [stderr]     |
[INFO] [stderr] 335 |     pub count_ge: Option<(u64)>,
[INFO] [stderr]     |                          ^   ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 335 -     pub count_ge: Option<(u64)>,
[INFO] [stderr] 335 +     pub count_ge: Option<u64 >,
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]    --> src/keysum.rs:104:16
[INFO] [stderr]     |
[INFO] [stderr] 104 |             if ( v.is_none()) {
[INFO] [stderr]     |                ^^           ^
[INFO] [stderr]     |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 104 -             if ( v.is_none()) {
[INFO] [stderr] 104 +             if v.is_none()  {
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/keysum.rs:103:17
[INFO] [stderr]     |
[INFO] [stderr] 103 |             let mut v = self.matrix.get_mut(i);
[INFO] [stderr]     |                 ----^
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `null_str`
[INFO] [stderr]    --> src/keysum.rs:140:17
[INFO] [stderr]     |
[INFO] [stderr] 140 |             let null_str = String::from("NULL");
[INFO] [stderr]     |                 ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_null_str`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `ss`
[INFO] [stderr]    --> src/keysum.rs:167:53
[INFO] [stderr]     |
[INFO] [stderr] 167 | pub fn schema_rec<T>(matrix: &mut Vec<Vec<String>>, ss: &mut String, line: &str, record: &T, rec_len: usize, map: &mut MyMap, cfg: ...
[INFO] [stderr]     |                                                     ^^ help: if this is intentional, prefix it with an underscore: `_ss`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `line`
[INFO] [stderr]    --> src/keysum.rs:167:70
[INFO] [stderr]     |
[INFO] [stderr] 167 | ...<String>>, ss: &mut String, line: &str, record: &T, rec_len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usi...
[INFO] [stderr]     |                                ^^^^ help: if this is intentional, prefix it with an underscore: `_line`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `map`
[INFO] [stderr]    --> src/keysum.rs:167:110
[INFO] [stderr]     |
[INFO] [stderr] 167 | ... record: &T, rec_len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stderr]     |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_map`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `cfg`
[INFO] [stderr]    --> src/keysum.rs:167:127
[INFO] [stderr]     |
[INFO] [stderr] 167 | ...len: usize, map: &mut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stderr]     |                                 ^^^ help: if this is intentional, prefix it with an underscore: `_cfg`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rowcount`
[INFO] [stderr]    --> src/keysum.rs:167:141
[INFO] [stderr]     |
[INFO] [stderr] 167 | ...ut MyMap, cfg: &CliCfg, rowcount: &mut usize) -> (usize,usize)
[INFO] [stderr]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rowcount`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/keysum.rs:199:9
[INFO] [stderr]     |
[INFO] [stderr] 199 |     let mut lines_filtered = 0usize;
[INFO] [stderr]     |         ----^^^^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/keysum.rs:251:9
[INFO] [stderr]     |
[INFO] [stderr] 251 |     let mut brec: &mut KeySum = {
[INFO] [stderr]     |         ----^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/main.rs:496:17
[INFO] [stderr]     |
[INFO] [stderr] 496 |             let mut print_skipped = false; // for the stuff after head and before tail
[INFO] [stderr]     |                 ----^^^^^^^^^^^^^
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `print_skipped`
[INFO] [stderr]    --> src/main.rs:496:17
[INFO] [stderr]     |
[INFO] [stderr] 496 |             let mut print_skipped = false; // for the stuff after head and before tail
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_print_skipped`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `inner_count`
[INFO] [stderr]    --> src/main.rs:843:30
[INFO] [stderr]     |
[INFO] [stderr] 843 |             'LINE_LOOP: for (inner_count, line) in slice.split(|c| *c == b'\n').enumerate() {
[INFO] [stderr]     |                              ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_inner_count`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/main.rs:922:9
[INFO] [stderr]     |
[INFO] [stderr] 922 |     let mut csv_builder = create_csv_builder(&cfg);
[INFO] [stderr]     |         ----^^^^^^^^^^^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `err`
[INFO] [stderr]    --> src/main.rs:987:56
[INFO] [stderr]     |
[INFO] [stderr] 987 | ...                   csv::ErrorKind::Utf8 { ref err, pos } => {
[INFO] [stderr]     |                                              ^^^^^^^ help: try ignoring the field: `err: _`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `cnt_rec` is assigned to, but never used
[INFO] [stderr]    --> src/main.rs:999:21
[INFO] [stderr]     |
[INFO] [stderr] 999 |                 let mut cnt_rec = 0usize;
[INFO] [stderr]     |                     ^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: consider using `_cnt_rec` instead
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `err`
[INFO] [stderr]     --> src/main.rs:1021:56
[INFO] [stderr]      |
[INFO] [stderr] 1021 | ...                   csv::ErrorKind::Utf8 { ref err, pos } => {
[INFO] [stderr]      |                                              ^^^^^^^ help: try ignoring the field: `err: _`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `cnt_rec` is never read
[INFO] [stderr]     --> src/main.rs:1015:37
[INFO] [stderr]      |
[INFO] [stderr] 1015 | ...                   cnt_rec += 1;
[INFO] [stderr]      |                       ^^^^^^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = help: maybe it is overwritten before being read?
[INFO] [stderr]      = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `e`
[INFO] [stderr]     --> src/main.rs:1148:28
[INFO] [stderr]      |
[INFO] [stderr] 1148 |                 if let Err(e) = line {
[INFO] [stderr]      |                            ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]     --> src/main.rs:1215:13
[INFO] [stderr]      |
[INFO] [stderr] 1215 |         let mut b = slice[pos];
[INFO] [stderr]      |             ----^
[INFO] [stderr]      |             |
[INFO] [stderr]      |             help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: panic message is not a string literal
[INFO] [stderr]    --> src/main.rs:761:20
[INFO] [stderr]     |
[INFO] [stderr] 761 |             panic!(err_msg);
[INFO] [stderr]     |                    ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stderr]     = note: `#[warn(non_fmt_panics)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stderr] help: add a "{}" format string to `Display` the message
[INFO] [stderr]     |
[INFO] [stderr] 761 |             panic!("{}", err_msg);
[INFO] [stderr]     |                    +++++
[INFO] [stderr] 
[INFO] [stderr] warning: panic message is not a string literal
[INFO] [stderr]    --> src/main.rs:908:20
[INFO] [stderr]     |
[INFO] [stderr] 908 |             panic!(err_msg);
[INFO] [stderr]     |                    ^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stderr] help: add a "{}" format string to `Display` the message
[INFO] [stderr]     |
[INFO] [stderr] 908 |             panic!("{}", err_msg);
[INFO] [stderr]     |                    +++++
[INFO] [stderr] 
[INFO] [stderr] warning: panic message is not a string literal
[INFO] [stderr]     --> src/main.rs:1049:20
[INFO] [stderr]      |
[INFO] [stderr] 1049 |             panic!(err_msg);
[INFO] [stderr]      |                    ^^^^^^^
[INFO] [stderr]      |
[INFO] [stderr]      = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021
[INFO] [stderr]      = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/panic-macro-consistency.html>
[INFO] [stderr] help: add a "{}" format string to `Display` the message
[INFO] [stderr]      |
[INFO] [stderr] 1049 |             panic!("{}", err_msg);
[INFO] [stderr]      |                    +++++
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `ISO_8859` should have a snake case name
[INFO] [stderr]    --> src/cli.rs:296:9
[INFO] [stderr]     |
[INFO] [stderr] 296 |     pub ISO_8859: bool,
[INFO] [stderr]     |         ^^^^^^^^ help: convert the identifier to snake case (notice the capitalization): `iso_8859`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `mem_metric` is never used
[INFO] [stderr]   --> src/gen.rs:98:4
[INFO] [stderr]    |
[INFO] [stderr] 98 | fn mem_metric<'a>(v: usize) -> (f64, &'a str) {
[INFO] [stderr]    |    ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `sig_dig` is never used
[INFO] [stderr]    --> src/gen.rs:112:4
[INFO] [stderr]     |
[INFO] [stderr] 112 | fn sig_dig(v: f64, digits: usize) -> String {
[INFO] [stderr]     |    ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `mem_metric_digit` is never used
[INFO] [stderr]    --> src/gen.rs:136:8
[INFO] [stderr]     |
[INFO] [stderr] 136 | pub fn mem_metric_digit(v: usize, sig: usize) -> String {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `csv-groupby` (bin "append" test) generated 11 warnings
[INFO] [stderr] warning: `csv-groupby` (bin "gb") generated 28 warnings (run `cargo fix --bin "gb" -p csv-groupby` to apply 25 suggestions)
[INFO] [stderr] warning: `csv-groupby` (bin "gb" test) generated 28 warnings (28 duplicates)
[INFO] [stderr] warning: `csv-groupby` (bin "append") generated 14 warnings (11 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.24s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: fs_extra v1.2.0
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] [stderr]      Running unittests src/append.rs (/opt/rustwide/target/debug/deps/append-66df962d6a34105c)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test gen::test_mem_metric_digit ... ok
[INFO] [stdout] test gen::test_distro_format ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/create_very_large_file.rs (/opt/rustwide/target/debug/deps/create_very_large_file-59837d6d44363c25)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/gb-85d7ac98bb437948)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test gen::test_mem_metric_digit ... ok
[INFO] [stdout] test gen::test_distro_format ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/quick.rs (/opt/rustwide/target/debug/deps/quick-c8e5fa9776f73ac5)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test gen::test_distro_format ... ok
[INFO] [stdout] test gen::test_mem_metric_digit ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running src/test.rs (/opt/rustwide/target/debug/deps/general_tests-21f2c08518e2bb9d)
[INFO] [stdout] 
[INFO] [stdout] running 9 tests
[INFO] [stdout] test tests::just_write_stdstuff_to_look_at ... ok
[INFO] [stdout] test tests::force_threaded_small_block has been running for over 60 seconds
[INFO] [stdout] test tests::force_threaded_varied_block_size has been running for over 60 seconds
[INFO] [stdout] test tests::force_threaded_varied_block_size_keyones has been running for over 60 seconds
[INFO] [stdout] test tests::force_threaded_varied_block_size_no_final_newline has been running for over 60 seconds
[INFO] [stdout] test tests::re_force_thread_small_block has been running for over 60 seconds
[INFO] [stdout] test tests::re_force_thread_small_block_afile has been running for over 60 seconds
[INFO] [stdout] test tests::run_easy has been running for over 60 seconds
[INFO] [stdout] test tests::write_distros has been running for over 60 seconds
[INFO] [stdout] test tests::run_easy ... ok
[INFO] [stdout] test tests::write_distros ... ok
[INFO] [stdout] test tests::force_threaded_small_block ... ok
[INFO] [stdout] test tests::re_force_thread_small_block_afile ... ok
[INFO] [stdout] test tests::re_force_thread_small_block ... ok
[INFO] [stdout] test tests::force_threaded_varied_block_size_keyones ... ok
[INFO] [stdout] test tests::force_threaded_varied_block_size ... ok
[INFO] [stdout] test tests::force_threaded_varied_block_size_no_final_newline ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 9 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 121.14s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "b789687374a57c7bf0c6d5ad89f4669dae7bf9d69e75dcdd9f0ca6291b2fbd9c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b789687374a57c7bf0c6d5ad89f4669dae7bf9d69e75dcdd9f0ca6291b2fbd9c", kill_on_drop: false }`
[INFO] [stdout] b789687374a57c7bf0c6d5ad89f4669dae7bf9d69e75dcdd9f0ca6291b2fbd9c
