[INFO] cloning repository https://github.com/tgifriday/ai-os
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/tgifriday/ai-os" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftgifriday%2Fai-os", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftgifriday%2Fai-os'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] bb9e0454fb1dfb19ba9c06ef1db78d365fe23bac
[INFO] checking tgifriday/ai-os against try#c86ec274072509d26d0ee52682a0c94ed012ed89 for pr-153027
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftgifriday%2Fai-os" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/tgifriday/ai-os
[INFO] finished tweaking git repo https://github.com/tgifriday/ai-os
[INFO] tweaked toml for git repo https://github.com/tgifriday/ai-os written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/tgifriday/ai-os on toolchain c86ec274072509d26d0ee52682a0c94ed012ed89
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c86ec274072509d26d0ee52682a0c94ed012ed89" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/tgifriday/ai-os 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" "+c86ec274072509d26d0ee52682a0c94ed012ed89" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: /workspace/builds/worker-7-tc2/source/aios-shell/Cargo.toml: file `/workspace/builds/worker-7-tc2/source/aios-shell/src/main.rs` found to be present in multiple build targets:
[INFO] [stderr]   * `bin` target `aios-shell`
[INFO] [stderr]   * `bin` target `aish`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[ERROR] error running command: no output for 300 seconds
[INFO] checking tgifriday/ai-os against try#c86ec274072509d26d0ee52682a0c94ed012ed89 for pr-153027
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftgifriday%2Fai-os" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/tgifriday/ai-os
[INFO] finished tweaking git repo https://github.com/tgifriday/ai-os
[INFO] tweaked toml for git repo https://github.com/tgifriday/ai-os written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/tgifriday/ai-os on toolchain c86ec274072509d26d0ee52682a0c94ed012ed89
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c86ec274072509d26d0ee52682a0c94ed012ed89" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/tgifriday/ai-os 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" "+c86ec274072509d26d0ee52682a0c94ed012ed89" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: /workspace/builds/worker-7-tc2/source/aios-shell/Cargo.toml: file `/workspace/builds/worker-7-tc2/source/aios-shell/src/main.rs` found to be present in multiple build targets:
[INFO] [stderr]   * `bin` target `aios-shell`
[INFO] [stderr]   * `bin` target `aish`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[ERROR] error running command: no output for 300 seconds
[INFO] checking tgifriday/ai-os against try#c86ec274072509d26d0ee52682a0c94ed012ed89 for pr-153027
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftgifriday%2Fai-os" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/tgifriday/ai-os
[INFO] finished tweaking git repo https://github.com/tgifriday/ai-os
[INFO] tweaked toml for git repo https://github.com/tgifriday/ai-os written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/tgifriday/ai-os on toolchain c86ec274072509d26d0ee52682a0c94ed012ed89
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c86ec274072509d26d0ee52682a0c94ed012ed89" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/tgifriday/ai-os 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" "+c86ec274072509d26d0ee52682a0c94ed012ed89" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: /workspace/builds/worker-7-tc2/source/aios-shell/Cargo.toml: file `/workspace/builds/worker-7-tc2/source/aios-shell/src/main.rs` found to be present in multiple build targets:
[INFO] [stderr]   * `bin` target `aios-shell`
[INFO] [stderr]   * `bin` target `aish`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[ERROR] error running command: no output for 300 seconds
[INFO] checking tgifriday/ai-os against try#c86ec274072509d26d0ee52682a0c94ed012ed89 for pr-153027
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Ftgifriday%2Fai-os" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/tgifriday/ai-os
[INFO] finished tweaking git repo https://github.com/tgifriday/ai-os
[INFO] tweaked toml for git repo https://github.com/tgifriday/ai-os written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/tgifriday/ai-os on toolchain c86ec274072509d26d0ee52682a0c94ed012ed89
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c86ec274072509d26d0ee52682a0c94ed012ed89" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/tgifriday/ai-os 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" "+c86ec274072509d26d0ee52682a0c94ed012ed89" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: /workspace/builds/worker-7-tc2/source/aios-shell/Cargo.toml: file `/workspace/builds/worker-7-tc2/source/aios-shell/src/main.rs` found to be present in multiple build targets:
[INFO] [stderr]   * `bin` target `aios-shell`
[INFO] [stderr]   * `bin` target `aish`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded users v0.11.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+c86ec274072509d26d0ee52682a0c94ed012ed89" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 870554645e4a474150735d1bc42f5bb8d0527f54ea9b14b98ad794a80d83edf4
[INFO] running `Command { std: "docker" "start" "-a" "870554645e4a474150735d1bc42f5bb8d0527f54ea9b14b98ad794a80d83edf4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "870554645e4a474150735d1bc42f5bb8d0527f54ea9b14b98ad794a80d83edf4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "870554645e4a474150735d1bc42f5bb8d0527f54ea9b14b98ad794a80d83edf4", kill_on_drop: false }`
[INFO] [stdout] 870554645e4a474150735d1bc42f5bb8d0527f54ea9b14b98ad794a80d83edf4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+c86ec274072509d26d0ee52682a0c94ed012ed89" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0eaa7128ca3f0a05920808d82d00580216aa34c74cfec4fe94cb48df9f4bddc8
[INFO] running `Command { std: "docker" "start" "-a" "0eaa7128ca3f0a05920808d82d00580216aa34c74cfec4fe94cb48df9f4bddc8", kill_on_drop: false }`
[INFO] [stderr] warning: /opt/rustwide/workdir/aios-shell/Cargo.toml: file `/opt/rustwide/workdir/aios-shell/src/main.rs` found to be present in multiple build targets:
[INFO] [stderr]   * `bin` target `aios-shell`
[INFO] [stderr]   * `bin` target `aish`
[INFO] [stderr]    Compiling libc v0.2.183
[INFO] [stderr]     Checking slab v0.4.12
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]     Checking aho-corasick v1.1.4
[INFO] [stderr]     Checking webpki-roots v1.0.6
[INFO] [stderr]     Checking winnow v0.7.15
[INFO] [stderr]    Compiling nix v0.29.0
[INFO] [stderr]     Checking unsafe-libyaml v0.2.11
[INFO] [stderr]     Checking regex-automata v0.4.14
[INFO] [stderr]     Checking errno v0.3.14
[INFO] [stderr]     Checking mio v1.1.1
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking socket2 v0.6.3
[INFO] [stderr]     Checking getrandom v0.2.17
[INFO] [stderr]     Checking dirs-sys v0.5.0
[INFO] [stderr]     Checking users v0.11.0
[INFO] [stderr]     Checking ring v0.17.14
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking signal-hook-registry v1.4.8
[INFO] [stderr]     Checking dirs v6.0.0
[INFO] [stderr]     Checking signal-hook v0.3.18
[INFO] [stderr]     Checking signal-hook-mio v0.2.5
[INFO] [stderr]     Checking crossterm v0.28.1
[INFO] [stderr]     Checking rustls-webpki v0.103.9
[INFO] [stderr]     Checking rustls v0.23.37
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking regex v1.12.3
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling tokio-macros v2.6.1
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling futures-macro v0.3.32
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]     Checking futures-util v0.3.32
[INFO] [stderr]     Checking async-stream v0.3.6
[INFO] [stderr]     Checking tokio v1.50.0
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]     Checking yoke v0.8.1
[INFO] [stderr]     Checking tracing-subscriber v0.3.22
[INFO] [stderr]     Checking thiserror v2.0.18
[INFO] [stderr]     Checking zerovec v0.11.5
[INFO] [stderr]     Checking zerotrie v0.2.3
[INFO] [stderr]     Checking tinystr v0.8.2
[INFO] [stderr]     Checking potential_utf v0.1.4
[INFO] [stderr]     Checking icu_collections v2.1.1
[INFO] [stderr]     Checking icu_locale_core v2.1.1
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]     Checking icu_properties v2.1.2
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking futures-executor v0.3.32
[INFO] [stderr]     Checking futures v0.3.32
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]     Checking chrono v0.4.44
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking serde_yaml v0.9.34+deprecated
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]     Checking url v2.5.8
[INFO] [stderr]     Checking hyper v1.8.1
[INFO] [stderr]     Checking tokio-rustls v0.26.4
[INFO] [stderr]     Checking tower v0.5.3
[INFO] [stderr]     Checking tokio-util v0.7.18
[INFO] [stderr]     Checking tokio-stream v0.1.18
[INFO] [stderr]     Checking aios-kernel v0.1.5 (/opt/rustwide/workdir/aios-kernel)
[INFO] [stderr]     Checking aios-knowledge v0.1.5 (/opt/rustwide/workdir/aios-knowledge)
[INFO] [stderr]     Checking aios-core v0.1.5 (/opt/rustwide/workdir/aios-core)
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> aios-core/src/commands/cat.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> aios-core/src/commands/mkdir.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> aios-core/src/commands/rm.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> aios-core/src/commands/wc.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking tower-http v0.6.8
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> aios-core/src/commands/cat.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> aios-core/src/commands/mkdir.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> aios-core/src/commands/rm.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]  --> aios-core/src/commands/wc.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::path::Path;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]  --> aios-core/src/commands/env_cmd.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn run(args: &[&str], _cwd: &std::path::Path) -> crate::CommandOutput {
[INFO] [stdout]   |            ^^^^ help: if this is intentional, prefix it with an underscore: `_args`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `args`
[INFO] [stdout]  --> aios-core/src/commands/env_cmd.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn run(args: &[&str], _cwd: &std::path::Path) -> crate::CommandOutput {
[INFO] [stdout]   |            ^^^^ help: if this is intentional, prefix it with an underscore: `_args`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking hyper-util v0.1.20
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking hyper-rustls v0.27.7
[INFO] [stderr]     Checking reqwest v0.12.28
[INFO] [stderr]     Checking aios-llm v0.1.5 (/opt/rustwide/workdir/aios-llm)
[INFO] [stderr]     Checking aios-shell v0.1.5 (/opt/rustwide/workdir/aios-shell)
[INFO] [stderr]     Checking aios-init v0.1.5 (/opt/rustwide/workdir/aios-init)
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> aios-shell/src/executor.rs:4:33
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `aios_core::CommandOutput`
[INFO] [stdout]  --> aios-shell/src/scripting.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use aios_core::CommandOutput;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> aios-shell/src/executor.rs:4:33
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `aios_core::CommandOutput`
[INFO] [stdout]  --> aios-shell/src/scripting.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use aios_core::CommandOutput;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> aios-shell/src/executor.rs:4:33
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `aios_core::CommandOutput`
[INFO] [stdout]  --> aios-shell/src/scripting.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use aios_core::CommandOutput;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> aios-shell/src/executor.rs:4:33
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `aios_core::CommandOutput`
[INFO] [stdout]  --> aios-shell/src/scripting.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use aios_core::CommandOutput;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> aios-shell/src/executor.rs:4:33
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `aios_core::CommandOutput`
[INFO] [stdout]  --> aios-shell/src/scripting.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use aios_core::CommandOutput;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> aios-shell/src/executor.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ----^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ----^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `new_args`
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_new_args`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> aios-shell/src/executor.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ----^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `op`
[INFO] [stdout]    --> aios-shell/src/router.rs:414:27
[INFO] [stdout]     |
[INFO] [stdout] 414 |         for (i, (segment, op)) in segments.iter().enumerate() {
[INFO] [stdout]     |                           ^^ help: if this is intentional, prefix it with an underscore: `_op`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output`
[INFO] [stdout]    --> aios-shell/src/router.rs:496:72
[INFO] [stdout]     |
[INFO] [stdout] 496 |     async fn handle_command_not_found(&mut self, original_input: &str, output: &CommandOutput) {
[INFO] [stdout]     |                                                                        ^^^^^^ help: if this is intentional, prefix it with an underscore: `_output`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> aios-shell/src/executor.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ----^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `new_args`
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_new_args`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ----^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> aios-shell/src/executor.rs:4:33
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `aios_core::CommandOutput`
[INFO] [stdout]  --> aios-shell/src/scripting.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use aios_core::CommandOutput;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ----^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `new_args`
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_new_args`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `cursor_pos` is never read
[INFO] [stdout]    --> aios-shell/src/main.rs:150:33
[INFO] [stdout]     |
[INFO] [stdout] 150 |     let mut cursor_pos: usize = 0;
[INFO] [stdout]     |                                 ^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 169 |         cursor_pos = 0;
[INFO] [stdout]     |         -------------- `cursor_pos` is overwritten here before the previous value is read
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `history_index` is never read
[INFO] [stdout]    --> aios-shell/src/main.rs:151:44
[INFO] [stdout]     |
[INFO] [stdout] 151 |     let mut history_index: Option<usize> = None;
[INFO] [stdout]     |                                            ^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 170 |         history_index = None;
[INFO] [stdout]     |         -------------------- `history_index` is overwritten here before the previous value is read
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `recent` and `search` are never used
[INFO] [stdout]   --> aios-shell/src/history.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl History {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub fn recent(&self, count: usize) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn search(&self, pattern: &str) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `background` is never read
[INFO] [stdout]  --> aios-shell/src/parser.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ParsedCommand {
[INFO] [stdout]   |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 9 |     pub background: bool,
[INFO] [stdout]   |         ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `ParsedCommand` 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 `background` is never read
[INFO] [stdout]   --> aios-shell/src/parser.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct Pipeline {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 20 |     pub commands: Vec<ParsedCommand>,
[INFO] [stdout] 21 |     pub background: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pipeline` 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: struct `ChainedCommand` is never constructed
[INFO] [stdout]   --> aios-shell/src/parser.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct ChainedCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_command_for_exec` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:265:8
[INFO] [stdout]     |
[INFO] [stdout] 265 | pub fn resolve_command_for_exec(cmd: &ParsedCommand) -> (String, Vec<String>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tokenize` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:559:8
[INFO] [stdout]     |
[INFO] [stdout] 559 | pub fn tokenize(input: &str) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Os` is never constructed
[INFO] [stdout]   --> aios-shell/src/router.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ShellMode {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] 18 |     Shell,
[INFO] [stdout] 19 |     Os,
[INFO] [stdout]    |     ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ShellMode` 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: struct `ScriptInterpreter` is never constructed
[INFO] [stdout]  --> aios-shell/src/scripting.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct ScriptInterpreter {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> aios-shell/src/scripting.rs:12:12
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl ScriptInterpreter {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  12 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  18 |     pub fn execute_file(&mut self, path: &Path, executor: &mut Executor) -> Result<i32, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  24 |     pub fn execute_string(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  72 |     fn handle_if(
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     fn handle_while(
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 166 |     fn handle_for(
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 210 |     fn expand_vars(&self, input: &str, executor: &Executor) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `op`
[INFO] [stdout]    --> aios-shell/src/router.rs:414:27
[INFO] [stdout]     |
[INFO] [stdout] 414 |         for (i, (segment, op)) in segments.iter().enumerate() {
[INFO] [stdout]     |                           ^^ help: if this is intentional, prefix it with an underscore: `_op`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output`
[INFO] [stdout]    --> aios-shell/src/router.rs:496:72
[INFO] [stdout]     |
[INFO] [stdout] 496 |     async fn handle_command_not_found(&mut self, original_input: &str, output: &CommandOutput) {
[INFO] [stdout]     |                                                                        ^^^^^^ help: if this is intentional, prefix it with an underscore: `_output`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `op`
[INFO] [stdout]    --> aios-shell/src/router.rs:414:27
[INFO] [stdout]     |
[INFO] [stdout] 414 |         for (i, (segment, op)) in segments.iter().enumerate() {
[INFO] [stdout]     |                           ^^ help: if this is intentional, prefix it with an underscore: `_op`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output`
[INFO] [stdout]    --> aios-shell/src/router.rs:496:72
[INFO] [stdout]     |
[INFO] [stdout] 496 |     async fn handle_command_not_found(&mut self, original_input: &str, output: &CommandOutput) {
[INFO] [stdout]     |                                                                        ^^^^^^ help: if this is intentional, prefix it with an underscore: `_output`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `cursor_pos` is never read
[INFO] [stdout]    --> aios-shell/src/main_os.rs:155:33
[INFO] [stdout]     |
[INFO] [stdout] 155 |     let mut cursor_pos: usize = 0;
[INFO] [stdout]     |                                 ^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 174 |         cursor_pos = 0;
[INFO] [stdout]     |         -------------- `cursor_pos` is overwritten here before the previous value is read
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `history_index` is never read
[INFO] [stdout]    --> aios-shell/src/main_os.rs:156:44
[INFO] [stdout]     |
[INFO] [stdout] 156 |     let mut history_index: Option<usize> = None;
[INFO] [stdout]     |                                            ^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 175 |         history_index = None;
[INFO] [stdout]     |         -------------------- `history_index` is overwritten here before the previous value is read
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `recent` and `search` are never used
[INFO] [stdout]   --> aios-shell/src/history.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl History {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub fn recent(&self, count: usize) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn search(&self, pattern: &str) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `background` is never read
[INFO] [stdout]  --> aios-shell/src/parser.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ParsedCommand {
[INFO] [stdout]   |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 9 |     pub background: bool,
[INFO] [stdout]   |         ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `ParsedCommand` 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 `background` is never read
[INFO] [stdout]   --> aios-shell/src/parser.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct Pipeline {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 20 |     pub commands: Vec<ParsedCommand>,
[INFO] [stdout] 21 |     pub background: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pipeline` 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: struct `ChainedCommand` is never constructed
[INFO] [stdout]   --> aios-shell/src/parser.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct ChainedCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_command_for_exec` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:265:8
[INFO] [stdout]     |
[INFO] [stdout] 265 | pub fn resolve_command_for_exec(cmd: &ParsedCommand) -> (String, Vec<String>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tokenize` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:559:8
[INFO] [stdout]     |
[INFO] [stdout] 559 | pub fn tokenize(input: &str) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Shell` is never constructed
[INFO] [stdout]   --> aios-shell/src/router.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ShellMode {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] 18 |     Shell,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ShellMode` 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: associated function `new` is never used
[INFO] [stdout]   --> aios-shell/src/router.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 35 | impl ShellRouter {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 36 |     pub fn new(llm_router: Option<LlmRouter>, config: LlmConfig) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ScriptInterpreter` is never constructed
[INFO] [stdout]  --> aios-shell/src/scripting.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct ScriptInterpreter {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> aios-shell/src/scripting.rs:12:12
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl ScriptInterpreter {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  12 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  18 |     pub fn execute_file(&mut self, path: &Path, executor: &mut Executor) -> Result<i32, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  24 |     pub fn execute_string(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  72 |     fn handle_if(
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     fn handle_while(
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 166 |     fn handle_for(
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 210 |     fn expand_vars(&self, input: &str, executor: &Executor) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `cursor_pos` is never read
[INFO] [stdout]    --> aios-shell/src/main.rs:150:33
[INFO] [stdout]     |
[INFO] [stdout] 150 |     let mut cursor_pos: usize = 0;
[INFO] [stdout]     |                                 ^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 169 |         cursor_pos = 0;
[INFO] [stdout]     |         -------------- `cursor_pos` is overwritten here before the previous value is read
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `history_index` is never read
[INFO] [stdout]    --> aios-shell/src/main.rs:151:44
[INFO] [stdout]     |
[INFO] [stdout] 151 |     let mut history_index: Option<usize> = None;
[INFO] [stdout]     |                                            ^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 170 |         history_index = None;
[INFO] [stdout]     |         -------------------- `history_index` is overwritten here before the previous value is read
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `recent` and `search` are never used
[INFO] [stdout]   --> aios-shell/src/history.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl History {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub fn recent(&self, count: usize) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn search(&self, pattern: &str) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `background` is never read
[INFO] [stdout]  --> aios-shell/src/parser.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ParsedCommand {
[INFO] [stdout]   |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 9 |     pub background: bool,
[INFO] [stdout]   |         ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `ParsedCommand` 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 `background` is never read
[INFO] [stdout]   --> aios-shell/src/parser.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct Pipeline {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 20 |     pub commands: Vec<ParsedCommand>,
[INFO] [stdout] 21 |     pub background: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pipeline` 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: struct `ChainedCommand` is never constructed
[INFO] [stdout]   --> aios-shell/src/parser.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct ChainedCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_command_for_exec` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:265:8
[INFO] [stdout]     |
[INFO] [stdout] 265 | pub fn resolve_command_for_exec(cmd: &ParsedCommand) -> (String, Vec<String>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tokenize` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:559:8
[INFO] [stdout]     |
[INFO] [stdout] 559 | pub fn tokenize(input: &str) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Os` is never constructed
[INFO] [stdout]   --> aios-shell/src/router.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ShellMode {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] 18 |     Shell,
[INFO] [stdout] 19 |     Os,
[INFO] [stdout]    |     ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ShellMode` 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: struct `ScriptInterpreter` is never constructed
[INFO] [stdout]  --> aios-shell/src/scripting.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct ScriptInterpreter {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> aios-shell/src/scripting.rs:12:12
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl ScriptInterpreter {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  12 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  18 |     pub fn execute_file(&mut self, path: &Path, executor: &mut Executor) -> Result<i32, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  24 |     pub fn execute_string(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  72 |     fn handle_if(
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     fn handle_while(
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 166 |     fn handle_for(
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 210 |     fn expand_vars(&self, input: &str, executor: &Executor) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> aios-shell/src/executor.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ----^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> aios-shell/src/executor.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ----^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ----^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `new_args`
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_new_args`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> aios-shell/src/executor.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ----^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]   --> aios-shell/src/completion.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let mut i = bytes.len();
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ----^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `new_args`
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_new_args`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ----^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `new_args`
[INFO] [stdout]    --> aios-shell/src/executor.rs:107:25
[INFO] [stdout]     |
[INFO] [stdout] 107 |                     let mut new_args = vec![args[0]];
[INFO] [stdout]     |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_new_args`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `op`
[INFO] [stdout]    --> aios-shell/src/router.rs:414:27
[INFO] [stdout]     |
[INFO] [stdout] 414 |         for (i, (segment, op)) in segments.iter().enumerate() {
[INFO] [stdout]     |                           ^^ help: if this is intentional, prefix it with an underscore: `_op`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output`
[INFO] [stdout]    --> aios-shell/src/router.rs:496:72
[INFO] [stdout]     |
[INFO] [stdout] 496 |     async fn handle_command_not_found(&mut self, original_input: &str, output: &CommandOutput) {
[INFO] [stdout]     |                                                                        ^^^^^^ help: if this is intentional, prefix it with an underscore: `_output`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `cursor_pos` is never read
[INFO] [stdout]    --> aios-shell/src/main.rs:150:33
[INFO] [stdout]     |
[INFO] [stdout] 150 |     let mut cursor_pos: usize = 0;
[INFO] [stdout]     |                                 ^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 169 |         cursor_pos = 0;
[INFO] [stdout]     |         -------------- `cursor_pos` is overwritten here before the previous value is read
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `history_index` is never read
[INFO] [stdout]    --> aios-shell/src/main.rs:151:44
[INFO] [stdout]     |
[INFO] [stdout] 151 |     let mut history_index: Option<usize> = None;
[INFO] [stdout]     |                                            ^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 170 |         history_index = None;
[INFO] [stdout]     |         -------------------- `history_index` is overwritten here before the previous value is read
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `recent` and `search` are never used
[INFO] [stdout]   --> aios-shell/src/history.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl History {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub fn recent(&self, count: usize) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn search(&self, pattern: &str) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `background` is never read
[INFO] [stdout]  --> aios-shell/src/parser.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ParsedCommand {
[INFO] [stdout]   |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 9 |     pub background: bool,
[INFO] [stdout]   |         ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `ParsedCommand` 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 `background` is never read
[INFO] [stdout]   --> aios-shell/src/parser.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct Pipeline {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 20 |     pub commands: Vec<ParsedCommand>,
[INFO] [stdout] 21 |     pub background: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pipeline` 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: struct `ChainedCommand` is never constructed
[INFO] [stdout]   --> aios-shell/src/parser.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct ChainedCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_command_for_exec` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:265:8
[INFO] [stdout]     |
[INFO] [stdout] 265 | pub fn resolve_command_for_exec(cmd: &ParsedCommand) -> (String, Vec<String>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tokenize` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:559:8
[INFO] [stdout]     |
[INFO] [stdout] 559 | pub fn tokenize(input: &str) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Os` is never constructed
[INFO] [stdout]   --> aios-shell/src/router.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ShellMode {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] 18 |     Shell,
[INFO] [stdout] 19 |     Os,
[INFO] [stdout]    |     ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ShellMode` 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: struct `ScriptInterpreter` is never constructed
[INFO] [stdout]  --> aios-shell/src/scripting.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct ScriptInterpreter {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> aios-shell/src/scripting.rs:12:12
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl ScriptInterpreter {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  12 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  18 |     pub fn execute_file(&mut self, path: &Path, executor: &mut Executor) -> Result<i32, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  24 |     pub fn execute_string(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  72 |     fn handle_if(
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     fn handle_while(
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 166 |     fn handle_for(
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 210 |     fn expand_vars(&self, input: &str, executor: &Executor) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `op`
[INFO] [stdout]    --> aios-shell/src/router.rs:414:27
[INFO] [stdout]     |
[INFO] [stdout] 414 |         for (i, (segment, op)) in segments.iter().enumerate() {
[INFO] [stdout]     |                           ^^ help: if this is intentional, prefix it with an underscore: `_op`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output`
[INFO] [stdout]    --> aios-shell/src/router.rs:496:72
[INFO] [stdout]     |
[INFO] [stdout] 496 |     async fn handle_command_not_found(&mut self, original_input: &str, output: &CommandOutput) {
[INFO] [stdout]     |                                                                        ^^^^^^ help: if this is intentional, prefix it with an underscore: `_output`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `op`
[INFO] [stdout]    --> aios-shell/src/router.rs:414:27
[INFO] [stdout]     |
[INFO] [stdout] 414 |         for (i, (segment, op)) in segments.iter().enumerate() {
[INFO] [stdout]     |                           ^^ help: if this is intentional, prefix it with an underscore: `_op`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output`
[INFO] [stdout]    --> aios-shell/src/router.rs:496:72
[INFO] [stdout]     |
[INFO] [stdout] 496 |     async fn handle_command_not_found(&mut self, original_input: &str, output: &CommandOutput) {
[INFO] [stdout]     |                                                                        ^^^^^^ help: if this is intentional, prefix it with an underscore: `_output`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `cursor_pos` is never read
[INFO] [stdout]    --> aios-shell/src/main_os.rs:155:33
[INFO] [stdout]     |
[INFO] [stdout] 155 |     let mut cursor_pos: usize = 0;
[INFO] [stdout]     |                                 ^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 174 |         cursor_pos = 0;
[INFO] [stdout]     |         -------------- `cursor_pos` is overwritten here before the previous value is read
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `history_index` is never read
[INFO] [stdout]    --> aios-shell/src/main_os.rs:156:44
[INFO] [stdout]     |
[INFO] [stdout] 156 |     let mut history_index: Option<usize> = None;
[INFO] [stdout]     |                                            ^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 175 |         history_index = None;
[INFO] [stdout]     |         -------------------- `history_index` is overwritten here before the previous value is read
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `cursor_pos` is never read
[INFO] [stdout]    --> aios-shell/src/main.rs:150:33
[INFO] [stdout]     |
[INFO] [stdout] 150 |     let mut cursor_pos: usize = 0;
[INFO] [stdout]     |                                 ^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 169 |         cursor_pos = 0;
[INFO] [stdout]     |         -------------- `cursor_pos` is overwritten here before the previous value is read
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `history_index` is never read
[INFO] [stdout]    --> aios-shell/src/main.rs:151:44
[INFO] [stdout]     |
[INFO] [stdout] 151 |     let mut history_index: Option<usize> = None;
[INFO] [stdout]     |                                            ^^^^ this value is reassigned later and never used
[INFO] [stdout] ...
[INFO] [stdout] 170 |         history_index = None;
[INFO] [stdout]     |         -------------------- `history_index` is overwritten here before the previous value is read
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `recent` and `search` are never used
[INFO] [stdout]   --> aios-shell/src/history.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl History {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub fn recent(&self, count: usize) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn search(&self, pattern: &str) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `background` is never read
[INFO] [stdout]  --> aios-shell/src/parser.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ParsedCommand {
[INFO] [stdout]   |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 9 |     pub background: bool,
[INFO] [stdout]   |         ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `ParsedCommand` 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 `background` is never read
[INFO] [stdout]   --> aios-shell/src/parser.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct Pipeline {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 20 |     pub commands: Vec<ParsedCommand>,
[INFO] [stdout] 21 |     pub background: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pipeline` 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: struct `ChainedCommand` is never constructed
[INFO] [stdout]   --> aios-shell/src/parser.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct ChainedCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_command_for_exec` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:265:8
[INFO] [stdout]     |
[INFO] [stdout] 265 | pub fn resolve_command_for_exec(cmd: &ParsedCommand) -> (String, Vec<String>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tokenize` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:559:8
[INFO] [stdout]     |
[INFO] [stdout] 559 | pub fn tokenize(input: &str) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Shell` is never constructed
[INFO] [stdout]   --> aios-shell/src/router.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ShellMode {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] 18 |     Shell,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ShellMode` 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: methods `recent` and `search` are never used
[INFO] [stdout]   --> aios-shell/src/history.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl History {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 51 |     pub fn recent(&self, count: usize) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn search(&self, pattern: &str) -> Vec<&HistoryEntry> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> aios-shell/src/router.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 35 | impl ShellRouter {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 36 |     pub fn new(llm_router: Option<LlmRouter>, config: LlmConfig) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ScriptInterpreter` is never constructed
[INFO] [stdout]  --> aios-shell/src/scripting.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct ScriptInterpreter {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `background` is never read
[INFO] [stdout]  --> aios-shell/src/parser.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct ParsedCommand {
[INFO] [stdout]   |            ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 9 |     pub background: bool,
[INFO] [stdout]   |         ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `ParsedCommand` 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: multiple associated items are never used
[INFO] [stdout]    --> aios-shell/src/scripting.rs:12:12
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl ScriptInterpreter {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  12 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  18 |     pub fn execute_file(&mut self, path: &Path, executor: &mut Executor) -> Result<i32, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  24 |     pub fn execute_string(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  72 |     fn handle_if(
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     fn handle_while(
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 166 |     fn handle_for(
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 210 |     fn expand_vars(&self, input: &str, executor: &Executor) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `background` is never read
[INFO] [stdout]   --> aios-shell/src/parser.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub struct Pipeline {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 20 |     pub commands: Vec<ParsedCommand>,
[INFO] [stdout] 21 |     pub background: bool,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Pipeline` 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: struct `ChainedCommand` is never constructed
[INFO] [stdout]   --> aios-shell/src/parser.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub struct ChainedCommand {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `resolve_command_for_exec` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:265:8
[INFO] [stdout]     |
[INFO] [stdout] 265 | pub fn resolve_command_for_exec(cmd: &ParsedCommand) -> (String, Vec<String>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `tokenize` is never used
[INFO] [stdout]    --> aios-shell/src/parser.rs:559:8
[INFO] [stdout]     |
[INFO] [stdout] 559 | pub fn tokenize(input: &str) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Os` is never constructed
[INFO] [stdout]   --> aios-shell/src/router.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum ShellMode {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] 18 |     Shell,
[INFO] [stdout] 19 |     Os,
[INFO] [stdout]    |     ^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ShellMode` 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: struct `ScriptInterpreter` is never constructed
[INFO] [stdout]  --> aios-shell/src/scripting.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct ScriptInterpreter {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> aios-shell/src/scripting.rs:12:12
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl ScriptInterpreter {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  12 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  18 |     pub fn execute_file(&mut self, path: &Path, executor: &mut Executor) -> Result<i32, String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  24 |     pub fn execute_string(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  72 |     fn handle_if(
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     fn handle_while(
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 166 |     fn handle_for(
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 210 |     fn expand_vars(&self, input: &str, executor: &Executor) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 33.25s
[INFO] running `Command { std: "docker" "inspect" "0eaa7128ca3f0a05920808d82d00580216aa34c74cfec4fe94cb48df9f4bddc8", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0eaa7128ca3f0a05920808d82d00580216aa34c74cfec4fe94cb48df9f4bddc8", kill_on_drop: false }`
[INFO] [stdout] 0eaa7128ca3f0a05920808d82d00580216aa34c74cfec4fe94cb48df9f4bddc8
