[INFO] cloning repository https://github.com/vinhnxv/varre [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/vinhnxv/varre" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fvinhnxv%2Fvarre", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fvinhnxv%2Fvarre'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 609d681446eac32f8e8e90b1e5d9d0eab5396a43 [INFO] checking vinhnxv/varre against try#3fada14ee01d755dc8076e611f11bf65b28ffd21 for pr-154971 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fvinhnxv%2Fvarre" "/workspace/builds/worker-0-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/vinhnxv/varre [INFO] finished tweaking git repo https://github.com/vinhnxv/varre [INFO] tweaked toml for git repo https://github.com/vinhnxv/varre written to /workspace/builds/worker-0-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/vinhnxv/varre on toolchain 3fada14ee01d755dc8076e611f11bf65b28ffd21 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+3fada14ee01d755dc8076e611f11bf65b28ffd21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/vinhnxv/varre 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" "+3fada14ee01d755dc8076e611f11bf65b28ffd21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [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 vinhnxv/varre against try#3fada14ee01d755dc8076e611f11bf65b28ffd21 for pr-154971 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fvinhnxv%2Fvarre" "/workspace/builds/worker-0-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/vinhnxv/varre [INFO] finished tweaking git repo https://github.com/vinhnxv/varre [INFO] tweaked toml for git repo https://github.com/vinhnxv/varre written to /workspace/builds/worker-0-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/vinhnxv/varre on toolchain 3fada14ee01d755dc8076e611f11bf65b28ffd21 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+3fada14ee01d755dc8076e611f11bf65b28ffd21" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/vinhnxv/varre 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" "+3fada14ee01d755dc8076e611f11bf65b28ffd21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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" "+3fada14ee01d755dc8076e611f11bf65b28ffd21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 876eaf63d6766d45e9b941a617b5e981ee593b395b43b03b0514a16c3944859b [INFO] running `Command { std: "docker" "start" "-a" "876eaf63d6766d45e9b941a617b5e981ee593b395b43b03b0514a16c3944859b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "876eaf63d6766d45e9b941a617b5e981ee593b395b43b03b0514a16c3944859b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "876eaf63d6766d45e9b941a617b5e981ee593b395b43b03b0514a16c3944859b", kill_on_drop: false }` [INFO] [stdout] 876eaf63d6766d45e9b941a617b5e981ee593b395b43b03b0514a16c3944859b [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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" "+3fada14ee01d755dc8076e611f11bf65b28ffd21" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] e29686f8fcbc9118e7afa7b6fd253dee10d5aa9898189b655126507ec961a9f1 [INFO] running `Command { std: "docker" "start" "-a" "e29686f8fcbc9118e7afa7b6fd253dee10d5aa9898189b655126507ec961a9f1", kill_on_drop: false }` [INFO] [stderr] Checking futures-channel v0.3.32 [INFO] [stderr] Checking tracing-core v0.1.36 [INFO] [stderr] Compiling instability v0.3.11 [INFO] [stderr] Compiling syn v2.0.117 [INFO] [stderr] Checking mio v1.1.1 [INFO] [stderr] Checking parking_lot_core v0.9.12 [INFO] [stderr] Checking slab v0.4.12 [INFO] [stderr] Compiling getrandom v0.4.2 [INFO] [stderr] Checking regex-syntax v0.8.10 [INFO] [stderr] Checking rustix v0.38.44 [INFO] [stderr] Checking signal-hook v0.3.18 [INFO] [stderr] Checking socket2 v0.6.3 [INFO] [stderr] Checking clap_lex v1.0.0 [INFO] [stderr] Checking toml_write v0.1.2 [INFO] [stderr] Checking compact_str v0.8.1 [INFO] [stderr] Checking dirs-sys v0.4.1 [INFO] [stderr] Checking serde_json v1.0.149 [INFO] [stderr] Checking dirs v5.0.1 [INFO] [stderr] Checking clap_builder v4.5.60 [INFO] [stderr] Checking parking_lot v0.12.5 [INFO] [stderr] Checking uuid v1.22.0 [INFO] [stderr] Checking signal-hook-mio v0.2.5 [INFO] [stderr] Checking tracing-log v0.2.0 [INFO] [stderr] Checking crossterm v0.28.1 [INFO] [stderr] Checking regex-automata v0.4.14 [INFO] [stderr] Checking matchers v0.2.0 [INFO] [stderr] Compiling darling_core v0.23.0 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling futures-macro v0.3.32 [INFO] [stderr] Compiling tracing-attributes v0.1.31 [INFO] [stderr] Compiling tokio-macros v2.6.1 [INFO] [stderr] Compiling strum_macros v0.26.4 [INFO] [stderr] Compiling clap_derive v4.5.55 [INFO] [stderr] Checking tokio v1.50.0 [INFO] [stderr] Checking futures-util v0.3.32 [INFO] [stderr] Checking tracing v0.1.44 [INFO] [stderr] Checking tracing-subscriber v0.3.22 [INFO] [stderr] Checking strum v0.26.3 [INFO] [stderr] Checking clap v4.5.60 [INFO] [stderr] Compiling darling_macro v0.23.0 [INFO] [stderr] Compiling darling v0.23.0 [INFO] [stderr] Checking ratatui v0.29.0 [INFO] [stderr] Checking serde v1.0.228 [INFO] [stderr] Checking serde_spanned v0.6.9 [INFO] [stderr] Checking toml_datetime v0.6.11 [INFO] [stderr] Checking chrono v0.4.44 [INFO] [stderr] Checking toml_edit v0.22.27 [INFO] [stderr] Checking futures-executor v0.3.32 [INFO] [stderr] Checking futures v0.3.32 [INFO] [stderr] Checking toml v0.8.23 [INFO] [stderr] Checking tokio-util v0.7.18 [INFO] [stderr] Checking varre v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `mock::MockBackend` [INFO] [stdout] --> src/backend/mod.rs:9:9 [INFO] [stdout] | [INFO] [stdout] 9 | pub use mock::MockBackend; [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 variable: `branch` [INFO] [stdout] --> src/tui/app.rs:75:13 [INFO] [stdout] | [INFO] [stdout] 75 | let branch = self.metrics.git_branch [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_branch` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `tmux` [INFO] [stdout] --> src/tui/mod.rs:170:5 [INFO] [stdout] | [INFO] [stdout] 170 | tmux: &TmuxWrapper, [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_tmux` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `config` [INFO] [stdout] --> src/tui/mod.rs:171:5 [INFO] [stdout] | [INFO] [stdout] 171 | config: &Config, [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `branch` [INFO] [stdout] --> src/tui/app.rs:75:13 [INFO] [stdout] | [INFO] [stdout] 75 | let branch = self.metrics.git_branch [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_branch` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `StreamJson` is never constructed [INFO] [stdout] --> src/backend/mod.rs:16:5 [INFO] [stdout] | [INFO] [stdout] 13 | pub enum OutputFormat { [INFO] [stdout] | ------------ variant in this enum [INFO] [stdout] ... [INFO] [stdout] 16 | StreamJson, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `OutputFormat` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `max_budget_usd` is never read [INFO] [stdout] --> src/backend/mod.rs:36:9 [INFO] [stdout] | [INFO] [stdout] 31 | pub struct ExecOptions { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 36 | pub max_budget_usd: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ExecOptions` 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: method `version` is never used [INFO] [stdout] --> src/backend/mod.rs:68:14 [INFO] [stdout] | [INFO] [stdout] 63 | pub trait ClaudeBackend: Send + Sync { [INFO] [stdout] | ------------- method in this trait [INFO] [stdout] ... [INFO] [stdout] 68 | async fn version(&self) -> Result; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `MockBackend` is never constructed [INFO] [stdout] --> src/backend/mock.rs:7:12 [INFO] [stdout] | [INFO] [stdout] 7 | pub struct MockBackend { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated functions `new`, `with_response`, `with_error`, and `with_delay` are never used [INFO] [stdout] --> src/backend/mock.rs:15:12 [INFO] [stdout] | [INFO] [stdout] 13 | impl MockBackend { [INFO] [stdout] | ---------------- associated functions in this implementation [INFO] [stdout] 14 | /// Create a mock that returns a default success response. [INFO] [stdout] 15 | pub fn new() -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 32 | pub fn with_response(response: ClaudeResponse) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 41 | pub fn with_error(message: impl Into) -> Self { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 50 | pub fn with_delay(delay: Duration) -> Self { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple variants are never constructed [INFO] [stdout] --> src/error.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 4 | pub enum VarreError { [INFO] [stdout] | ---------- variants in this enum [INFO] [stdout] ... [INFO] [stdout] 7 | SessionLocked(String), [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 8 | InvalidTransition { from: String, event: String }, [INFO] [stdout] 9 | ClaudeNotFound, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 13 | DetectionTimeout, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 14 | TuiError(String), [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 15 | Timeout { seconds: u64 }, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] 16 | QueueEmpty, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 17 | CircuitBreakerOpen { consecutive_failures: u32 }, [INFO] [stdout] 18 | Config(String), [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `VarreError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `created_at` is never read [INFO] [stdout] --> src/orchestrator/mod.rs:33:9 [INFO] [stdout] | [INFO] [stdout] 25 | pub struct SessionInfo { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 33 | pub created_at: DateTime, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `cancel_token` is never read [INFO] [stdout] --> src/orchestrator/mod.rs:49:5 [INFO] [stdout] | [INFO] [stdout] 39 | pub struct Orchestrator { [INFO] [stdout] | ------------ field in this struct [INFO] [stdout] ... [INFO] [stdout] 49 | cancel_token: CancellationToken, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `session_status`, `cancel_token`, `has_session`, and `reset_circuit_breaker` are never used [INFO] [stdout] --> src/orchestrator/mod.rs:142:18 [INFO] [stdout] | [INFO] [stdout] 54 | impl Orchestrator { [INFO] [stdout] | -------------------------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 142 | pub async fn session_status(&self, name: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 395 | pub fn cancel_token(&self) -> &CancellationToken { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 400 | pub fn has_session(&self, name: &str) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 405 | pub fn reset_circuit_breaker(&self) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `id` is never used [INFO] [stdout] --> src/session/mod.rs:98:12 [INFO] [stdout] | [INFO] [stdout] 79 | impl HeadlessSession { [INFO] [stdout] | -------------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 98 | pub fn id(&self) -> &SessionId { [INFO] [stdout] | ^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `list` is never used [INFO] [stdout] --> src/session/mod.rs:269:12 [INFO] [stdout] | [INFO] [stdout] 175 | impl SessionStore { [INFO] [stdout] | ----------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 269 | pub fn list(&self) -> Vec<&SessionId> { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `SessionUpdate` is never constructed [INFO] [stdout] --> src/session/event.rs:10:12 [INFO] [stdout] | [INFO] [stdout] 10 | pub struct SessionUpdate { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/session/event.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 19 | impl SessionUpdate { [INFO] [stdout] | ------------------ associated function in this implementation [INFO] [stdout] 20 | /// Create a new session update with the current timestamp. [INFO] [stdout] 21 | pub fn new(session_id: SessionId, event: SessionEvent) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `session_update_channel` is never used [INFO] [stdout] --> src/session/event.rs:33:8 [INFO] [stdout] | [INFO] [stdout] 33 | pub fn session_update_channel( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `config`, `claude_status`, `output_buffer`, and `max_output_lines` are never read [INFO] [stdout] --> src/session/interactive.rs:32:9 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct InteractiveSession { [INFO] [stdout] | ------------------ fields in this struct [INFO] [stdout] ... [INFO] [stdout] 32 | pub config: ClaudeConfig, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 36 | claude_status: Arc>, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 37 | /// Recent captured output lines (sliding window via VecDeque — Finding 6). [INFO] [stdout] 38 | output_buffer: Arc>>, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 39 | /// Maximum output lines to keep. [INFO] [stdout] 40 | max_output_lines: usize, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `InteractiveSession` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/session/interactive.rs:62:18 [INFO] [stdout] | [INFO] [stdout] 43 | impl InteractiveSession { [INFO] [stdout] | ----------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 62 | pub async fn start_claude(&self, session_name: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 81 | pub async fn status(&self) -> ClaudeStatus { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 86 | pub async fn poll_once(&self, session_name: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 132 | pub async fn output_lines(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 137 | pub fn shared_status(&self) -> Arc> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 142 | pub fn shared_output(&self) -> Arc>> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 147 | pub fn shared_state(&self) -> Arc> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 152 | pub fn id(&self) -> &SessionId { [INFO] [stdout] | ^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `TmuxSessionInfo` is never constructed [INFO] [stdout] --> src/tmux/mod.rs:16:12 [INFO] [stdout] | [INFO] [stdout] 16 | pub struct TmuxSessionInfo { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `prompt_marker` is never read [INFO] [stdout] --> src/tmux/mod.rs:33:5 [INFO] [stdout] | [INFO] [stdout] 27 | pub struct TmuxWrapper { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 33 | prompt_marker: String, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `TmuxWrapper` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `detect_session_status`, `list_sessions`, `start_claude`, and `prompt_marker` are never used [INFO] [stdout] --> src/tmux/mod.rs:216:18 [INFO] [stdout] | [INFO] [stdout] 36 | impl TmuxWrapper { [INFO] [stdout] | ---------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 216 | pub async fn detect_session_status(&self, name: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 222 | pub async fn list_sessions(&self) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 284 | pub async fn start_claude(&self, name: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 289 | pub fn prompt_marker(&self) -> &str { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `pane_pid` is never read [INFO] [stdout] --> src/tmux/scanner.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub struct DiscoveredSession { [INFO] [stdout] | ----------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 47 | pub pane_pid: Option, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DiscoveredSession` 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: method `with_capture_lines` is never used [INFO] [stdout] --> src/tmux/scanner.rs:77:12 [INFO] [stdout] | [INFO] [stdout] 67 | impl TmuxScanner { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 77 | pub fn with_capture_lines(mut self, lines: i32) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `pane_size` is never read [INFO] [stdout] --> src/tui/app.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 15 | pub struct SessionViewModel { [INFO] [stdout] | ---------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 27 | pub pane_size: (u16, u16), [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `SessionViewModel` 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 `Key`, `Tick`, and `Resize` are never constructed [INFO] [stdout] --> src/tui/event.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 7 | pub enum AppEvent { [INFO] [stdout] | -------- variants in this enum [INFO] [stdout] 8 | /// A keyboard input event. [INFO] [stdout] 9 | Key(KeyEvent), [INFO] [stdout] | ^^^ [INFO] [stdout] 10 | /// Periodic tick for UI refresh. [INFO] [stdout] 11 | Tick, [INFO] [stdout] | ^^^^ [INFO] [stdout] ... [INFO] [stdout] 15 | Resize(u16, u16), [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AppEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `tmux` [INFO] [stdout] --> src/tui/mod.rs:170:5 [INFO] [stdout] | [INFO] [stdout] 170 | tmux: &TmuxWrapper, [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_tmux` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `config` [INFO] [stdout] --> src/tui/mod.rs:171:5 [INFO] [stdout] | [INFO] [stdout] 171 | config: &Config, [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `StreamJson` is never constructed [INFO] [stdout] --> src/backend/mod.rs:16:5 [INFO] [stdout] | [INFO] [stdout] 13 | pub enum OutputFormat { [INFO] [stdout] | ------------ variant in this enum [INFO] [stdout] ... [INFO] [stdout] 16 | StreamJson, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `OutputFormat` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `max_budget_usd` is never read [INFO] [stdout] --> src/backend/mod.rs:36:9 [INFO] [stdout] | [INFO] [stdout] 31 | pub struct ExecOptions { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 36 | pub max_budget_usd: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `ExecOptions` 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: method `version` is never used [INFO] [stdout] --> src/backend/mod.rs:68:14 [INFO] [stdout] | [INFO] [stdout] 63 | pub trait ClaudeBackend: Send + Sync { [INFO] [stdout] | ------------- method in this trait [INFO] [stdout] ... [INFO] [stdout] 68 | async fn version(&self) -> Result; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated functions `with_response`, `with_error`, and `with_delay` are never used [INFO] [stdout] --> src/backend/mock.rs:32:12 [INFO] [stdout] | [INFO] [stdout] 13 | impl MockBackend { [INFO] [stdout] | ---------------- associated functions in this implementation [INFO] [stdout] ... [INFO] [stdout] 32 | pub fn with_response(response: ClaudeResponse) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 41 | pub fn with_error(message: impl Into) -> Self { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 50 | pub fn with_delay(delay: Duration) -> Self { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple variants are never constructed [INFO] [stdout] --> src/error.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 4 | pub enum VarreError { [INFO] [stdout] | ---------- variants in this enum [INFO] [stdout] ... [INFO] [stdout] 7 | SessionLocked(String), [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] 8 | InvalidTransition { from: String, event: String }, [INFO] [stdout] 9 | ClaudeNotFound, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 13 | DetectionTimeout, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] 14 | TuiError(String), [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 15 | Timeout { seconds: u64 }, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] 16 | QueueEmpty, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 17 | CircuitBreakerOpen { consecutive_failures: u32 }, [INFO] [stdout] 18 | Config(String), [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `VarreError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `created_at` is never read [INFO] [stdout] --> src/orchestrator/mod.rs:33:9 [INFO] [stdout] | [INFO] [stdout] 25 | pub struct SessionInfo { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 33 | pub created_at: DateTime, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `cancel_token` is never read [INFO] [stdout] --> src/orchestrator/mod.rs:49:5 [INFO] [stdout] | [INFO] [stdout] 39 | pub struct Orchestrator { [INFO] [stdout] | ------------ field in this struct [INFO] [stdout] ... [INFO] [stdout] 49 | cancel_token: CancellationToken, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `session_status`, `cancel_token`, `has_session`, and `reset_circuit_breaker` are never used [INFO] [stdout] --> src/orchestrator/mod.rs:142:18 [INFO] [stdout] | [INFO] [stdout] 54 | impl Orchestrator { [INFO] [stdout] | -------------------------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 142 | pub async fn session_status(&self, name: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 395 | pub fn cancel_token(&self) -> &CancellationToken { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 400 | pub fn has_session(&self, name: &str) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 405 | pub fn reset_circuit_breaker(&self) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `id` is never used [INFO] [stdout] --> src/session/mod.rs:98:12 [INFO] [stdout] | [INFO] [stdout] 79 | impl HeadlessSession { [INFO] [stdout] | -------------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 98 | pub fn id(&self) -> &SessionId { [INFO] [stdout] | ^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `list` is never used [INFO] [stdout] --> src/session/mod.rs:269:12 [INFO] [stdout] | [INFO] [stdout] 175 | impl SessionStore { [INFO] [stdout] | ----------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 269 | pub fn list(&self) -> Vec<&SessionId> { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `SessionUpdate` is never constructed [INFO] [stdout] --> src/session/event.rs:10:12 [INFO] [stdout] | [INFO] [stdout] 10 | pub struct SessionUpdate { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/session/event.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 19 | impl SessionUpdate { [INFO] [stdout] | ------------------ associated function in this implementation [INFO] [stdout] 20 | /// Create a new session update with the current timestamp. [INFO] [stdout] 21 | pub fn new(session_id: SessionId, event: SessionEvent) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `session_update_channel` is never used [INFO] [stdout] --> src/session/event.rs:33:8 [INFO] [stdout] | [INFO] [stdout] 33 | pub fn session_update_channel( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `config` and `max_output_lines` are never read [INFO] [stdout] --> src/session/interactive.rs:32:9 [INFO] [stdout] | [INFO] [stdout] 22 | pub struct InteractiveSession { [INFO] [stdout] | ------------------ fields in this struct [INFO] [stdout] ... [INFO] [stdout] 32 | pub config: ClaudeConfig, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 40 | max_output_lines: usize, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `InteractiveSession` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `start_claude`, `poll_once`, `shared_status`, `shared_output`, `shared_state`, and `id` are never used [INFO] [stdout] --> src/session/interactive.rs:62:18 [INFO] [stdout] | [INFO] [stdout] 43 | impl InteractiveSession { [INFO] [stdout] | ----------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 62 | pub async fn start_claude(&self, session_name: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 86 | pub async fn poll_once(&self, session_name: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 137 | pub fn shared_status(&self) -> Arc> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 142 | pub fn shared_output(&self) -> Arc>> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 147 | pub fn shared_state(&self) -> Arc> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 152 | pub fn id(&self) -> &SessionId { [INFO] [stdout] | ^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `TmuxSessionInfo` is never constructed [INFO] [stdout] --> src/tmux/mod.rs:16:12 [INFO] [stdout] | [INFO] [stdout] 16 | pub struct TmuxSessionInfo { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `prompt_marker` is never read [INFO] [stdout] --> src/tmux/mod.rs:33:5 [INFO] [stdout] | [INFO] [stdout] 27 | pub struct TmuxWrapper { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 33 | prompt_marker: String, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `TmuxWrapper` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `detect_session_status`, `list_sessions`, `start_claude`, and `prompt_marker` are never used [INFO] [stdout] --> src/tmux/mod.rs:216:18 [INFO] [stdout] | [INFO] [stdout] 36 | impl TmuxWrapper { [INFO] [stdout] | ---------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 216 | pub async fn detect_session_status(&self, name: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 222 | pub async fn list_sessions(&self) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 284 | pub async fn start_claude(&self, name: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 289 | pub fn prompt_marker(&self) -> &str { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `pane_pid` is never read [INFO] [stdout] --> src/tmux/scanner.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 39 | pub struct DiscoveredSession { [INFO] [stdout] | ----------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 47 | pub pane_pid: Option, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DiscoveredSession` 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 `pane_size` is never read [INFO] [stdout] --> src/tui/app.rs:27:9 [INFO] [stdout] | [INFO] [stdout] 15 | pub struct SessionViewModel { [INFO] [stdout] | ---------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 27 | pub pane_size: (u16, u16), [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `SessionViewModel` 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 `Key`, `Tick`, and `Resize` are never constructed [INFO] [stdout] --> src/tui/event.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 7 | pub enum AppEvent { [INFO] [stdout] | -------- variants in this enum [INFO] [stdout] 8 | /// A keyboard input event. [INFO] [stdout] 9 | Key(KeyEvent), [INFO] [stdout] | ^^^ [INFO] [stdout] 10 | /// Periodic tick for UI refresh. [INFO] [stdout] 11 | Tick, [INFO] [stdout] | ^^^^ [INFO] [stdout] ... [INFO] [stdout] 15 | Resize(u16, u16), [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AppEvent` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 7.50s [INFO] running `Command { std: "docker" "inspect" "e29686f8fcbc9118e7afa7b6fd253dee10d5aa9898189b655126507ec961a9f1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e29686f8fcbc9118e7afa7b6fd253dee10d5aa9898189b655126507ec961a9f1", kill_on_drop: false }` [INFO] [stdout] e29686f8fcbc9118e7afa7b6fd253dee10d5aa9898189b655126507ec961a9f1