[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 1.90.0 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftristanpoland%2FFlex-SH" "/workspace/builds/worker-5-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc1/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-5-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/tristanpoland/Flex-SH on toolchain 1.90.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "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" "+1.90.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded toml_parser v1.0.2
[INFO] [stderr]   Downloaded serde_spanned v1.0.0
[INFO] [stderr]   Downloaded serde v1.0.221
[INFO] [stderr]   Downloaded toml_writer v1.0.2
[INFO] [stderr]   Downloaded toml v0.9.5
[INFO] [stderr]   Downloaded subprocess v0.2.9
[INFO] [stderr]   Downloaded redox_users v0.5.2
[INFO] [stderr]   Downloaded rustyline-derive v0.10.0
[INFO] [stderr]   Downloaded serde_core v1.0.221
[INFO] [stderr]   Downloaded serde_derive v1.0.221
[INFO] [stderr]   Downloaded serde_json v1.0.144
[INFO] [stderr]   Downloaded cc v1.2.37
[INFO] [stderr]   Downloaded rustyline v17.0.1
[INFO] [stderr]   Downloaded toml_datetime v0.7.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 89dc4a1d4bd6a3272e8c8fc20ead0b37bc0f68bf0e60f3f45e62d1ca25ac3b4c
[INFO] running `Command { std: "docker" "start" "-a" "89dc4a1d4bd6a3272e8c8fc20ead0b37bc0f68bf0e60f3f45e62d1ca25ac3b4c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "89dc4a1d4bd6a3272e8c8fc20ead0b37bc0f68bf0e60f3f45e62d1ca25ac3b4c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "89dc4a1d4bd6a3272e8c8fc20ead0b37bc0f68bf0e60f3f45e62d1ca25ac3b4c", kill_on_drop: false }`
[INFO] [stdout] 89dc4a1d4bd6a3272e8c8fc20ead0b37bc0f68bf0e60f3f45e62d1ca25ac3b4c
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 4c0dce8f792ce526b16d1374ba59d4a3e56e70f511ff073b48586c286d23cde3
[INFO] running `Command { std: "docker" "start" "-a" "4c0dce8f792ce526b16d1374ba59d4a3e56e70f511ff073b48586c286d23cde3", kill_on_drop: false }`
[INFO] [stderr]    Compiling unicode-ident v1.0.19
[INFO] [stderr]    Compiling libc v0.2.175
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling serde_core v1.0.221
[INFO] [stderr]    Compiling cfg-if v1.0.3
[INFO] [stderr]    Compiling bitflags v2.9.4
[INFO] [stderr]    Compiling log v0.4.28
[INFO] [stderr]    Compiling memchr v2.7.5
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling serde v1.0.221
[INFO] [stderr]    Compiling rustix v1.1.2
[INFO] [stderr]    Compiling linux-raw-sys v0.11.0
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling nix v0.30.1
[INFO] [stderr]    Compiling anstyle-parse v0.2.7
[INFO] [stderr]    Compiling colorchoice v1.0.4
[INFO] [stderr]    Compiling regex-syntax v0.8.6
[INFO] [stderr]    Compiling proc-macro2 v1.0.101
[INFO] [stderr]    Compiling anstyle-query v1.1.4
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling anstyle v1.0.11
[INFO] [stderr]    Compiling convert_case v0.7.1
[INFO] [stderr]    Compiling anstream v0.6.20
[INFO] [stderr]    Compiling winnow v0.7.13
[INFO] [stderr]    Compiling serde_json v1.0.144
[INFO] [stderr]    Compiling nibble_vec v0.1.0
[INFO] [stderr]    Compiling option-ext v0.2.0
[INFO] [stderr]    Compiling litrs v0.4.2
[INFO] [stderr]    Compiling clap_lex v0.7.5
[INFO] [stderr]    Compiling endian-type v0.1.2
[INFO] [stderr]    Compiling anyhow v1.0.99
[INFO] [stderr]    Compiling thiserror v2.0.16
[INFO] [stderr]    Compiling radix_trie v0.2.1
[INFO] [stderr]    Compiling unicode-width v0.2.1
[INFO] [stderr]    Compiling toml_writer v1.0.2
[INFO] [stderr]    Compiling jiff v0.2.15
[INFO] [stderr]    Compiling clap_builder v4.5.47
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling iana-time-zone v0.1.64
[INFO] [stderr]    Compiling home v0.5.11
[INFO] [stderr]    Compiling lock_api v0.4.13
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling document-features v0.2.11
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling colored v3.0.0
[INFO] [stderr]    Compiling glob v0.3.3
[INFO] [stderr]    Compiling regex-automata v0.4.10
[INFO] [stderr]    Compiling signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling socket2 v0.6.0
[INFO] [stderr]    Compiling dirs-sys v0.5.0
[INFO] [stderr]    Compiling subprocess v0.2.9
[INFO] [stderr]    Compiling parking_lot v0.12.4
[INFO] [stderr]    Compiling signal-hook-mio v0.2.4
[INFO] [stderr]    Compiling toml_parser v1.0.2
[INFO] [stderr]    Compiling dirs v6.0.0
[INFO] [stderr]    Compiling fd-lock v4.0.4
[INFO] [stderr]    Compiling gethostname v1.0.2
[INFO] [stderr]    Compiling ctrlc v3.5.0
[INFO] [stderr]    Compiling rustyline v17.0.1
[INFO] [stderr]    Compiling regex v1.11.2
[INFO] [stderr]    Compiling env_filter v0.1.3
[INFO] [stderr]    Compiling serde_derive v1.0.221
[INFO] [stderr]    Compiling derive_more-impl v2.0.1
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling thiserror-impl v2.0.16
[INFO] [stderr]    Compiling clap_derive v4.5.47
[INFO] [stderr]    Compiling rustyline-derive v0.10.0
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling tokio v1.47.1
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling derive_more v2.0.1
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling clap v4.5.47
[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)]` 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)]` 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)]` 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)]` 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 33.61s
[INFO] running `Command { std: "docker" "inspect" "4c0dce8f792ce526b16d1374ba59d4a3e56e70f511ff073b48586c286d23cde3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4c0dce8f792ce526b16d1374ba59d4a3e56e70f511ff073b48586c286d23cde3", kill_on_drop: false }`
[INFO] [stdout] 4c0dce8f792ce526b16d1374ba59d4a3e56e70f511ff073b48586c286d23cde3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 67a40055add72161a203feb34a6ef0f89777b1278d1b8b04f9c1ea118208e94a
[INFO] running `Command { std: "docker" "start" "-a" "67a40055add72161a203feb34a6ef0f89777b1278d1b8b04f9c1ea118208e94a", kill_on_drop: false }`
[INFO] [stderr]    Compiling regex-syntax v0.8.6
[INFO] [stderr]    Compiling doc-comment v0.3.3
[INFO] [stderr]    Compiling predicates-core v1.0.9
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling float-cmp v0.10.0
[INFO] [stderr]    Compiling normalize-line-endings v0.3.0
[INFO] [stderr]    Compiling termtree v0.5.1
[INFO] [stderr]    Compiling assert_cmd v2.0.17
[INFO] [stderr]    Compiling difflib v0.4.0
[INFO] [stderr]    Compiling wait-timeout v0.2.1
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling predicates-tree v1.0.12
[INFO] [stderr]    Compiling tempfile v3.22.0
[INFO] [stderr]    Compiling regex-automata v0.4.10
[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)]` 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)]` 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)]` 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)]` 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)]` 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)]` 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)]` 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)]` 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 12.10s
[INFO] running `Command { std: "docker" "inspect" "67a40055add72161a203feb34a6ef0f89777b1278d1b8b04f9c1ea118208e94a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "67a40055add72161a203feb34a6ef0f89777b1278d1b8b04f9c1ea118208e94a", kill_on_drop: false }`
[INFO] [stdout] 67a40055add72161a203feb34a6ef0f89777b1278d1b8b04f9c1ea118208e94a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 0cee84789bc240a9bae9cd980b9df3fcac45dbbc54e4f6f9514bd3405ee3dda5
[INFO] running `Command { std: "docker" "start" "-a" "0cee84789bc240a9bae9cd980b9df3fcac45dbbc54e4f6f9514bd3405ee3dda5", 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)]` 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)]` 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)]` 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)]` 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` 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: 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: 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: 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: 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 (run `cargo fix --bin "flex-sh" --tests` to apply 9 suggestions)
[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: 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 `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 (21 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.16s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/flex_sh-83b1a3b319b12951)
[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_quoted_arguments ... ok
[INFO] [stdout] test core::parser::tests::test_redirection ... ok
[INFO] [stdout] test core::parser::tests::test_environment_variables ... ok
[INFO] [stdout] test core::parser::tests::test_simple_command ... ok
[INFO] [stdout] test terminal::colors::tests::test_get_color ... ok
[INFO] [stdout] test terminal::colors::tests::test_available_schemes ... ok
[INFO] [stdout] test terminal::colors::tests::test_default_scheme ... ok
[INFO] [stdout] test terminal::events::tests::test_ctrl_c_detection ... ok
[INFO] [stdout] test terminal::events::tests::test_char_extraction ... ok
[INFO] [stdout] test terminal::events::tests::test_enter_detection ... ok
[INFO] [stdout] test terminal::events::tests::test_modifier_detection ... ok
[INFO] [stdout] test core::parser::tests::test_background ... ok
[INFO] [stdout] test core::history::tests::test_ignore_duplicates ... ok
[INFO] [stdout] test utils::completion::tests::test_extract_word_at_cursor ... ok
[INFO] [stdout] test core::history::tests::test_max_entries ... ok
[INFO] [stdout] test utils::glob_expand::tests::test_expand_args ... ok
[INFO] [stdout] test core::history::tests::test_add_command ... ok
[INFO] [stdout] test utils::glob_expand::tests::test_has_glob_chars ... ok
[INFO] [stdout] test utils::path::tests::test_expand_tilde ... ok
[INFO] [stdout] test utils::path::tests::test_is_hidden ... ok
[INFO] [stdout] test utils::completion::tests::test_matches_prefix ... ok
[INFO] [stdout] test utils::completion::tests::test_complete_commands ... ok
[INFO] [stdout] test core::history::tests::test_search ... ok
[INFO] [stdout] test terminal::interface::tests::test_terminal_interface_creation ... FAILED
[INFO] [stdout] test terminal::interface::tests::test_dimensions ... ok
[INFO] [stdout] test utils::path::tests::test_get_parent_and_name ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- terminal::interface::tests::test_terminal_interface_creation stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'terminal::interface::tests::test_terminal_interface_creation' panicked at src/terminal/interface.rs:159:9:
[INFO] [stdout] assertion failed: interface.is_ok()
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x6010f15d33f2 - std::backtrace_rs::backtrace::libunwind::trace::h2d45396358f41939
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x6010f15d33f2 - std::backtrace_rs::backtrace::trace_unsynchronized::hffcefc0b67f1d6e2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x6010f15d33f2 - std::sys::backtrace::_print_fmt::hd72f71d23b436b92
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x6010f15d33f2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::hdcfcb6d4c8489523
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x6010f15fa043 - core::fmt::rt::Argument::fmt::h2c56b3114963061a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x6010f15fa043 - core::fmt::write::h8a494366950f23bb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x6010f15cfda3 - std::io::default_write_fmt::h7b8824096454f323
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x6010f15cfda3 - std::io::Write::write_fmt::h4e71294925c334d0
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x6010f15d3242 - std::sys::backtrace::BacktraceLock::print::hb2a626a81e06b2dc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x6010f15d4cb9 - std::panicking::default_hook::{{closure}}::h4f78485264f12d10
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x6010f15d4aee - std::panicking::default_hook::h2c66fc99e962531d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x6010f1559234 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hb6bd65493727d71a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x6010f1559234 - test::test_main_with_exit_callback::{{closure}}::h60217ec76a0ece4a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x6010f15d578e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h318e4efb8c1a5689
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x6010f15d578e - std::panicking::rust_panic_with_hook::h33ac55f64bbd807d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x6010f15d5426 - std::panicking::begin_panic_handler::{{closure}}::h30e7cb89678a57fe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:699:13
[INFO] [stdout]   16:     0x6010f15d38f9 - std::sys::backtrace::__rust_end_short_backtrace::hed60f27456c16ced
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x6010f15d50ed - __rustc[de2ca18b4c54d5b8]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x6010f15f8a90 - core::panicking::panic_fmt::h62f63d096dd276af
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x6010f15f8b1c - core::panicking::panic::h89a5f2df32b0508a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:145:5
[INFO] [stdout]   20:     0x6010f1509122 - flex_sh::terminal::interface::tests::test_terminal_interface_creation::hc32cf32779b365a8
[INFO] [stdout]                                at /opt/rustwide/workdir/src/terminal/interface.rs:159:9
[INFO] [stdout]   21:     0x6010f1509087 - flex_sh::terminal::interface::tests::test_terminal_interface_creation::{{closure}}::h866d210f9fee63ac
[INFO] [stdout]                                at /opt/rustwide/workdir/src/terminal/interface.rs:156:42
[INFO] [stdout]   22:     0x6010f14f6ae6 - core::ops::function::FnOnce::call_once::hb9707ac044ee5450
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   23:     0x6010f155ea9b - core::ops::function::FnOnce::call_once::h1f9474f1347fff52
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   24:     0x6010f155ea9b - test::__rust_begin_short_backtrace::ha52ab26e77157f03
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:648:18
[INFO] [stdout]   25:     0x6010f155dbd5 - test::run_test_in_process::{{closure}}::h229c1a11a50b261f
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:74
[INFO] [stdout]   26:     0x6010f155dbd5 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h78821afbf97b39a9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   27:     0x6010f155dbd5 - std::panicking::catch_unwind::do_call::h53abf3ed5bd32ba3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   28:     0x6010f155dbd5 - std::panicking::catch_unwind::h6deb5fe1e91873c9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   29:     0x6010f155dbd5 - std::panic::catch_unwind::hea0829b6b565654b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x6010f155dbd5 - test::run_test_in_process::hdc44dfecea3db21b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:27
[INFO] [stdout]   31:     0x6010f155dbd5 - test::run_test::{{closure}}::h0364ba59bf23f652
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:592:43
[INFO] [stdout]   32:     0x6010f15217d4 - test::run_test::{{closure}}::h32730b304eec05da
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:622:41
[INFO] [stdout]   33:     0x6010f15217d4 - std::sys::backtrace::__rust_begin_short_backtrace::h177cb952fc54ad2c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   34:     0x6010f15251aa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h119d903520007597
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   35:     0x6010f15251aa - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hab88401d606702a6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   36:     0x6010f15251aa - std::panicking::catch_unwind::do_call::h163fe12cca9901c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   37:     0x6010f15251aa - std::panicking::catch_unwind::he81557d0e17cc1bc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   38:     0x6010f15251aa - std::panic::catch_unwind::hc2b8e79c20593955
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x6010f15251aa - std::thread::Builder::spawn_unchecked_::{{closure}}::hfa6b4978e07815cc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   40:     0x6010f15251aa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hddcd7484a13fd793
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   41:     0x6010f15d89bf - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h5924238c754de3b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   42:     0x6010f15d89bf - std::sys::pal::unix::thread::Thread::new::thread_start::hb6e99e73da4d28f8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/pal/unix/thread.rs:107:17
[INFO] [stdout]   43:     0x7dd87362aaa4 - <unknown>
[INFO] [stdout]   44:     0x7dd8736b7a34 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[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' 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:     0x6010f15d33f2 - std::backtrace_rs::backtrace::libunwind::trace::h2d45396358f41939
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x6010f15d33f2 - std::backtrace_rs::backtrace::trace_unsynchronized::hffcefc0b67f1d6e2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x6010f15d33f2 - std::sys::backtrace::_print_fmt::hd72f71d23b436b92
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x6010f15d33f2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::hdcfcb6d4c8489523
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x6010f15fa043 - core::fmt::rt::Argument::fmt::h2c56b3114963061a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x6010f15fa043 - core::fmt::write::h8a494366950f23bb
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/fmt/mod.rs:1468:25
[INFO] [stdout]    6:     0x6010f15cfda3 - std::io::default_write_fmt::h7b8824096454f323
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x6010f15cfda3 - std::io::Write::write_fmt::h4e71294925c334d0
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x6010f15d3242 - std::sys::backtrace::BacktraceLock::print::hb2a626a81e06b2dc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x6010f15d4cb9 - std::panicking::default_hook::{{closure}}::h4f78485264f12d10
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x6010f15d4aee - std::panicking::default_hook::h2c66fc99e962531d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x6010f1559234 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::hb6bd65493727d71a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x6010f1559234 - test::test_main_with_exit_callback::{{closure}}::h60217ec76a0ece4a
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x6010f15d578e - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h318e4efb8c1a5689
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x6010f15d578e - std::panicking::rust_panic_with_hook::h33ac55f64bbd807d
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x6010f15d545a - std::panicking::begin_panic_handler::{{closure}}::h30e7cb89678a57fe
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:706:13
[INFO] [stdout]   16:     0x6010f15d38f9 - std::sys::backtrace::__rust_end_short_backtrace::hed60f27456c16ced
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:174:18
[INFO] [stdout]   17:     0x6010f15d50ed - __rustc[de2ca18b4c54d5b8]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x6010f15f8a90 - core::panicking::panic_fmt::h62f63d096dd276af
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x6010f15f8de3 - core::panicking::assert_failed_inner::h102b4539a88470c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:448:17
[INFO] [stdout]   20:     0x6010f150488d - core::panicking::assert_failed::hd6073fd344eb98cd
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panicking.rs:403:5
[INFO] [stdout]   21:     0x6010f150997e - flex_sh::utils::path::tests::test_get_parent_and_name::h522675b0b872384a
[INFO] [stdout]                                at /opt/rustwide/workdir/src/utils/path.rs:87:9
[INFO] [stdout]   22:     0x6010f1509697 - flex_sh::utils::path::tests::test_get_parent_and_name::{{closure}}::h7779641a692ef66f
[INFO] [stdout]                                at /opt/rustwide/workdir/src/utils/path.rs:81:34
[INFO] [stdout]   23:     0x6010f14f6736 - core::ops::function::FnOnce::call_once::h5a2d21ba30653830
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   24:     0x6010f155ea9b - core::ops::function::FnOnce::call_once::h1f9474f1347fff52
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   25:     0x6010f155ea9b - test::__rust_begin_short_backtrace::ha52ab26e77157f03
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:648:18
[INFO] [stdout]   26:     0x6010f155dbd5 - test::run_test_in_process::{{closure}}::h229c1a11a50b261f
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:74
[INFO] [stdout]   27:     0x6010f155dbd5 - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h78821afbf97b39a9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   28:     0x6010f155dbd5 - std::panicking::catch_unwind::do_call::h53abf3ed5bd32ba3
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   29:     0x6010f155dbd5 - std::panicking::catch_unwind::h6deb5fe1e91873c9
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   30:     0x6010f155dbd5 - std::panic::catch_unwind::hea0829b6b565654b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x6010f155dbd5 - test::run_test_in_process::hdc44dfecea3db21b
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:671:27
[INFO] [stdout]   32:     0x6010f155dbd5 - test::run_test::{{closure}}::h0364ba59bf23f652
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:592:43
[INFO] [stdout]   33:     0x6010f15217d4 - test::run_test::{{closure}}::h32730b304eec05da
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/test/src/lib.rs:622:41
[INFO] [stdout]   34:     0x6010f15217d4 - std::sys::backtrace::__rust_begin_short_backtrace::h177cb952fc54ad2c
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/backtrace.rs:158:18
[INFO] [stdout]   35:     0x6010f15251aa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h119d903520007597
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   36:     0x6010f15251aa - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::hab88401d606702a6
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   37:     0x6010f15251aa - std::panicking::catch_unwind::do_call::h163fe12cca9901c2
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:589:40
[INFO] [stdout]   38:     0x6010f15251aa - std::panicking::catch_unwind::he81557d0e17cc1bc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panicking.rs:552:19
[INFO] [stdout]   39:     0x6010f15251aa - std::panic::catch_unwind::hc2b8e79c20593955
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x6010f15251aa - std::thread::Builder::spawn_unchecked_::{{closure}}::hfa6b4978e07815cc
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   41:     0x6010f15251aa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hddcd7484a13fd793
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/core/src/ops/function.rs:253:5
[INFO] [stdout]   42:     0x6010f15d89bf - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h5924238c754de3b8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   43:     0x6010f15d89bf - std::sys::pal::unix::thread::Thread::new::thread_start::hb6e99e73da4d28f8
[INFO] [stdout]                                at /rustc/1159e78c4747b02ef996e55082b704c09b970588/library/std/src/sys/pal/unix/thread.rs:107:17
[INFO] [stdout]   44:     0x7dd87362aaa4 - <unknown>
[INFO] [stdout]   45:     0x7dd8736b7a34 - clone
[INFO] [stdout]   46:                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.13s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin flex-sh`
[INFO] running `Command { std: "docker" "inspect" "0cee84789bc240a9bae9cd980b9df3fcac45dbbc54e4f6f9514bd3405ee3dda5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0cee84789bc240a9bae9cd980b9df3fcac45dbbc54e4f6f9514bd3405ee3dda5", kill_on_drop: false }`
[INFO] [stdout] 0cee84789bc240a9bae9cd980b9df3fcac45dbbc54e4f6f9514bd3405ee3dda5
