[INFO] cloning repository https://github.com/tristanpoland/Flex-SH
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/tristanpoland/Flex-SH" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftristanpoland%2FFlex-SH", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftristanpoland%2FFlex-SH'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 299616460eb9dab28ee67d84dbcc78f91c6da6a1
[INFO] testing tristanpoland/Flex-SH against try#bd7d74411512a3dd3b35d2f699c51dd2557c7e7e+cargoflags=-Zbuild-dir-new-layout for pr-149852-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftristanpoland%2FFlex-SH" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/tristanpoland/Flex-SH
[INFO] finished tweaking git repo https://github.com/tristanpoland/Flex-SH
[INFO] tweaked toml for git repo https://github.com/tristanpoland/Flex-SH written to /workspace/builds/worker-3-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/tristanpoland/Flex-SH on toolchain bd7d74411512a3dd3b35d2f699c51dd2557c7e7e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/tristanpoland/Flex-SH 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" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] d5c20ab1bb732d697dedcc4f6e1e32b354a122fc3a7cea1825c5f59892175a80
[INFO] running `Command { std: "docker" "start" "-a" "d5c20ab1bb732d697dedcc4f6e1e32b354a122fc3a7cea1825c5f59892175a80", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "d5c20ab1bb732d697dedcc4f6e1e32b354a122fc3a7cea1825c5f59892175a80", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d5c20ab1bb732d697dedcc4f6e1e32b354a122fc3a7cea1825c5f59892175a80", kill_on_drop: false }`
[INFO] [stdout] d5c20ab1bb732d697dedcc4f6e1e32b354a122fc3a7cea1825c5f59892175a80
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "build" "--frozen" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 62ebb3f19399de56be65e66898ba855afcc01782d9bcee4e61c67c2474165bb7
[INFO] running `Command { std: "docker" "start" "-a" "62ebb3f19399de56be65e66898ba855afcc01782d9bcee4e61c67c2474165bb7", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.175
[INFO] [stderr]    Compiling serde_core v1.0.221
[INFO] [stderr]    Compiling log v0.4.28
[INFO] [stderr]    Compiling rustix v1.1.2
[INFO] [stderr]    Compiling serde v1.0.221
[INFO] [stderr]    Compiling linux-raw-sys v0.11.0
[INFO] [stderr]    Compiling lock_api v0.4.13
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling nix v0.30.1
[INFO] [stderr]    Compiling anstyle v1.0.11
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling regex-syntax v0.8.6
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling anstyle-query v1.1.4
[INFO] [stderr]    Compiling nibble_vec v0.1.0
[INFO] [stderr]    Compiling litrs v0.4.2
[INFO] [stderr]    Compiling anyhow v1.0.99
[INFO] [stderr]    Compiling endian-type v0.1.2
[INFO] [stderr]    Compiling anstream v0.6.20
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling thiserror v2.0.16
[INFO] [stderr]    Compiling clap_lex v0.7.5
[INFO] [stderr]    Compiling winnow v0.7.13
[INFO] [stderr]    Compiling serde_json v1.0.144
[INFO] [stderr]    Compiling convert_case v0.7.1
[INFO] [stderr]    Compiling radix_trie v0.2.1
[INFO] [stderr]    Compiling clap_builder v4.5.47
[INFO] [stderr]    Compiling toml_writer v1.0.2
[INFO] [stderr]    Compiling jiff v0.2.15
[INFO] [stderr]    Compiling unicode-width v0.2.1
[INFO] [stderr]    Compiling glob v0.3.3
[INFO] [stderr]    Compiling colored v3.0.0
[INFO] [stderr]    Compiling document-features v0.2.11
[INFO] [stderr]    Compiling regex-automata v0.4.10
[INFO] [stderr]    Compiling toml_parser v1.0.2
[INFO] [stderr]    Compiling signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling dirs-sys v0.5.0
[INFO] [stderr]    Compiling socket2 v0.6.0
[INFO] [stderr]    Compiling subprocess v0.2.9
[INFO] [stderr]    Compiling dirs v6.0.0
[INFO] [stderr]    Compiling parking_lot v0.12.4
[INFO] [stderr]    Compiling signal-hook-mio v0.2.4
[INFO] [stderr]    Compiling fd-lock v4.0.4
[INFO] [stderr]    Compiling gethostname v1.0.2
[INFO] [stderr]    Compiling serde_derive v1.0.221
[INFO] [stderr]    Compiling derive_more-impl v2.0.1
[INFO] [stderr]    Compiling clap_derive v4.5.47
[INFO] [stderr]    Compiling thiserror-impl v2.0.16
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling rustyline-derive v0.10.0
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling rustyline v17.0.1
[INFO] [stderr]    Compiling derive_more v2.0.1
[INFO] [stderr]    Compiling ctrlc v3.5.0
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling clap v4.5.47
[INFO] [stderr]    Compiling regex v1.11.2
[INFO] [stderr]    Compiling env_filter v0.1.3
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling serde_spanned v1.0.0
[INFO] [stderr]    Compiling toml_datetime v0.7.0
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling toml v0.9.5
[INFO] [stderr]    Compiling flex-sh v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> src/main.rs:4:18
[INFO] [stdout]   |
[INFO] [stdout] 4 | use log::{error, info, debug};
[INFO] [stdout]   |                  ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> src/config/mod.rs:6:18
[INFO] [stdout]   |
[INFO] [stdout] 6 | use log::{debug, info};
[INFO] [stdout]   |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Helper`
[INFO] [stdout]  --> src/core/shell.rs:8:25
[INFO] [stdout]   |
[INFO] [stdout] 8 | use rustyline::{Editor, Helper, Context, Config as EditorConfig, CompletionType, EditMode};
[INFO] [stdout]   |                         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Ordering`
[INFO] [stdout]  --> src/core/executor.rs:8:43
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::sync::{Arc, atomic::{AtomicBool, Ordering}};
[INFO] [stdout]   |                                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ctrlc`
[INFO] [stdout]  --> src/core/executor.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use ctrlc;
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `path::expand_tilde`
[INFO] [stdout]  --> src/utils/mod.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub use path::expand_tilde;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/executor.rs:172:39
[INFO] [stdout]     |
[INFO] [stdout] 172 |     async fn execute_pipeline(&mut self, mut command: ParsedCommand, current_dir: &PathBuf) -> Result<i32> {
[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: `ctx`
[INFO] [stdout]    --> src/core/shell.rs:319:9
[INFO] [stdout]     |
[INFO] [stdout] 319 |         ctx: &Context<'_>,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/shell.rs:631:35
[INFO] [stdout]     |
[INFO] [stdout] 631 |     fn process_color_codes(&self, mut prompt: String) -> String {
[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/builtins/cd.rs:31:21
[INFO] [stdout]    |
[INFO] [stdout] 31 |                 let mut target = if expanded_path.is_absolute() {
[INFO] [stdout]    |                     ----^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `colored_text`
[INFO] [stdout]   --> src/terminal/mod.rs:88:25
[INFO] [stdout]    |
[INFO] [stdout] 88 |                     let colored_text = bracket_content.bright_cyan().to_string();
[INFO] [stdout]    |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_colored_text`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `save` is never used
[INFO] [stdout]    --> src/config/mod.rs:125:12
[INFO] [stdout]     |
[INFO] [stdout]  87 | impl ShellConfig {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn save(&self, path: &PathBuf) -> Result<()> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config_path` is never read
[INFO] [stdout]  --> src/config/settings.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Config {
[INFO] [stdout]   |            ------ field in this struct
[INFO] [stdout] 6 |     config: ShellConfig,
[INFO] [stdout] 7 |     config_path: Option<PathBuf>,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_mut`, `save`, and `reload` are never used
[INFO] [stdout]   --> src/config/settings.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | impl Config {
[INFO] [stdout]    | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn get_mut(&mut self) -> &mut ShellConfig {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn save(&self) -> Result<()> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39 |     pub fn reload(&mut self) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `process_color_codes`, `remove_color_codes`, and `exit_code` are never used
[INFO] [stdout]    --> src/core/shell.rs:631:8
[INFO] [stdout]     |
[INFO] [stdout] 425 | impl Shell {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 631 |     fn process_color_codes(&self, mut prompt: String) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 686 |     fn remove_color_codes(&self, prompt: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 719 |     pub fn exit_code(&self) -> i32 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `remove_alias` is never used
[INFO] [stdout]    --> src/core/parser.rs:199:12
[INFO] [stdout]     |
[INFO] [stdout]  35 | impl Parser {
[INFO] [stdout]     | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn remove_alias(&mut self, name: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `interrupt_flag` is never read
[INFO] [stdout]   --> src/core/executor.rs:16:2
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct Executor {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 15 |     background_processes: HashMap<u32, Child>,
[INFO] [stdout] 16 |     interrupt_flag: Arc<AtomicBool>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `cleanup_background_processes` is never used
[INFO] [stdout]    --> src/core/executor.rs:261:15
[INFO] [stdout]     |
[INFO] [stdout]  19 | impl Executor {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 261 |     pub async fn cleanup_background_processes(&mut self) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_entries`, `search`, and `clear` are never used
[INFO] [stdout]   --> src/core/history.rs:61:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl History {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn get_entries(&self) -> &VecDeque<String> {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn search(&self, pattern: &str) -> Vec<String> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn clear(&mut self) -> Result<()> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `print_success`, `print_warning`, `colorize_prompt`, and `colorize_output` are never used
[INFO] [stdout]    --> src/terminal/mod.rs:46:18
[INFO] [stdout]     |
[INFO] [stdout]  13 | impl Terminal {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  46 |     pub async fn print_success(&self, message: &str) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  55 |     pub async fn print_warning(&self, message: &str) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  64 |     pub fn colorize_prompt(&self, prompt: &str) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn colorize_output(&self, text: &str, color_type: OutputColorType) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `OutputColorType` is never used
[INFO] [stdout]    --> src/terminal/mod.rs:144:10
[INFO] [stdout]     |
[INFO] [stdout] 144 | pub enum OutputColorType {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ColorScheme` is never constructed
[INFO] [stdout]  --> src/terminal/colors.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ColorScheme {
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `default_scheme`, `dark_scheme`, `light_scheme`, `monokai_scheme`, `get_color`, and `get_available_schemes` are never used
[INFO] [stdout]   --> src/terminal/colors.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl ColorScheme {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] 10 |     pub fn default_scheme() -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn dark_scheme() -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn light_scheme() -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     pub fn monokai_scheme() -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 94 |     pub fn get_color(&self, key: &str) -> Option<&String> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 98 |     pub fn get_available_schemes() -> Vec<ColorScheme> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TerminalEvent` is never used
[INFO] [stdout]  --> src/terminal/events.rs:4:10
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub enum TerminalEvent {
[INFO] [stdout]   |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/terminal/events.rs:27:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl TerminalEvent {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout]  27 |     pub fn is_key(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  31 |     pub fn is_mouse(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     pub fn is_resize(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  39 |     pub fn is_ctrl_c(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  52 |     pub fn is_ctrl_d(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  65 |     pub fn is_enter(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  75 |     pub fn is_tab(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     pub fn is_backspace(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn is_delete(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn is_arrow_up(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn is_arrow_down(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn is_arrow_left(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn is_arrow_right(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn get_char(&self) -> Option<char> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub fn has_ctrl(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 165 |     pub fn has_alt(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn has_shift(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TerminalInterface` is never constructed
[INFO] [stdout]   --> src/terminal/interface.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct TerminalInterface {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/terminal/interface.rs:18:12
[INFO] [stdout]     |
[INFO] [stdout]  17 | impl TerminalInterface {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  18 |     pub fn new(color_scheme: ColorScheme) -> Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  27 |     pub fn update_size(&mut self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  34 |     pub fn clear_screen(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  39 |     pub fn clear_line(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  44 |     pub fn move_cursor(&self, x: u16, y: u16) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  49 |     pub fn hide_cursor(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  54 |     pub fn show_cursor(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  59 |     pub fn print_colored(&self, text: &str, _color_key: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  65 |     pub fn print_status_line(&self, status: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub fn print_completion_menu(&self, completions: &[String], selected: usize) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub fn get_dimensions(&self) -> (u16, u16) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn set_color_scheme(&mut self, scheme: ColorScheme) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn draw_border(&self, x: u16, y: u16, width: u16, height: u16, title: Option<&str>) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn draw_progress_bar(&self, x: u16, y: u16, width: u16, progress: f32, label: Option<&str>) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalize_path` is never used
[INFO] [stdout]   --> src/utils/path.rs:30:8
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn normalize_path<P: AsRef<Path>>(path: P) -> PathBuf {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_hidden` is never used
[INFO] [stdout]   --> src/utils/path.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub fn is_hidden<P: AsRef<Path>>(path: P) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_parent_and_name` is never used
[INFO] [stdout]   --> src/utils/path.rs:49:8
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub fn get_parent_and_name<P: AsRef<Path>>(path: P) -> (PathBuf, String) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompletionCandidate` is never constructed
[INFO] [stdout]  --> src/utils/completion.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct CompletionCandidate {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CompletionKind` is never used
[INFO] [stdout]   --> src/utils/completion.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum CompletionKind {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompletionEngine` is never constructed
[INFO] [stdout]   --> src/utils/completion.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct CompletionEngine {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/utils/completion.rs:31:12
[INFO] [stdout]     |
[INFO] [stdout]  30 | impl CompletionEngine {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout]  31 |     pub fn new(show_hidden: bool, case_sensitive: bool) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  38 |     pub fn complete(&self, input: &str, cursor_pos: usize) -> Vec<CompletionCandidate> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  50 |     fn extract_word_at_cursor(&self, input: &str, cursor_pos: usize) -> (String, usize) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  68 |     fn complete_commands(&self, prefix: &str) -> Vec<CompletionCandidate> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     fn complete_paths(&self, prefix: &str) -> Vec<CompletionCandidate> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 186 |     fn matches_prefix(&self, candidate: &str, prefix: &str) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 198 |     fn is_executable(&self, path: &Path) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `expand_glob` is never used
[INFO] [stdout]  --> src/utils/glob_expand.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn expand_glob(pattern: &str) -> Result<Vec<PathBuf>> {
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `has_glob_chars` is never used
[INFO] [stdout]   --> src/utils/glob_expand.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub fn has_glob_chars(pattern: &str) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `expand_args` is never used
[INFO] [stdout]   --> src/utils/glob_expand.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn expand_args(args: &[String]) -> Result<Vec<String>> {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 30.31s
[INFO] running `Command { std: "docker" "inspect" "62ebb3f19399de56be65e66898ba855afcc01782d9bcee4e61c67c2474165bb7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "62ebb3f19399de56be65e66898ba855afcc01782d9bcee4e61c67c2474165bb7", kill_on_drop: false }`
[INFO] [stdout] 62ebb3f19399de56be65e66898ba855afcc01782d9bcee4e61c67c2474165bb7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "--no-run" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 0e418e0acfdae983abbc31aaeeb7eaafd579e7026abf9c233016e5a654a2441a
[INFO] running `Command { std: "docker" "start" "-a" "0e418e0acfdae983abbc31aaeeb7eaafd579e7026abf9c233016e5a654a2441a", kill_on_drop: false }`
[INFO] [stderr]    Compiling regex-automata v0.4.10
[INFO] [stderr]    Compiling doc-comment v0.3.3
[INFO] [stderr]    Compiling predicates-core v1.0.9
[INFO] [stderr]    Compiling float-cmp v0.10.0
[INFO] [stderr]    Compiling difflib v0.4.0
[INFO] [stderr]    Compiling termtree v0.5.1
[INFO] [stderr]    Compiling assert_cmd v2.0.17
[INFO] [stderr]    Compiling normalize-line-endings v0.3.0
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling wait-timeout v0.2.1
[INFO] [stderr]    Compiling predicates-tree v1.0.12
[INFO] [stderr]    Compiling tempfile v3.22.0
[INFO] [stderr]    Compiling regex v1.11.2
[INFO] [stderr]    Compiling bstr v1.12.0
[INFO] [stderr]    Compiling env_filter v0.1.3
[INFO] [stderr]    Compiling predicates v3.1.3
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling flex-sh v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> src/main.rs:4:18
[INFO] [stdout]   |
[INFO] [stdout] 4 | use log::{error, info, debug};
[INFO] [stdout]   |                  ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> src/config/mod.rs:6:18
[INFO] [stdout]   |
[INFO] [stdout] 6 | use log::{debug, info};
[INFO] [stdout]   |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Helper`
[INFO] [stdout]  --> src/core/shell.rs:8:25
[INFO] [stdout]   |
[INFO] [stdout] 8 | use rustyline::{Editor, Helper, Context, Config as EditorConfig, CompletionType, EditMode};
[INFO] [stdout]   |                         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Ordering`
[INFO] [stdout]  --> src/core/executor.rs:8:43
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::sync::{Arc, atomic::{AtomicBool, Ordering}};
[INFO] [stdout]   |                                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ctrlc`
[INFO] [stdout]  --> src/core/executor.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use ctrlc;
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `path::expand_tilde`
[INFO] [stdout]  --> src/utils/mod.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub use path::expand_tilde;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> src/main.rs:4:18
[INFO] [stdout]   |
[INFO] [stdout] 4 | use log::{error, info, debug};
[INFO] [stdout]   |                  ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `info`
[INFO] [stdout]  --> src/config/mod.rs:6:18
[INFO] [stdout]   |
[INFO] [stdout] 6 | use log::{debug, info};
[INFO] [stdout]   |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Helper`
[INFO] [stdout]  --> src/core/shell.rs:8:25
[INFO] [stdout]   |
[INFO] [stdout] 8 | use rustyline::{Editor, Helper, Context, Config as EditorConfig, CompletionType, EditMode};
[INFO] [stdout]   |                         ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Ordering`
[INFO] [stdout]  --> src/core/executor.rs:8:43
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::sync::{Arc, atomic::{AtomicBool, Ordering}};
[INFO] [stdout]   |                                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ctrlc`
[INFO] [stdout]  --> src/core/executor.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use ctrlc;
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `path::expand_tilde`
[INFO] [stdout]  --> src/utils/mod.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub use path::expand_tilde;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/executor.rs:172:39
[INFO] [stdout]     |
[INFO] [stdout] 172 |     async fn execute_pipeline(&mut self, mut command: ParsedCommand, current_dir: &PathBuf) -> Result<i32> {
[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/core/executor.rs:172:39
[INFO] [stdout]     |
[INFO] [stdout] 172 |     async fn execute_pipeline(&mut self, mut command: ParsedCommand, current_dir: &PathBuf) -> Result<i32> {
[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: `ctx`
[INFO] [stdout]    --> src/core/shell.rs:319:9
[INFO] [stdout]     |
[INFO] [stdout] 319 |         ctx: &Context<'_>,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/shell.rs:631:35
[INFO] [stdout]     |
[INFO] [stdout] 631 |     fn process_color_codes(&self, mut prompt: String) -> String {
[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/builtins/cd.rs:31:21
[INFO] [stdout]    |
[INFO] [stdout] 31 |                 let mut target = if expanded_path.is_absolute() {
[INFO] [stdout]    |                     ----^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `colored_text`
[INFO] [stdout]   --> src/terminal/mod.rs:88:25
[INFO] [stdout]    |
[INFO] [stdout] 88 |                     let colored_text = bracket_content.bright_cyan().to_string();
[INFO] [stdout]    |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_colored_text`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `save` is never used
[INFO] [stdout]    --> src/config/mod.rs:125:12
[INFO] [stdout]     |
[INFO] [stdout]  87 | impl ShellConfig {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn save(&self, path: &PathBuf) -> Result<()> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config_path` is never read
[INFO] [stdout]  --> src/config/settings.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Config {
[INFO] [stdout]   |            ------ field in this struct
[INFO] [stdout] 6 |     config: ShellConfig,
[INFO] [stdout] 7 |     config_path: Option<PathBuf>,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_mut`, `save`, and `reload` are never used
[INFO] [stdout]   --> src/config/settings.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | impl Config {
[INFO] [stdout]    | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn get_mut(&mut self) -> &mut ShellConfig {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn save(&self) -> Result<()> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39 |     pub fn reload(&mut self) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `process_color_codes`, `remove_color_codes`, and `exit_code` are never used
[INFO] [stdout]    --> src/core/shell.rs:631:8
[INFO] [stdout]     |
[INFO] [stdout] 425 | impl Shell {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 631 |     fn process_color_codes(&self, mut prompt: String) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 686 |     fn remove_color_codes(&self, prompt: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 719 |     pub fn exit_code(&self) -> i32 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `remove_alias` is never used
[INFO] [stdout]    --> src/core/parser.rs:199:12
[INFO] [stdout]     |
[INFO] [stdout]  35 | impl Parser {
[INFO] [stdout]     | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn remove_alias(&mut self, name: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `interrupt_flag` is never read
[INFO] [stdout]   --> src/core/executor.rs:16:2
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct Executor {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 15 |     background_processes: HashMap<u32, Child>,
[INFO] [stdout] 16 |     interrupt_flag: Arc<AtomicBool>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `cleanup_background_processes` is never used
[INFO] [stdout]    --> src/core/executor.rs:261:15
[INFO] [stdout]     |
[INFO] [stdout]  19 | impl Executor {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 261 |     pub async fn cleanup_background_processes(&mut self) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_entries`, `search`, and `clear` are never used
[INFO] [stdout]   --> src/core/history.rs:61:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl History {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn get_entries(&self) -> &VecDeque<String> {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn search(&self, pattern: &str) -> Vec<String> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn clear(&mut self) -> Result<()> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `print_success`, `print_warning`, `colorize_prompt`, and `colorize_output` are never used
[INFO] [stdout]    --> src/terminal/mod.rs:46:18
[INFO] [stdout]     |
[INFO] [stdout]  13 | impl Terminal {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  46 |     pub async fn print_success(&self, message: &str) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  55 |     pub async fn print_warning(&self, message: &str) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  64 |     pub fn colorize_prompt(&self, prompt: &str) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn colorize_output(&self, text: &str, color_type: OutputColorType) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `OutputColorType` is never used
[INFO] [stdout]    --> src/terminal/mod.rs:144:10
[INFO] [stdout]     |
[INFO] [stdout] 144 | pub enum OutputColorType {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ColorScheme` is never constructed
[INFO] [stdout]  --> src/terminal/colors.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ColorScheme {
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `default_scheme`, `dark_scheme`, `light_scheme`, `monokai_scheme`, `get_color`, and `get_available_schemes` are never used
[INFO] [stdout]   --> src/terminal/colors.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl ColorScheme {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] 10 |     pub fn default_scheme() -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31 |     pub fn dark_scheme() -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn light_scheme() -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |     pub fn monokai_scheme() -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 94 |     pub fn get_color(&self, key: &str) -> Option<&String> {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 98 |     pub fn get_available_schemes() -> Vec<ColorScheme> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `TerminalEvent` is never used
[INFO] [stdout]  --> src/terminal/events.rs:4:10
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub enum TerminalEvent {
[INFO] [stdout]   |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/terminal/events.rs:27:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl TerminalEvent {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout]  27 |     pub fn is_key(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  31 |     pub fn is_mouse(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     pub fn is_resize(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  39 |     pub fn is_ctrl_c(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  52 |     pub fn is_ctrl_d(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  65 |     pub fn is_enter(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  75 |     pub fn is_tab(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     pub fn is_backspace(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn is_delete(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn is_arrow_up(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn is_arrow_down(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn is_arrow_left(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn is_arrow_right(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn get_char(&self) -> Option<char> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub fn has_ctrl(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 165 |     pub fn has_alt(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn has_shift(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TerminalInterface` is never constructed
[INFO] [stdout]   --> src/terminal/interface.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct TerminalInterface {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/terminal/interface.rs:18:12
[INFO] [stdout]     |
[INFO] [stdout]  17 | impl TerminalInterface {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  18 |     pub fn new(color_scheme: ColorScheme) -> Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  27 |     pub fn update_size(&mut self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  34 |     pub fn clear_screen(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  39 |     pub fn clear_line(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  44 |     pub fn move_cursor(&self, x: u16, y: u16) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  49 |     pub fn hide_cursor(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  54 |     pub fn show_cursor(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  59 |     pub fn print_colored(&self, text: &str, _color_key: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  65 |     pub fn print_status_line(&self, status: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub fn print_completion_menu(&self, completions: &[String], selected: usize) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     pub fn get_dimensions(&self) -> (u16, u16) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn set_color_scheme(&mut self, scheme: ColorScheme) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn draw_border(&self, x: u16, y: u16, width: u16, height: u16, title: Option<&str>) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn draw_progress_bar(&self, x: u16, y: u16, width: u16, progress: f32, label: Option<&str>) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalize_path` is never used
[INFO] [stdout]   --> src/utils/path.rs:30:8
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn normalize_path<P: AsRef<Path>>(path: P) -> PathBuf {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_hidden` is never used
[INFO] [stdout]   --> src/utils/path.rs:41:8
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub fn is_hidden<P: AsRef<Path>>(path: P) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_parent_and_name` is never used
[INFO] [stdout]   --> src/utils/path.rs:49:8
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub fn get_parent_and_name<P: AsRef<Path>>(path: P) -> (PathBuf, String) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompletionCandidate` is never constructed
[INFO] [stdout]  --> src/utils/completion.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct CompletionCandidate {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CompletionKind` is never used
[INFO] [stdout]   --> src/utils/completion.rs:16:10
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum CompletionKind {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompletionEngine` is never constructed
[INFO] [stdout]   --> src/utils/completion.rs:25:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct CompletionEngine {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/utils/completion.rs:31:12
[INFO] [stdout]     |
[INFO] [stdout]  30 | impl CompletionEngine {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout]  31 |     pub fn new(show_hidden: bool, case_sensitive: bool) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  38 |     pub fn complete(&self, input: &str, cursor_pos: usize) -> Vec<CompletionCandidate> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  50 |     fn extract_word_at_cursor(&self, input: &str, cursor_pos: usize) -> (String, usize) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  68 |     fn complete_commands(&self, prefix: &str) -> Vec<CompletionCandidate> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     fn complete_paths(&self, prefix: &str) -> Vec<CompletionCandidate> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 186 |     fn matches_prefix(&self, candidate: &str, prefix: &str) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 198 |     fn is_executable(&self, path: &Path) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `expand_glob` is never used
[INFO] [stdout]  --> src/utils/glob_expand.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn expand_glob(pattern: &str) -> Result<Vec<PathBuf>> {
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `has_glob_chars` is never used
[INFO] [stdout]   --> src/utils/glob_expand.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub fn has_glob_chars(pattern: &str) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `expand_args` is never used
[INFO] [stdout]   --> src/utils/glob_expand.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn expand_args(args: &[String]) -> Result<Vec<String>> {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ctx`
[INFO] [stdout]    --> src/core/shell.rs:319:9
[INFO] [stdout]     |
[INFO] [stdout] 319 |         ctx: &Context<'_>,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/core/shell.rs:631:35
[INFO] [stdout]     |
[INFO] [stdout] 631 |     fn process_color_codes(&self, mut prompt: String) -> String {
[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/builtins/cd.rs:31:21
[INFO] [stdout]    |
[INFO] [stdout] 31 |                 let mut target = if expanded_path.is_absolute() {
[INFO] [stdout]    |                     ----^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `colored_text`
[INFO] [stdout]   --> src/terminal/mod.rs:88:25
[INFO] [stdout]    |
[INFO] [stdout] 88 |                     let colored_text = bracket_content.bright_cyan().to_string();
[INFO] [stdout]    |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_colored_text`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `save` is never used
[INFO] [stdout]    --> src/config/mod.rs:125:12
[INFO] [stdout]     |
[INFO] [stdout]  87 | impl ShellConfig {
[INFO] [stdout]     | ---------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn save(&self, path: &PathBuf) -> Result<()> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config_path` is never read
[INFO] [stdout]  --> src/config/settings.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Config {
[INFO] [stdout]   |            ------ field in this struct
[INFO] [stdout] 6 |     config: ShellConfig,
[INFO] [stdout] 7 |     config_path: Option<PathBuf>,
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_mut`, `save`, and `reload` are never used
[INFO] [stdout]   --> src/config/settings.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | impl Config {
[INFO] [stdout]    | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub fn get_mut(&mut self) -> &mut ShellConfig {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn save(&self) -> Result<()> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39 |     pub fn reload(&mut self) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `process_color_codes`, `remove_color_codes`, and `exit_code` are never used
[INFO] [stdout]    --> src/core/shell.rs:631:8
[INFO] [stdout]     |
[INFO] [stdout] 425 | impl Shell {
[INFO] [stdout]     | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 631 |     fn process_color_codes(&self, mut prompt: String) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 686 |     fn remove_color_codes(&self, prompt: &str) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 719 |     pub fn exit_code(&self) -> i32 {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `remove_alias` is never used
[INFO] [stdout]    --> src/core/parser.rs:199:12
[INFO] [stdout]     |
[INFO] [stdout]  35 | impl Parser {
[INFO] [stdout]     | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 199 |     pub fn remove_alias(&mut self, name: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `interrupt_flag` is never read
[INFO] [stdout]   --> src/core/executor.rs:16:2
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct Executor {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 15 |     background_processes: HashMap<u32, Child>,
[INFO] [stdout] 16 |     interrupt_flag: Arc<AtomicBool>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `cleanup_background_processes` is never used
[INFO] [stdout]    --> src/core/executor.rs:261:15
[INFO] [stdout]     |
[INFO] [stdout]  19 | impl Executor {
[INFO] [stdout]     | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 261 |     pub async fn cleanup_background_processes(&mut self) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_entries` and `clear` are never used
[INFO] [stdout]   --> src/core/history.rs:61:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl History {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn get_entries(&self) -> &VecDeque<String> {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn clear(&mut self) -> Result<()> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `print_success`, `print_warning`, `colorize_prompt`, and `colorize_output` are never used
[INFO] [stdout]    --> src/terminal/mod.rs:46:18
[INFO] [stdout]     |
[INFO] [stdout]  13 | impl Terminal {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  46 |     pub async fn print_success(&self, message: &str) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  55 |     pub async fn print_warning(&self, message: &str) -> Result<()> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  64 |     pub fn colorize_prompt(&self, prompt: &str) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn colorize_output(&self, text: &str, color_type: OutputColorType) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `OutputColorType` is never used
[INFO] [stdout]    --> src/terminal/mod.rs:144:10
[INFO] [stdout]     |
[INFO] [stdout] 144 | pub enum OutputColorType {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/terminal/events.rs:6:11
[INFO] [stdout]   |
[INFO] [stdout] 6 |     Mouse(MouseEvent),
[INFO] [stdout]   |     ----- ^^^^^^^^^^
[INFO] [stdout]   |     |
[INFO] [stdout]   |     field in this variant
[INFO] [stdout]   |
[INFO] [stdout]   = note: `TerminalEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]   |
[INFO] [stdout] 6 -     Mouse(MouseEvent),
[INFO] [stdout] 6 +     Mouse(()),
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `0` and `1` are never read
[INFO] [stdout]  --> src/terminal/events.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 |     Resize(u16, u16),
[INFO] [stdout]   |     ------ ^^^  ^^^
[INFO] [stdout]   |     |
[INFO] [stdout]   |     fields in this variant
[INFO] [stdout]   |
[INFO] [stdout]   = note: `TerminalEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the fields to be of unit type to suppress this warning while preserving the field numbering, or remove the fields
[INFO] [stdout]   |
[INFO] [stdout] 7 -     Resize(u16, u16),
[INFO] [stdout] 7 +     Resize((), ()),
[INFO] [stdout]   |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/terminal/events.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 |     Paste(String),
[INFO] [stdout]    |     ----- ^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TerminalEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 10 -     Paste(String),
[INFO] [stdout] 10 +     Paste(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/terminal/events.rs:27:12
[INFO] [stdout]     |
[INFO] [stdout]  26 | impl TerminalEvent {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout]  27 |     pub fn is_key(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  31 |     pub fn is_mouse(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     pub fn is_resize(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  52 |     pub fn is_ctrl_d(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  75 |     pub fn is_tab(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     pub fn is_backspace(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn is_delete(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn is_arrow_up(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn is_arrow_down(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn is_arrow_left(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn is_arrow_right(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `color_scheme` is never read
[INFO] [stdout]   --> src/terminal/interface.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct TerminalInterface {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] 12 |     color_scheme: ColorScheme,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/terminal/interface.rs:27:12
[INFO] [stdout]     |
[INFO] [stdout]  17 | impl TerminalInterface {
[INFO] [stdout]     | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  27 |     pub fn update_size(&mut self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  34 |     pub fn clear_screen(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  39 |     pub fn clear_line(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  44 |     pub fn move_cursor(&self, x: u16, y: u16) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  49 |     pub fn hide_cursor(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  54 |     pub fn show_cursor(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  59 |     pub fn print_colored(&self, text: &str, _color_key: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  65 |     pub fn print_status_line(&self, status: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub fn print_completion_menu(&self, completions: &[String], selected: usize) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn set_color_scheme(&mut self, scheme: ColorScheme) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn draw_border(&self, x: u16, y: u16, width: u16, height: u16, title: Option<&str>) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn draw_progress_bar(&self, x: u16, y: u16, width: u16, progress: f32, label: Option<&str>) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalize_path` is never used
[INFO] [stdout]   --> src/utils/path.rs:30:8
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn normalize_path<P: AsRef<Path>>(path: P) -> PathBuf {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `display` and `description` are never read
[INFO] [stdout]   --> src/utils/completion.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct CompletionCandidate {
[INFO] [stdout]    |            ------------------- fields in this struct
[INFO] [stdout]  9 |     pub text: String,
[INFO] [stdout] 10 |     pub display: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 11 |     pub kind: CompletionKind,
[INFO] [stdout] 12 |     pub description: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CompletionCandidate` 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: variants `File`, `Directory`, `Variable`, and `Alias` are never constructed
[INFO] [stdout]   --> src/utils/completion.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub enum CompletionKind {
[INFO] [stdout]    |          -------------- variants in this enum
[INFO] [stdout] 17 |     Command,
[INFO] [stdout] 18 |     File,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 19 |     Directory,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 20 |     Builtin,
[INFO] [stdout] 21 |     Variable,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 22 |     Alias,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CompletionKind` 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: field `show_hidden` is never read
[INFO] [stdout]   --> src/utils/completion.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct CompletionEngine {
[INFO] [stdout]    |            ---------------- field in this struct
[INFO] [stdout] 26 |     show_hidden: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `complete` and `complete_paths` are never used
[INFO] [stdout]    --> src/utils/completion.rs:38:12
[INFO] [stdout]     |
[INFO] [stdout]  30 | impl CompletionEngine {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  38 |     pub fn complete(&self, input: &str, cursor_pos: usize) -> Vec<CompletionCandidate> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     fn complete_paths(&self, prefix: &str) -> Vec<CompletionCandidate> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 11.86s
[INFO] running `Command { std: "docker" "inspect" "0e418e0acfdae983abbc31aaeeb7eaafd579e7026abf9c233016e5a654a2441a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0e418e0acfdae983abbc31aaeeb7eaafd579e7026abf9c233016e5a654a2441a", kill_on_drop: false }`
[INFO] [stdout] 0e418e0acfdae983abbc31aaeeb7eaafd579e7026abf9c233016e5a654a2441a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 01ded7851068ab2ce0716237c127421097472b71d42cd3c161e09a4ecb874a71
[INFO] running `Command { std: "docker" "start" "-a" "01ded7851068ab2ce0716237c127421097472b71d42cd3c161e09a4ecb874a71", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `info`
[INFO] [stderr]  --> src/main.rs:4:18
[INFO] [stderr]   |
[INFO] [stderr] 4 | use log::{error, info, debug};
[INFO] [stderr]   |                  ^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `info`
[INFO] [stderr]  --> src/config/mod.rs:6:18
[INFO] [stderr]   |
[INFO] [stderr] 6 | use log::{debug, info};
[INFO] [stderr]   |                  ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Helper`
[INFO] [stderr]  --> src/core/shell.rs:8:25
[INFO] [stderr]   |
[INFO] [stderr] 8 | use rustyline::{Editor, Helper, Context, Config as EditorConfig, CompletionType, EditMode};
[INFO] [stderr]   |                         ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Ordering`
[INFO] [stderr]  --> src/core/executor.rs:8:43
[INFO] [stderr]   |
[INFO] [stderr] 8 | use std::sync::{Arc, atomic::{AtomicBool, Ordering}};
[INFO] [stderr]   |                                           ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ctrlc`
[INFO] [stderr]  --> src/core/executor.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 | use ctrlc;
[INFO] [stderr]   |     ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `path::expand_tilde`
[INFO] [stderr]  --> src/utils/mod.rs:6:9
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub use path::expand_tilde;
[INFO] [stderr]   |         ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/core/executor.rs:172:39
[INFO] [stderr]     |
[INFO] [stderr] 172 |     async fn execute_pipeline(&mut self, mut command: ParsedCommand, current_dir: &PathBuf) -> Result<i32> {
[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: `ctx`
[INFO] [stderr]    --> src/core/shell.rs:319:9
[INFO] [stderr]     |
[INFO] [stderr] 319 |         ctx: &Context<'_>,
[INFO] [stderr]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/core/shell.rs:631:35
[INFO] [stderr]     |
[INFO] [stderr] 631 |     fn process_color_codes(&self, mut prompt: String) -> String {
[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/builtins/cd.rs:31:21
[INFO] [stderr]    |
[INFO] [stderr] 31 |                 let mut target = if expanded_path.is_absolute() {
[INFO] [stderr]    |                     ----^^^^^^
[INFO] [stderr]    |                     |
[INFO] [stderr]    |                     help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `colored_text`
[INFO] [stderr]   --> src/terminal/mod.rs:88:25
[INFO] [stderr]    |
[INFO] [stderr] 88 |                     let colored_text = bracket_content.bright_cyan().to_string();
[INFO] [stderr]    |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_colored_text`
[INFO] [stderr] 
[INFO] [stderr] warning: method `save` is never used
[INFO] [stderr]    --> src/config/mod.rs:125:12
[INFO] [stderr]     |
[INFO] [stderr]  87 | impl ShellConfig {
[INFO] [stderr]     | ---------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 125 |     pub fn save(&self, path: &PathBuf) -> Result<()> {
[INFO] [stderr]     |            ^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: field `config_path` is never read
[INFO] [stderr]  --> src/config/settings.rs:7:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct Config {
[INFO] [stderr]   |            ------ field in this struct
[INFO] [stderr] 6 |     config: ShellConfig,
[INFO] [stderr] 7 |     config_path: Option<PathBuf>,
[INFO] [stderr]   |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `get_mut`, `save`, and `reload` are never used
[INFO] [stderr]   --> src/config/settings.rs:23:12
[INFO] [stderr]    |
[INFO] [stderr] 10 | impl Config {
[INFO] [stderr]    | ----------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 23 |     pub fn get_mut(&mut self) -> &mut ShellConfig {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 27 |     pub fn save(&self) -> Result<()> {
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 39 |     pub fn reload(&mut self) -> Result<()> {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `process_color_codes`, `remove_color_codes`, and `exit_code` are never used
[INFO] [stderr]    --> src/core/shell.rs:631:8
[INFO] [stderr]     |
[INFO] [stderr] 425 | impl Shell {
[INFO] [stderr]     | ---------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 631 |     fn process_color_codes(&self, mut prompt: String) -> String {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 686 |     fn remove_color_codes(&self, prompt: &str) -> String {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 719 |     pub fn exit_code(&self) -> i32 {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `remove_alias` is never used
[INFO] [stderr]    --> src/core/parser.rs:199:12
[INFO] [stderr]     |
[INFO] [stderr]  35 | impl Parser {
[INFO] [stderr]     | ----------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 199 |     pub fn remove_alias(&mut self, name: &str) {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `interrupt_flag` is never read
[INFO] [stderr]   --> src/core/executor.rs:16:2
[INFO] [stderr]    |
[INFO] [stderr] 14 | pub struct Executor {
[INFO] [stderr]    |            -------- field in this struct
[INFO] [stderr] 15 |     background_processes: HashMap<u32, Child>,
[INFO] [stderr] 16 |     interrupt_flag: Arc<AtomicBool>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `cleanup_background_processes` is never used
[INFO] [stderr]    --> src/core/executor.rs:261:15
[INFO] [stderr]     |
[INFO] [stderr]  19 | impl Executor {
[INFO] [stderr]     | ------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 261 |     pub async fn cleanup_background_processes(&mut self) -> Result<()> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `get_entries`, `search`, and `clear` are never used
[INFO] [stderr]   --> src/core/history.rs:61:12
[INFO] [stderr]    |
[INFO] [stderr] 14 | impl History {
[INFO] [stderr]    | ------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 61 |     pub fn get_entries(&self) -> &VecDeque<String> {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 65 |     pub fn search(&self, pattern: &str) -> Vec<String> {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 74 |     pub fn clear(&mut self) -> Result<()> {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `print_success`, `print_warning`, `colorize_prompt`, and `colorize_output` are never used
[INFO] [stderr]    --> src/terminal/mod.rs:46:18
[INFO] [stderr]     |
[INFO] [stderr]  13 | impl Terminal {
[INFO] [stderr]     | ------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  46 |     pub async fn print_success(&self, message: &str) -> Result<()> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  55 |     pub async fn print_warning(&self, message: &str) -> Result<()> {
[INFO] [stderr]     |                  ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  64 |     pub fn colorize_prompt(&self, prompt: &str) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 125 |     pub fn colorize_output(&self, text: &str, color_type: OutputColorType) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `OutputColorType` is never used
[INFO] [stderr]    --> src/terminal/mod.rs:144:10
[INFO] [stderr]     |
[INFO] [stderr] 144 | pub enum OutputColorType {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ColorScheme` is never constructed
[INFO] [stderr]  --> src/terminal/colors.rs:4:12
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub struct ColorScheme {
[INFO] [stderr]   |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `default_scheme`, `dark_scheme`, `light_scheme`, `monokai_scheme`, `get_color`, and `get_available_schemes` are never used
[INFO] [stderr]   --> src/terminal/colors.rs:10:12
[INFO] [stderr]    |
[INFO] [stderr]  9 | impl ColorScheme {
[INFO] [stderr]    | ---------------- associated items in this implementation
[INFO] [stderr] 10 |     pub fn default_scheme() -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 31 |     pub fn dark_scheme() -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 52 |     pub fn light_scheme() -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 73 |     pub fn monokai_scheme() -> Self {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 94 |     pub fn get_color(&self, key: &str) -> Option<&String> {
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 98 |     pub fn get_available_schemes() -> Vec<ColorScheme> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `TerminalEvent` is never used
[INFO] [stderr]  --> src/terminal/events.rs:4:10
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub enum TerminalEvent {
[INFO] [stderr]   |          ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/terminal/events.rs:27:12
[INFO] [stderr]     |
[INFO] [stderr]  26 | impl TerminalEvent {
[INFO] [stderr]     | ------------------ methods in this implementation
[INFO] [stderr]  27 |     pub fn is_key(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  31 |     pub fn is_mouse(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  35 |     pub fn is_resize(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  39 |     pub fn is_ctrl_c(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  52 |     pub fn is_ctrl_d(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  65 |     pub fn is_enter(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  75 |     pub fn is_tab(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  85 |     pub fn is_backspace(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  95 |     pub fn is_delete(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 105 |     pub fn is_arrow_up(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 115 |     pub fn is_arrow_down(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 125 |     pub fn is_arrow_left(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 135 |     pub fn is_arrow_right(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 145 |     pub fn get_char(&self) -> Option<char> {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 157 |     pub fn has_ctrl(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 165 |     pub fn has_alt(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 173 |     pub fn has_shift(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `TerminalInterface` is never constructed
[INFO] [stderr]   --> src/terminal/interface.rs:11:12
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub struct TerminalInterface {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/terminal/interface.rs:18:12
[INFO] [stderr]     |
[INFO] [stderr]  17 | impl TerminalInterface {
[INFO] [stderr]     | ---------------------- associated items in this implementation
[INFO] [stderr]  18 |     pub fn new(color_scheme: ColorScheme) -> Result<Self> {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr]  27 |     pub fn update_size(&mut self) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  34 |     pub fn clear_screen(&self) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  39 |     pub fn clear_line(&self) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  44 |     pub fn move_cursor(&self, x: u16, y: u16) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  49 |     pub fn hide_cursor(&self) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  54 |     pub fn show_cursor(&self) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  59 |     pub fn print_colored(&self, text: &str, _color_key: &str) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  65 |     pub fn print_status_line(&self, status: &str) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  76 |     pub fn print_completion_menu(&self, completions: &[String], selected: usize) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  93 |     pub fn get_dimensions(&self) -> (u16, u16) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  97 |     pub fn set_color_scheme(&mut self, scheme: ColorScheme) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 101 |     pub fn draw_border(&self, x: u16, y: u16, width: u16, height: u16, title: Option<&str>) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 132 |     pub fn draw_progress_bar(&self, x: u16, y: u16, width: u16, progress: f32, label: Option<&str>) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `normalize_path` is never used
[INFO] [stderr]   --> src/utils/path.rs:30:8
[INFO] [stderr]    |
[INFO] [stderr] 30 | pub fn normalize_path<P: AsRef<Path>>(path: P) -> PathBuf {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `is_hidden` is never used
[INFO] [stderr]   --> src/utils/path.rs:41:8
[INFO] [stderr]    |
[INFO] [stderr] 41 | pub fn is_hidden<P: AsRef<Path>>(path: P) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_parent_and_name` is never used
[INFO] [stderr]   --> src/utils/path.rs:49:8
[INFO] [stderr]    |
[INFO] [stderr] 49 | pub fn get_parent_and_name<P: AsRef<Path>>(path: P) -> (PathBuf, String) {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CompletionCandidate` is never constructed
[INFO] [stderr]  --> src/utils/completion.rs:8:12
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub struct CompletionCandidate {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `CompletionKind` is never used
[INFO] [stderr]   --> src/utils/completion.rs:16:10
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub enum CompletionKind {
[INFO] [stderr]    |          ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CompletionEngine` is never constructed
[INFO] [stderr]   --> src/utils/completion.rs:25:12
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub struct CompletionEngine {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/utils/completion.rs:31:12
[INFO] [stderr]     |
[INFO] [stderr]  30 | impl CompletionEngine {
[INFO] [stderr]     | --------------------- associated items in this implementation
[INFO] [stderr]  31 |     pub fn new(show_hidden: bool, case_sensitive: bool) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr]  38 |     pub fn complete(&self, input: &str, cursor_pos: usize) -> Vec<CompletionCandidate> {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  50 |     fn extract_word_at_cursor(&self, input: &str, cursor_pos: usize) -> (String, usize) {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  68 |     fn complete_commands(&self, prefix: &str) -> Vec<CompletionCandidate> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 125 |     fn complete_paths(&self, prefix: &str) -> Vec<CompletionCandidate> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 186 |     fn matches_prefix(&self, candidate: &str, prefix: &str) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 198 |     fn is_executable(&self, path: &Path) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `expand_glob` is never used
[INFO] [stderr]  --> src/utils/glob_expand.rs:5:8
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub fn expand_glob(pattern: &str) -> Result<Vec<PathBuf>> {
[INFO] [stderr]   |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `has_glob_chars` is never used
[INFO] [stderr]   --> src/utils/glob_expand.rs:23:8
[INFO] [stderr]    |
[INFO] [stderr] 23 | pub fn has_glob_chars(pattern: &str) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `expand_args` is never used
[INFO] [stderr]   --> src/utils/glob_expand.rs:27:8
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub fn expand_args(args: &[String]) -> Result<Vec<String>> {
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `flex-sh` (bin "flex-sh") generated 37 warnings (run `cargo fix --bin "flex-sh" -p flex-sh` to apply 11 suggestions)
[INFO] [stderr] warning: methods `get_entries` and `clear` are never used
[INFO] [stderr]   --> src/core/history.rs:61:12
[INFO] [stderr]    |
[INFO] [stderr] 14 | impl History {
[INFO] [stderr]    | ------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 61 |     pub fn get_entries(&self) -> &VecDeque<String> {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 74 |     pub fn clear(&mut self) -> Result<()> {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]  --> src/terminal/events.rs:6:11
[INFO] [stderr]   |
[INFO] [stderr] 6 |     Mouse(MouseEvent),
[INFO] [stderr]   |     ----- ^^^^^^^^^^
[INFO] [stderr]   |     |
[INFO] [stderr]   |     field in this variant
[INFO] [stderr]   |
[INFO] [stderr]   = note: `TerminalEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]   |
[INFO] [stderr] 6 -     Mouse(MouseEvent),
[INFO] [stderr] 6 +     Mouse(()),
[INFO] [stderr]   |
[INFO] [stderr] 
[INFO] [stderr] warning: fields `0` and `1` are never read
[INFO] [stderr]  --> src/terminal/events.rs:7:12
[INFO] [stderr]   |
[INFO] [stderr] 7 |     Resize(u16, u16),
[INFO] [stderr]   |     ------ ^^^  ^^^
[INFO] [stderr]   |     |
[INFO] [stderr]   |     fields in this variant
[INFO] [stderr]   |
[INFO] [stderr]   = note: `TerminalEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the fields to be of unit type to suppress this warning while preserving the field numbering, or remove the fields
[INFO] [stderr]   |
[INFO] [stderr] 7 -     Resize(u16, u16),
[INFO] [stderr] 7 +     Resize((), ()),
[INFO] [stderr]   |
[INFO] [stderr] 
[INFO] [stderr] warning: field `0` is never read
[INFO] [stderr]   --> src/terminal/events.rs:10:11
[INFO] [stderr]    |
[INFO] [stderr] 10 |     Paste(String),
[INFO] [stderr]    |     ----- ^^^^^^
[INFO] [stderr]    |     |
[INFO] [stderr]    |     field in this variant
[INFO] [stderr]    |
[INFO] [stderr]    = note: `TerminalEvent` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stderr]    |
[INFO] [stderr] 10 -     Paste(String),
[INFO] [stderr] 10 +     Paste(()),
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/terminal/events.rs:27:12
[INFO] [stderr]     |
[INFO] [stderr]  26 | impl TerminalEvent {
[INFO] [stderr]     | ------------------ methods in this implementation
[INFO] [stderr]  27 |     pub fn is_key(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  31 |     pub fn is_mouse(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  35 |     pub fn is_resize(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  52 |     pub fn is_ctrl_d(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  75 |     pub fn is_tab(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  85 |     pub fn is_backspace(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  95 |     pub fn is_delete(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 105 |     pub fn is_arrow_up(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 115 |     pub fn is_arrow_down(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 125 |     pub fn is_arrow_left(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 135 |     pub fn is_arrow_right(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `color_scheme` is never read
[INFO] [stderr]   --> src/terminal/interface.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub struct TerminalInterface {
[INFO] [stderr]    |            ----------------- field in this struct
[INFO] [stderr] 12 |     color_scheme: ColorScheme,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/terminal/interface.rs:27:12
[INFO] [stderr]     |
[INFO] [stderr]  17 | impl TerminalInterface {
[INFO] [stderr]     | ---------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  27 |     pub fn update_size(&mut self) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  34 |     pub fn clear_screen(&self) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  39 |     pub fn clear_line(&self) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  44 |     pub fn move_cursor(&self, x: u16, y: u16) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  49 |     pub fn hide_cursor(&self) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  54 |     pub fn show_cursor(&self) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  59 |     pub fn print_colored(&self, text: &str, _color_key: &str) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  65 |     pub fn print_status_line(&self, status: &str) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  76 |     pub fn print_completion_menu(&self, completions: &[String], selected: usize) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  97 |     pub fn set_color_scheme(&mut self, scheme: ColorScheme) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 101 |     pub fn draw_border(&self, x: u16, y: u16, width: u16, height: u16, title: Option<&str>) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 132 |     pub fn draw_progress_bar(&self, x: u16, y: u16, width: u16, progress: f32, label: Option<&str>) -> Result<()> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `display` and `description` are never read
[INFO] [stderr]   --> src/utils/completion.rs:10:9
[INFO] [stderr]    |
[INFO] [stderr]  8 | pub struct CompletionCandidate {
[INFO] [stderr]    |            ------------------- fields in this struct
[INFO] [stderr]  9 |     pub text: String,
[INFO] [stderr] 10 |     pub display: String,
[INFO] [stderr]    |         ^^^^^^^
[INFO] [stderr] 11 |     pub kind: CompletionKind,
[INFO] [stderr] 12 |     pub description: Option<String>,
[INFO] [stderr]    |         ^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `CompletionCandidate` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variants `File`, `Directory`, `Variable`, and `Alias` are never constructed
[INFO] [stderr]   --> src/utils/completion.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub enum CompletionKind {
[INFO] [stderr]    |          -------------- variants in this enum
[INFO] [stderr] 17 |     Command,
[INFO] [stderr] 18 |     File,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 19 |     Directory,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 20 |     Builtin,
[INFO] [stderr] 21 |     Variable,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 22 |     Alias,
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `CompletionKind` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `show_hidden` is never read
[INFO] [stderr]   --> src/utils/completion.rs:26:5
[INFO] [stderr]    |
[INFO] [stderr] 25 | pub struct CompletionEngine {
[INFO] [stderr]    |            ---------------- field in this struct
[INFO] [stderr] 26 |     show_hidden: bool,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `complete` and `complete_paths` are never used
[INFO] [stderr]    --> src/utils/completion.rs:38:12
[INFO] [stderr]     |
[INFO] [stderr]  30 | impl CompletionEngine {
[INFO] [stderr]     | --------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  38 |     pub fn complete(&self, input: &str, cursor_pos: usize) -> Vec<CompletionCandidate> {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 125 |     fn complete_paths(&self, prefix: &str) -> Vec<CompletionCandidate> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `flex-sh` (bin "flex-sh" test) generated 32 warnings (21 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.33s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/build/flex-sh/0e61df32deb65b2c/deps/flex_sh-0e61df32deb65b2c)
[INFO] [stdout] 
[INFO] [stdout] running 27 tests
[INFO] [stdout] test core::history::tests::test_ignore_space_prefixed ... ok
[INFO] [stdout] test core::parser::tests::test_environment_variables ... ok
[INFO] [stdout] test core::parser::tests::test_redirection ... ok
[INFO] [stdout] test core::parser::tests::test_simple_command ... ok
[INFO] [stdout] test terminal::colors::tests::test_available_schemes ... ok
[INFO] [stdout] test core::parser::tests::test_background ... ok
[INFO] [stdout] test core::history::tests::test_add_command ... ok
[INFO] [stdout] test terminal::events::tests::test_char_extraction ... ok
[INFO] [stdout] test terminal::colors::tests::test_get_color ... ok
[INFO] [stdout] test terminal::colors::tests::test_default_scheme ... ok
[INFO] [stdout] test core::history::tests::test_ignore_duplicates ... ok
[INFO] [stdout] test terminal::events::tests::test_enter_detection ... ok
[INFO] [stdout] test terminal::events::tests::test_ctrl_c_detection ... ok
[INFO] [stdout] test terminal::events::tests::test_modifier_detection ... ok
[INFO] [stdout] test core::history::tests::test_max_entries ... ok
[INFO] [stdout] test utils::completion::tests::test_matches_prefix ... ok
[INFO] [stdout] test utils::glob_expand::tests::test_has_glob_chars ... ok
[INFO] [stdout] test utils::glob_expand::tests::test_expand_args ... ok
[INFO] [stdout] test utils::path::tests::test_expand_tilde ... ok
[INFO] [stdout] test core::parser::tests::test_quoted_arguments ... ok
[INFO] [stdout] test core::history::tests::test_search ... ok
[INFO] [stdout] test utils::completion::tests::test_extract_word_at_cursor ... ok
[INFO] [stdout] test utils::path::tests::test_is_hidden ... ok
[INFO] [stdout] test utils::completion::tests::test_complete_commands ... ok
[INFO] [stdout] test utils::path::tests::test_get_parent_and_name ... FAILED
[INFO] [stdout] test terminal::interface::tests::test_dimensions ... ok
[INFO] [stdout] test terminal::interface::tests::test_terminal_interface_creation ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- utils::path::tests::test_get_parent_and_name stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'utils::path::tests::test_get_parent_and_name' (52) panicked at src/utils/path.rs:87:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: ""
[INFO] [stdout]  right: "."
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5951f06b40d2 - std[840933623431fd06]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5951f06b40d2 - std[840933623431fd06]::backtrace_rs::backtrace::trace_unsynchronized::<std[840933623431fd06]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5951f06b40d2 - std[840933623431fd06]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5951f06b40d2 - <<std[840933623431fd06]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[8f93d80df273fe75]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5951f06ca07a - <core[8f93d80df273fe75]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5951f06ca07a - core[8f93d80df273fe75]::fmt::write
[INFO] [stdout]    6:     0x5951f06b97b6 - std[840933623431fd06]::io::default_write_fmt::<alloc[40b2bae28975ac47]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5951f06b97b6 - <alloc[40b2bae28975ac47]::vec::Vec<u8> as std[840933623431fd06]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5951f0690d6f - <std[840933623431fd06]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5951f0690d6f - std[840933623431fd06]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5951f06ac0c9 - std[840933623431fd06]::panicking::default_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5951f060498e - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x5951f060498e - test[2f1252070343a163]::test_main_with_exit_callback::<test[2f1252070343a163]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5951f06ac282 - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5951f06ac282 - std[840933623431fd06]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5951f0690e28 - std[840933623431fd06]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x5951f06880f9 - std[840933623431fd06]::sys::backtrace::__rust_end_short_backtrace::<std[840933623431fd06]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5951f0691d6d - __rustc[5b4a0c6d8cc4a177]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5951f06ca74c - core[8f93d80df273fe75]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5951f06ca603 - core[8f93d80df273fe75]::panicking::assert_failed_inner
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:439:17
[INFO] [stdout]   20:     0x5951f05dad41 - core[8f93d80df273fe75]::panicking::assert_failed::<std[840933623431fd06]::path::PathBuf, std[840933623431fd06]::path::PathBuf>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x5951f05e84e8 - flex_sh[31e44f2f17a35b4c]::utils::path::tests::test_get_parent_and_name
[INFO] [stdout]                                at /opt/rustwide/workdir/src/utils/path.rs:87:9
[INFO] [stdout]   22:     0x5951f05e7727 - flex_sh[31e44f2f17a35b4c]::utils::path::tests::test_get_parent_and_name::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/utils/path.rs:81:34
[INFO] [stdout]   23:     0x5951f05f1ae6 - <flex_sh[31e44f2f17a35b4c]::utils::path::tests::test_get_parent_and_name::{closure#0} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5951f05f8d3b - <fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x5951f05f8d3b - test[2f1252070343a163]::__rust_begin_short_backtrace::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x5951f060559a - test[2f1252070343a163]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x5951f060559a - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x5951f060559a - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   29:     0x5951f060559a - std[840933623431fd06]::panicking::catch_unwind::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   30:     0x5951f060559a - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x5951f060559a - test[2f1252070343a163]::run_test_in_process
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x5951f060559a - test[2f1252070343a163]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x5951f05ffa64 - test[2f1252070343a163]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x5951f05ffa64 - std[840933623431fd06]::sys::backtrace::__rust_begin_short_backtrace::<test[2f1252070343a163]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   35:     0x5951f0608092 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   36:     0x5951f0608092 - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x5951f0608092 - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   38:     0x5951f0608092 - std[840933623431fd06]::panicking::catch_unwind::<(), core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   39:     0x5951f0608092 - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x5951f0608092 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   41:     0x5951f0608092 - <std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x5951f06b397f - <alloc[40b2bae28975ac47]::boxed::Box<dyn core[8f93d80df273fe75]::ops::function::FnOnce<(), Output = ()> + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   43:     0x5951f06b397f - <std[840933623431fd06]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   44:     0x727b1ab33aa4 - <unknown>
[INFO] [stdout]   45:     0x727b1abc0a64 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- terminal::interface::tests::test_terminal_interface_creation stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'terminal::interface::tests::test_terminal_interface_creation' (44) panicked at src/terminal/interface.rs:159:9:
[INFO] [stdout] assertion failed: interface.is_ok()
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5951f06b40d2 - std[840933623431fd06]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5951f06b40d2 - std[840933623431fd06]::backtrace_rs::backtrace::trace_unsynchronized::<std[840933623431fd06]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5951f06b40d2 - std[840933623431fd06]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x5951f06b40d2 - <<std[840933623431fd06]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[8f93d80df273fe75]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5951f06ca07a - <core[8f93d80df273fe75]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5951f06ca07a - core[8f93d80df273fe75]::fmt::write
[INFO] [stdout]    6:     0x5951f06b97b6 - std[840933623431fd06]::io::default_write_fmt::<alloc[40b2bae28975ac47]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5951f06b97b6 - <alloc[40b2bae28975ac47]::vec::Vec<u8> as std[840933623431fd06]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x5951f0690d6f - <std[840933623431fd06]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x5951f0690d6f - std[840933623431fd06]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x5951f06ac0c9 - std[840933623431fd06]::panicking::default_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x5951f060498e - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x5951f060498e - test[2f1252070343a163]::test_main_with_exit_callback::<test[2f1252070343a163]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5951f06ac282 - <alloc[40b2bae28975ac47]::boxed::Box<dyn for<'a, 'b> core[8f93d80df273fe75]::ops::function::Fn<(&'a std[840933623431fd06]::panic::PanicHookInfo<'b>,), Output = ()> + core[8f93d80df273fe75]::marker::Sync + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::Fn<(&std[840933623431fd06]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x5951f06ac282 - std[840933623431fd06]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x5951f0690e5a - std[840933623431fd06]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x5951f06880f9 - std[840933623431fd06]::sys::backtrace::__rust_end_short_backtrace::<std[840933623431fd06]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x5951f0691d6d - __rustc[5b4a0c6d8cc4a177]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5951f06ca74c - core[8f93d80df273fe75]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5951f06ca712 - core[8f93d80df273fe75]::panicking::panic
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panicking.rs:150:5
[INFO] [stdout]   20:     0x5951f05e0171 - flex_sh[31e44f2f17a35b4c]::terminal::interface::tests::test_terminal_interface_creation
[INFO] [stdout]                                at /opt/rustwide/workdir/src/terminal/interface.rs:159:9
[INFO] [stdout]   21:     0x5951f05dbff7 - flex_sh[31e44f2f17a35b4c]::terminal::interface::tests::test_terminal_interface_creation::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/terminal/interface.rs:156:42
[INFO] [stdout]   22:     0x5951f05f1d26 - <flex_sh[31e44f2f17a35b4c]::terminal::interface::tests::test_terminal_interface_creation::{closure#0} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x5951f05f8d3b - <fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5951f05f8d3b - test[2f1252070343a163]::__rust_begin_short_backtrace::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, fn() -> core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x5951f060559a - test[2f1252070343a163]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x5951f060559a - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x5951f060559a - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x5951f060559a - std[840933623431fd06]::panicking::catch_unwind::<core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>, core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x5951f060559a - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<test[2f1252070343a163]::run_test_in_process::{closure#0}>, core[8f93d80df273fe75]::result::Result<(), alloc[40b2bae28975ac47]::string::String>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x5951f060559a - test[2f1252070343a163]::run_test_in_process
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x5951f060559a - test[2f1252070343a163]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x5951f05ffa64 - test[2f1252070343a163]::run_test::{closure#1}
[INFO] [stderr] error: test failed, to rerun pass `--bin flex-sh`
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x5951f05ffa64 - std[840933623431fd06]::sys::backtrace::__rust_begin_short_backtrace::<test[2f1252070343a163]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x5951f0608092 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x5951f0608092 - <core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x5951f0608092 - std[840933623431fd06]::panicking::catch_unwind::do_call::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x5951f0608092 - std[840933623431fd06]::panicking::catch_unwind::<(), core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x5951f0608092 - std[840933623431fd06]::panic::catch_unwind::<core[8f93d80df273fe75]::panic::unwind_safe::AssertUnwindSafe<std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x5951f0608092 - std[840933623431fd06]::thread::lifecycle::spawn_unchecked::<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x5951f0608092 - <std[840933623431fd06]::thread::lifecycle::spawn_unchecked<test[2f1252070343a163]::run_test::{closure#1}, ()>::{closure#1} as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x5951f06b397f - <alloc[40b2bae28975ac47]::boxed::Box<dyn core[8f93d80df273fe75]::ops::function::FnOnce<(), Output = ()> + core[8f93d80df273fe75]::marker::Send> as core[8f93d80df273fe75]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x5951f06b397f - <std[840933623431fd06]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/bd7d74411512a3dd3b35d2f699c51dd2557c7e7e/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   43:     0x727b1ab33aa4 - <unknown>
[INFO] [stdout]   44:     0x727b1abc0a64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     terminal::interface::tests::test_terminal_interface_creation
[INFO] [stdout]     utils::path::tests::test_get_parent_and_name
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 25 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.12s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "01ded7851068ab2ce0716237c127421097472b71d42cd3c161e09a4ecb874a71", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "01ded7851068ab2ce0716237c127421097472b71d42cd3c161e09a4ecb874a71", kill_on_drop: false }`
[INFO] [stdout] 01ded7851068ab2ce0716237c127421097472b71d42cd3c161e09a4ecb874a71
