[INFO] cloning repository https://github.com/Agora-Build/Atem [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Agora-Build/Atem" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAgora-Build%2FAtem", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAgora-Build%2FAtem'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 3ca8d7640db44d16e6e93c3ccd1051c95006ba0e [INFO] checking Agora-Build/Atem against master#0028f344ce9f64766259577c998a1959ca1f6a0b for pr-153041 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAgora-Build%2FAtem" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/Agora-Build/Atem [INFO] finished tweaking git repo https://github.com/Agora-Build/Atem [INFO] tweaked toml for git repo https://github.com/Agora-Build/Atem written to /workspace/builds/worker-4-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/Agora-Build/Atem on toolchain 0028f344ce9f64766259577c998a1959ca1f6a0b [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+0028f344ce9f64766259577c998a1959ca1f6a0b" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/Agora-Build/Atem 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" "+0028f344ce9f64766259577c998a1959ca1f6a0b" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded vte v0.11.1 [INFO] [stderr] Downloaded vt100 v0.15.2 [INFO] [stderr] Downloaded vte_generate_state_changes v0.1.2 [INFO] [stderr] Downloaded hostname v0.4.2 [INFO] [stderr] Downloaded fd-lock v4.0.4 [INFO] [stderr] Downloaded ctrlc v3.5.1 [INFO] [stderr] Downloaded instability v0.3.9 [INFO] [stderr] Downloaded indoc v2.0.6 [INFO] [stderr] Downloaded portable-pty v0.9.0 [INFO] [stderr] Downloaded clap v4.5.47 [INFO] [stderr] Downloaded serial2 v0.2.34 [INFO] [stderr] Downloaded compact_str v0.8.1 [INFO] [stderr] Downloaded rustyline v14.0.0 [INFO] [stderr] Downloaded rcgen v0.13.2 [INFO] [stderr] Downloaded indexmap v2.11.1 [INFO] [stderr] Downloaded js-sys v0.3.78 [INFO] [stderr] Downloaded uuid v1.18.1 [INFO] [stderr] Downloaded clap_builder v4.5.47 [INFO] [stderr] Downloaded tempfile v3.21.0 [INFO] [stderr] Downloaded unicode-truncate v1.1.0 [INFO] [stderr] Downloaded wasm-bindgen-futures v0.4.51 [INFO] [stderr] Downloaded ratatui v0.29.0 [INFO] [stderr] Downloaded web-sys v0.3.78 [INFO] [stderr] Downloaded openssl-src v300.5.5+3.5.5 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:61361fe0aef631f17e9d025a70c5a647956f8c671dd02950a60ad3f5cc5526d7" "/opt/rustwide/cargo-home/bin/cargo" "+0028f344ce9f64766259577c998a1959ca1f6a0b" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 3889df80d24fe63f3022cd4bdcf7d9119c19b4ec1b7e9d9010261e9c472ad19d [INFO] running `Command { std: "docker" "start" "-a" "3889df80d24fe63f3022cd4bdcf7d9119c19b4ec1b7e9d9010261e9c472ad19d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "3889df80d24fe63f3022cd4bdcf7d9119c19b4ec1b7e9d9010261e9c472ad19d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "3889df80d24fe63f3022cd4bdcf7d9119c19b4ec1b7e9d9010261e9c472ad19d", kill_on_drop: false }` [INFO] [stdout] 3889df80d24fe63f3022cd4bdcf7d9119c19b4ec1b7e9d9010261e9c472ad19d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:61361fe0aef631f17e9d025a70c5a647956f8c671dd02950a60ad3f5cc5526d7" "/opt/rustwide/cargo-home/bin/cargo" "+0028f344ce9f64766259577c998a1959ca1f6a0b" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] fe3ee49ebee26b9de5638d25e5157994268c6d9d80ec785cfbc5c04393c79960 [INFO] running `Command { std: "docker" "start" "-a" "fe3ee49ebee26b9de5638d25e5157994268c6d9d80ec785cfbc5c04393c79960", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.101 [INFO] [stderr] Compiling libc v0.2.175 [INFO] [stderr] Checking cfg-if v1.0.3 [INFO] [stderr] Checking smallvec v1.15.1 [INFO] [stderr] Checking log v0.4.28 [INFO] [stderr] Checking bitflags v2.9.4 [INFO] [stderr] Compiling serde_core v1.0.228 [INFO] [stderr] Compiling zerocopy v0.8.27 [INFO] [stderr] Checking hashbrown v0.15.5 [INFO] [stderr] Compiling rustversion v1.0.22 [INFO] [stderr] Checking slab v0.4.11 [INFO] [stderr] Checking percent-encoding v2.3.2 [INFO] [stderr] Compiling aws-lc-rs v1.16.0 [INFO] [stderr] Checking rustls-pki-types v1.14.0 [INFO] [stderr] Compiling ahash v0.8.12 [INFO] [stderr] Compiling cfg_aliases v0.1.1 [INFO] [stderr] Checking tracing v0.1.41 [INFO] [stderr] Compiling nix v0.28.0 [INFO] [stderr] Checking inout v0.1.4 [INFO] [stderr] Checking unicode-width v0.1.14 [INFO] [stderr] Checking form_urlencoded v1.2.2 [INFO] [stderr] Compiling cfg_aliases v0.2.1 [INFO] [stderr] Checking rustix v1.0.8 [INFO] [stderr] Checking deranged v0.5.8 [INFO] [stderr] Checking futures-channel v0.3.31 [INFO] [stderr] Compiling nix v0.30.1 [INFO] [stderr] Checking opaque-debug v0.3.1 [INFO] [stderr] Checking anstyle-query v1.1.4 [INFO] [stderr] Compiling serde_json v1.0.143 [INFO] [stderr] Compiling anyhow v1.0.99 [INFO] [stderr] Compiling rustls v0.23.36 [INFO] [stderr] Compiling instability v0.3.9 [INFO] [stderr] Checking anstream v0.6.20 [INFO] [stderr] Checking itertools v0.13.0 [INFO] [stderr] Checking rustix v0.38.44 [INFO] [stderr] Checking nibble_vec v0.1.0 [INFO] [stderr] Checking base64 v0.21.7 [INFO] [stderr] Checking endian-type v0.1.2 [INFO] [stderr] Compiling indoc v2.0.6 [INFO] [stderr] Checking data-encoding v2.9.0 [INFO] [stderr] Checking winnow v0.7.14 [INFO] [stderr] Checking indexmap v2.11.1 [INFO] [stderr] Checking utf-8 v0.7.6 [INFO] [stderr] Checking castaway v0.2.4 [INFO] [stderr] Checking radix_trie v0.2.1 [INFO] [stderr] Checking rustls-pemfile v1.0.4 [INFO] [stderr] Checking compact_str v0.8.1 [INFO] [stderr] Checking lru v0.12.5 [INFO] [stderr] Checking pem v3.0.6 [INFO] [stderr] Checking clap_builder v4.5.47 [INFO] [stderr] Checking crc32fast v1.5.0 [INFO] [stderr] Checking encoding_rs v0.8.35 [INFO] [stderr] Checking time v0.3.47 [INFO] [stderr] Checking cassowary v0.3.0 [INFO] [stderr] Checking ipnet v2.11.0 [INFO] [stderr] Checking fallible-streaming-iterator v0.1.9 [INFO] [stderr] Checking shell-words v1.1.0 [INFO] [stderr] Compiling quote v1.0.40 [INFO] [stderr] Checking downcast-rs v1.2.1 [INFO] [stderr] Checking home v0.5.12 [INFO] [stderr] Checking sync_wrapper v0.1.2 [INFO] [stderr] Compiling syn v2.0.106 [INFO] [stderr] Compiling jobserver v0.1.34 [INFO] [stderr] Checking fallible-iterator v0.3.0 [INFO] [stderr] Checking flate2 v1.1.9 [INFO] [stderr] Checking rustls-pemfile v2.2.0 [INFO] [stderr] Compiling vte_generate_state_changes v0.1.2 [INFO] [stderr] Compiling cc v1.2.56 [INFO] [stderr] Checking yasna v0.5.2 [INFO] [stderr] Checking glob v0.3.3 [INFO] [stderr] Checking ppv-lite86 v0.2.21 [INFO] [stderr] Checking vte v0.11.1 [INFO] [stderr] Checking unicode-truncate v1.1.0 [INFO] [stderr] Checking hashbrown v0.14.5 [INFO] [stderr] Checking vt100 v0.15.2 [INFO] [stderr] Checking hashlink v0.9.1 [INFO] [stderr] Checking getrandom v0.2.16 [INFO] [stderr] Checking signal-hook-registry v1.4.6 [INFO] [stderr] Checking parking_lot_core v0.9.11 [INFO] [stderr] Checking mio v1.0.4 [INFO] [stderr] Checking socket2 v0.6.0 [INFO] [stderr] Checking mio v0.8.11 [INFO] [stderr] Checking socket2 v0.5.10 [INFO] [stderr] Checking signal-hook v0.3.18 [INFO] [stderr] Checking rand_core v0.6.4 [INFO] [stderr] Checking getrandom v0.3.3 [INFO] [stderr] Compiling cmake v0.1.57 [INFO] [stderr] Checking fd-lock v4.0.4 [INFO] [stderr] Checking serial2 v0.2.34 [INFO] [stderr] Checking parking_lot v0.12.4 [INFO] [stderr] Checking dirs-sys v0.4.1 [INFO] [stderr] Checking tempfile v3.21.0 [INFO] [stderr] Checking uuid v1.18.1 [INFO] [stderr] Checking crypto-common v0.1.6 [INFO] [stderr] Checking rand_chacha v0.3.1 [INFO] [stderr] Checking digest v0.10.7 [INFO] [stderr] Checking universal-hash v0.5.1 [INFO] [stderr] Checking cipher v0.4.4 [INFO] [stderr] Checking aead v0.5.2 [INFO] [stderr] Checking dirs v5.0.1 [INFO] [stderr] Checking hostname v0.4.2 [INFO] [stderr] Checking polyval v0.6.2 [INFO] [stderr] Checking sha1 v0.10.6 [INFO] [stderr] Checking hmac v0.12.1 [INFO] [stderr] Checking sha2 v0.10.9 [INFO] [stderr] Checking signal-hook-mio v0.2.4 [INFO] [stderr] Checking crossterm v0.28.1 [INFO] [stderr] Checking crossterm v0.27.0 [INFO] [stderr] Checking ghash v0.5.1 [INFO] [stderr] Checking rand v0.8.5 [INFO] [stderr] Checking aes v0.8.4 [INFO] [stderr] Checking ctr v0.9.2 [INFO] [stderr] Compiling openssl-sys v0.9.109 [INFO] [stderr] Compiling aws-lc-sys v0.37.1 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling libsqlite3-sys v0.30.1 [INFO] [stderr] Compiling atem v0.4.64 (/opt/rustwide/workdir) [INFO] [stderr] Checking ctrlc v3.5.1 [INFO] [stderr] Checking aes-gcm v0.10.3 [INFO] [stderr] Compiling openssl v0.10.73 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Checking rustyline v14.0.0 [INFO] [stderr] Checking rcgen v0.13.2 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.20.11 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.0 [INFO] [stderr] Compiling zerovec-derive v0.11.1 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling serde_derive v1.0.228 [INFO] [stderr] Compiling tokio-macros v2.5.0 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling strum_macros v0.26.4 [INFO] [stderr] Compiling clap_derive v4.5.47 [INFO] [stderr] Checking tokio v1.47.1 [INFO] [stderr] Checking zerofrom v0.1.6 [INFO] [stderr] Checking yoke v0.8.0 [INFO] [stderr] Checking zerovec v0.11.4 [INFO] [stderr] Checking zerotrie v0.2.2 [INFO] [stderr] Checking futures-util v0.3.31 [INFO] [stderr] Compiling darling_macro v0.20.11 [INFO] [stderr] Checking thiserror v1.0.69 [INFO] [stderr] Checking filedescriptor v0.8.3 [INFO] [stderr] Checking portable-pty v0.9.0 [INFO] [stderr] Compiling darling v0.20.11 [INFO] [stderr] Checking clap v4.5.47 [INFO] [stderr] Checking strum v0.26.3 [INFO] [stderr] Checking ratatui v0.29.0 [INFO] [stderr] Checking tinystr v0.8.1 [INFO] [stderr] Checking potential_utf v0.1.3 [INFO] [stderr] Checking serde v1.0.228 [INFO] [stderr] Checking icu_collections v2.0.0 [INFO] [stderr] Checking icu_locale_core v2.0.0 [INFO] [stderr] Checking icu_provider v2.0.0 [INFO] [stderr] Checking serde_spanned v0.6.9 [INFO] [stderr] Checking toml_datetime v0.6.11 [INFO] [stderr] Checking serde_urlencoded v0.7.1 [INFO] [stderr] Checking toml_edit v0.22.27 [INFO] [stderr] Checking icu_normalizer v2.0.0 [INFO] [stderr] Checking icu_properties v2.0.1 [INFO] [stderr] Checking toml v0.8.23 [INFO] [stderr] Checking idna_adapter v1.2.1 [INFO] [stderr] Checking rusqlite v0.32.1 [INFO] [stderr] Checking idna v1.1.0 [INFO] [stderr] Checking url v2.5.7 [INFO] [stderr] Checking tungstenite v0.20.1 [INFO] [stderr] Checking tokio-util v0.7.16 [INFO] [stderr] Checking tokio-native-tls v0.3.1 [INFO] [stderr] Checking h2 v0.3.27 [INFO] [stderr] Checking tokio-tungstenite v0.20.1 [INFO] [stderr] Checking rustls-webpki v0.103.9 [INFO] [stderr] Checking hyper v0.14.32 [INFO] [stderr] Checking hyper-tls v0.5.0 [INFO] [stderr] Checking reqwest v0.11.27 [INFO] [stderr] Checking tokio-rustls v0.26.4 [INFO] [stdout] warning: unused import: `json` [INFO] [stdout] --> src/app.rs:9:25 [INFO] [stdout] | [INFO] [stdout] 9 | use serde_json::{Value, json}; [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: `RtmConfig` [INFO] [stdout] --> src/app.rs:30:36 [INFO] [stdout] | [INFO] [stdout] 30 | use crate::rtm_client::{RtmClient, RtmConfig, RtmEvent}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::token::generate_rtm_token` [INFO] [stdout] --> src/app.rs:31:5 [INFO] [stdout] | [INFO] [stdout] 31 | use crate::token::generate_rtm_token; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `json` [INFO] [stdout] --> src/app.rs:9:25 [INFO] [stdout] | [INFO] [stdout] 9 | use serde_json::{Value, json}; [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: `RtmConfig` [INFO] [stdout] --> src/app.rs:30:36 [INFO] [stdout] | [INFO] [stdout] 30 | use crate::rtm_client::{RtmClient, RtmConfig, RtmEvent}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::token::generate_rtm_token` [INFO] [stdout] --> src/app.rs:31:5 [INFO] [stdout] | [INFO] [stdout] 31 | use crate::token::generate_rtm_token; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `StreamExt` [INFO] [stdout] --> src/acp_client.rs:958:37 [INFO] [stdout] | [INFO] [stdout] 958 | use futures_util::{SinkExt, StreamExt}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `pty_client` [INFO] [stdout] --> src/app.rs:1148:13 [INFO] [stdout] | [INFO] [stdout] 1148 | let pty_client = PtyAgentClient::new(&agent_id, session.sender, session.receiver); [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pty_client` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `relay_ws_url` [INFO] [stdout] --> src/app.rs:1621:17 [INFO] [stdout] | [INFO] [stdout] 1621 | let relay_ws_url = relay_base [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_relay_ws_url` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `SinkExt` [INFO] [stdout] --> src/acp_client.rs:992:28 [INFO] [stdout] | [INFO] [stdout] 992 | use futures_util::{SinkExt, StreamExt}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `pty_client` [INFO] [stdout] --> src/app.rs:1148:13 [INFO] [stdout] | [INFO] [stdout] 1148 | let pty_client = PtyAgentClient::new(&agent_id, session.sender, session.receiver); [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_pty_client` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `relay_ws_url` [INFO] [stdout] --> src/app.rs:1621:17 [INFO] [stdout] | [INFO] [stdout] 1621 | let relay_ws_url = relay_base [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_relay_ws_url` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `AGORA_RTM_TOKEN_TTL_SECS` is never used [INFO] [stdout] --> src/app.rs:37:11 [INFO] [stdout] | [INFO] [stdout] 37 | pub const AGORA_RTM_TOKEN_TTL_SECS: u32 = 3600; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `token`, `channel`, `uid`, and `expires_in` are never read [INFO] [stdout] --> src/app.rs:58:9 [INFO] [stdout] | [INFO] [stdout] 57 | pub struct TokenInfo { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 58 | pub token: String, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 59 | pub channel: String, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] 60 | pub uid: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 61 | pub expires_in: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `TokenInfo` 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: fields `rtm_client`, `rtm_client_id`, and `rtm_token_expires_at` are never read [INFO] [stdout] --> src/app.rs:103:9 [INFO] [stdout] | [INFO] [stdout] 64 | pub struct App { [INFO] [stdout] | --- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 103 | pub rtm_client: Option, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 104 | pub rtm_client_id: String, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 108 | pub rtm_token_expires_at: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `relay_url` is never read [INFO] [stdout] --> src/app.rs:161:9 [INFO] [stdout] | [INFO] [stdout] 159 | pub struct PendingVisualize { [INFO] [stdout] | ---------------- field in this struct [INFO] [stdout] 160 | pub session_id: String, [INFO] [stdout] 161 | pub relay_url: Option, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `PendingVisualize` 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 `ensure_rtm_client`, `handle_rtm_event`, `launch_claude_pty_agent`, and `try_connect_astation` are never used [INFO] [stdout] --> src/app.rs:766:18 [INFO] [stdout] | [INFO] [stdout] 179 | impl App { [INFO] [stdout] | -------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 766 | pub async fn ensure_rtm_client(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 804 | pub fn handle_rtm_event(&mut self, event: RtmEvent) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 1138 | pub async fn launch_claude_pty_agent(&mut self) -> anyhow::Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 1672 | pub async fn try_connect_astation(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `current_timestamp_ms` is never used [INFO] [stdout] --> src/app.rs:2449:8 [INFO] [stdout] | [INFO] [stdout] 2449 | pub fn current_timestamp_ms() -> u64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `has_pending` and `pending_count` are never used [INFO] [stdout] --> src/command.rs:46:12 [INFO] [stdout] | [INFO] [stdout] 10 | impl TaskQueue { [INFO] [stdout] | -------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 46 | pub fn has_pending(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 51 | pub fn pending_count(&self) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `clear` is never used [INFO] [stdout] --> src/command.rs:124:12 [INFO] [stdout] | [INFO] [stdout] 76 | impl StreamBuffer { [INFO] [stdout] | ----------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 124 | pub fn clear(&mut self) { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `received_at_ms` and `kind` are never read [INFO] [stdout] --> src/dispatch.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 19 | pub struct WorkItem { [INFO] [stdout] | -------- fields in this struct [INFO] [stdout] 20 | pub task_id: String, [INFO] [stdout] 21 | pub received_at_ms: u64, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 22 | pub kind: WorkKind, [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `WorkItem` 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: constant `DEFAULT_SERVER_URL` is never used [INFO] [stdout] --> src/auth.rs:6:7 [INFO] [stdout] | [INFO] [stdout] 6 | const DEFAULT_SERVER_URL: &str = "https://station.agora.build"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `age_seconds` is never used [INFO] [stdout] --> src/auth.rs:46:12 [INFO] [stdout] | [INFO] [stdout] 19 | impl AuthSession { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 46 | pub fn age_seconds(&self) -> u64 { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `remove`, `active_sessions`, and `cleanup_expired` are never used [INFO] [stdout] --> src/auth.rs:122:12 [INFO] [stdout] | [INFO] [stdout] 66 | impl SessionManager { [INFO] [stdout] | ------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 122 | pub fn remove(&mut self, astation_id: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 128 | pub fn active_sessions(&self) -> Vec<&AuthSession> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 133 | pub fn cleanup_expired(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_deep_link` is never used [INFO] [stdout] --> src/auth.rs:154:8 [INFO] [stdout] | [INFO] [stdout] 154 | pub fn build_deep_link(session_id: &str, hostname: &str, otp: &str) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_web_fallback_url` is never used [INFO] [stdout] --> src/auth.rs:162:8 [INFO] [stdout] | [INFO] [stdout] 162 | pub fn build_web_fallback_url(server_url: &str, session_id: &str, hostname: &str) -> String { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `open_url` is never used [INFO] [stdout] --> src/auth.rs:180:8 [INFO] [stdout] | [INFO] [stdout] 180 | pub fn open_url(url: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `create_server_session` is never used [INFO] [stdout] --> src/auth.rs:199:14 [INFO] [stdout] | [INFO] [stdout] 199 | pub async fn create_server_session( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `poll_session_status` is never used [INFO] [stdout] --> src/auth.rs:234:14 [INFO] [stdout] | [INFO] [stdout] 234 | pub async fn poll_session_status( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `run_login_flow` is never used [INFO] [stdout] --> src/auth.rs:303:14 [INFO] [stdout] | [INFO] [stdout] 303 | pub async fn run_login_flow(server_url: Option<&str>, astation_id: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `rtm_channel` is never used [INFO] [stdout] --> src/config.rs:280:12 [INFO] [stdout] | [INFO] [stdout] 54 | impl AtemConfig { [INFO] [stdout] | --------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 280 | pub fn rtm_channel(&self) -> &str { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `delete` is never used [INFO] [stdout] --> src/config.rs:547:12 [INFO] [stdout] | [INFO] [stdout] 474 | impl CredentialStore { [INFO] [stdout] | -------------------- associated function in this implementation [INFO] [stdout] ... [INFO] [stdout] 547 | pub fn delete() -> Result<()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AtemRtmConfig` is never constructed [INFO] [stdout] --> src/rtm_client.rs:17:8 [INFO] [stdout] | [INFO] [stdout] 17 | struct AtemRtmConfig { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `AtemRtmMessageCallback` is never used [INFO] [stdout] --> src/rtm_client.rs:24:6 [INFO] [stdout] | [INFO] [stdout] 24 | type AtemRtmMessageCallback = unsafe extern "C" fn( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `from` and `payload` are never read [INFO] [stdout] --> src/rtm_client.rs:61:9 [INFO] [stdout] | [INFO] [stdout] 60 | pub struct RtmEvent { [INFO] [stdout] | -------- fields in this struct [INFO] [stdout] 61 | pub from: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] 62 | pub payload: String, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `sender` is never read [INFO] [stdout] --> src/rtm_client.rs:66:5 [INFO] [stdout] | [INFO] [stdout] 65 | struct CallbackState { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] 66 | sender: UnboundedSender, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new` and `as_ptr` are never used [INFO] [stdout] --> src/rtm_client.rs:72:8 [INFO] [stdout] | [INFO] [stdout] 71 | impl OwnedCString { [INFO] [stdout] | ----------------- associated items in this implementation [INFO] [stdout] 72 | fn new(value: CString) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 76 | fn as_ptr(&self) -> *const c_char { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `on_message` is never used [INFO] [stdout] --> src/rtm_client.rs:92:22 [INFO] [stdout] | [INFO] [stdout] 92 | unsafe extern "C" fn on_message( [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `inner`, `receiver`, and `owned_strings` are never read [INFO] [stdout] --> src/rtm_client.rs:121:5 [INFO] [stdout] | [INFO] [stdout] 120 | pub struct RtmClient { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 121 | inner: Arc>, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 122 | receiver: Mutex>, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 123 | _state: *mut CallbackState, [INFO] [stdout] 124 | owned_strings: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RtmConfig` is never constructed [INFO] [stdout] --> src/rtm_client.rs:154:12 [INFO] [stdout] | [INFO] [stdout] 154 | pub struct RtmConfig { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/rtm_client.rs:162:12 [INFO] [stdout] | [INFO] [stdout] 161 | impl RtmClient { [INFO] [stdout] | -------------- associated items in this implementation [INFO] [stdout] 162 | pub fn new(config: RtmConfig) -> Result { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 212 | pub async fn publish_channel(&self, payload: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 222 | pub async fn login_and_join(&self, token: &str, account: &str, channel: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 247 | pub async fn send_peer(&self, target: &str, payload: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 258 | pub async fn next_event(&self) -> Option { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 263 | pub async fn drain_events(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 276 | pub async fn set_token(&self, token: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 286 | pub async fn subscribe_topic(&self, channel: &str, topic: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 302 | pub async fn disconnect(&self) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_create` is never used [INFO] [stdout] --> src/rtm_client.rs:32:8 [INFO] [stdout] | [INFO] [stdout] 32 | fn atem_rtm_create( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_connect` is never used [INFO] [stdout] --> src/rtm_client.rs:38:8 [INFO] [stdout] | [INFO] [stdout] 38 | fn atem_rtm_connect(client: *mut AtemRtmClient) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_login` is never used [INFO] [stdout] --> src/rtm_client.rs:40:8 [INFO] [stdout] | [INFO] [stdout] 40 | fn atem_rtm_login( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_join_channel` is never used [INFO] [stdout] --> src/rtm_client.rs:45:8 [INFO] [stdout] | [INFO] [stdout] 45 | fn atem_rtm_join_channel(client: *mut AtemRtmClient, channel_id: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_publish_channel` is never used [INFO] [stdout] --> src/rtm_client.rs:46:8 [INFO] [stdout] | [INFO] [stdout] 46 | fn atem_rtm_publish_channel(client: *mut AtemRtmClient, payload: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_send_peer` is never used [INFO] [stdout] --> src/rtm_client.rs:47:8 [INFO] [stdout] | [INFO] [stdout] 47 | fn atem_rtm_send_peer( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_set_token` is never used [INFO] [stdout] --> src/rtm_client.rs:52:8 [INFO] [stdout] | [INFO] [stdout] 52 | fn atem_rtm_set_token(client: *mut AtemRtmClient, token: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_subscribe_topic` is never used [INFO] [stdout] --> src/rtm_client.rs:53:8 [INFO] [stdout] | [INFO] [stdout] 53 | fn atem_rtm_subscribe_topic( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `invalidate` is never used [INFO] [stdout] --> src/time_sync.rs:80:12 [INFO] [stdout] | [INFO] [stdout] 11 | impl TimeSync { [INFO] [stdout] | ------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 80 | pub fn invalidate(&mut self) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `generate_rtm_token` is never used [INFO] [stdout] --> src/token.rs:437:8 [INFO] [stdout] | [INFO] [stdout] 437 | pub fn generate_rtm_token( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `md5_simple` is never used [INFO] [stdout] --> src/token.rs:456:4 [INFO] [stdout] | [INFO] [stdout] 456 | fn md5_simple(data: &[u8]) -> u128 { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `LOW_THRESHOLD` is never used [INFO] [stdout] --> src/tui/voice_fx.rs:4:7 [INFO] [stdout] | [INFO] [stdout] 4 | const LOW_THRESHOLD: f32 = 0.3; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `HIGH_THRESHOLD` is never used [INFO] [stdout] --> src/tui/voice_fx.rs:5:7 [INFO] [stdout] | [INFO] [stdout] 5 | const HIGH_THRESHOLD: f32 = 0.6; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `border_chars` is never used [INFO] [stdout] --> src/tui/voice_fx.rs:11:8 [INFO] [stdout] | [INFO] [stdout] 11 | pub fn border_chars(volume: f32) -> (&'static str, &'static str) { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `border_color` is never used [INFO] [stdout] --> src/tui/voice_fx.rs:26:8 [INFO] [stdout] | [INFO] [stdout] 26 | pub fn border_color(volume: f32) -> Color { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `border_jitter` is never used [INFO] [stdout] --> src/tui/voice_fx.rs:44:8 [INFO] [stdout] | [INFO] [stdout] 44 | pub fn border_jitter(volume: f32, tick: u64) -> i16 { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `lerp` is never used [INFO] [stdout] --> src/tui/voice_fx.rs:58:4 [INFO] [stdout] | [INFO] [stdout] 58 | fn lerp(a: u8, b: u8, t: f32) -> u8 { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/websocket_client.rs:543:18 [INFO] [stdout] | [INFO] [stdout] 263 | impl AstationClient { [INFO] [stdout] | ------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 543 | pub async fn request_projects(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 547 | pub async fn request_token( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 561 | pub async fn launch_claude(&self, context: Option) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 566 | pub async fn send_user_command( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 578 | pub async fn send_status_update(&self, status: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 590 | pub async fn send_heartbeat(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 601 | pub fn is_connected(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 649 | pub async fn send_codex_task( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 725 | pub async fn send_agent_status( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `JsonRpcNotification` is never constructed [INFO] [stdout] --> src/acp_client.rs:38:12 [INFO] [stdout] | [INFO] [stdout] 38 | pub struct JsonRpcNotification { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_cancel_request` is never used [INFO] [stdout] --> src/acp_client.rs:103:8 [INFO] [stdout] | [INFO] [stdout] 103 | pub fn build_cancel_request(id: u64, session_id: &str) -> JsonRpcRequest { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `url` is never read [INFO] [stdout] --> src/acp_client.rs:250:5 [INFO] [stdout] | [INFO] [stdout] 249 | pub struct AcpClient { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] 250 | url: String, [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `url`, `is_connected`, and `cancel` are never used [INFO] [stdout] --> src/acp_client.rs:317:12 [INFO] [stdout] | [INFO] [stdout] 262 | impl AcpClient { [INFO] [stdout] | -------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 317 | pub fn url(&self) -> &str { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 325 | pub fn is_connected(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 429 | pub fn cancel(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `Disconnected` is never constructed [INFO] [stdout] --> src/agent_client.rs:111:5 [INFO] [stdout] | [INFO] [stdout] 95 | pub enum AgentEvent { [INFO] [stdout] | ---------- variant in this enum [INFO] [stdout] ... [INFO] [stdout] 111 | Disconnected, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `AgentEvent` 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 `PtyAgentClient` is never constructed [INFO] [stdout] --> src/agent_client.rs:121:12 [INFO] [stdout] | [INFO] [stdout] 121 | pub struct PtyAgentClient { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new`, `send_prompt`, and `drain_events` are never used [INFO] [stdout] --> src/agent_client.rs:131:12 [INFO] [stdout] | [INFO] [stdout] 130 | impl PtyAgentClient { [INFO] [stdout] | ------------------- associated items in this implementation [INFO] [stdout] 131 | pub fn new( [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 144 | pub fn send_prompt(&self, prompt: &str) -> anyhow::Result<()> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 151 | pub fn drain_events(&mut self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `lockfile` is never read [INFO] [stdout] --> src/agent_detector.rs:44:9 [INFO] [stdout] | [INFO] [stdout] 36 | pub struct DetectedAgent { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 44 | pub lockfile: PathBuf, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `DetectedAgent` 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 `is_acp` is never used [INFO] [stdout] --> src/agent_detector.rs:168:12 [INFO] [stdout] | [INFO] [stdout] 167 | impl ProbeResult { [INFO] [stdout] | ---------------- method in this implementation [INFO] [stdout] 168 | pub fn is_acp(&self) -> bool { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `add_session`, `remove_session`, `remove`, `len`, `is_empty`, and `connected` are never used [INFO] [stdout] --> src/agent_registry.rs:57:12 [INFO] [stdout] | [INFO] [stdout] 24 | impl AgentRegistry { [INFO] [stdout] | ------------------ methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 57 | pub fn add_session(&self, agent_id: &str, session_id: &str) { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 66 | pub fn remove_session(&self, agent_id: &str, session_id: &str) { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 73 | pub fn remove(&self, id: &str) { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 87 | pub fn len(&self) -> usize { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 92 | pub fn is_empty(&self) -> bool { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 97 | pub fn connected(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `id`, `topic`, and `created_at` are never read [INFO] [stdout] --> src/diagram_server.rs:22:9 [INFO] [stdout] | [INFO] [stdout] 21 | pub struct DiagramEntry { [INFO] [stdout] | ------------ fields in this struct [INFO] [stdout] 22 | pub id: String, [INFO] [stdout] | ^^ [INFO] [stdout] 23 | pub topic: String, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 24 | pub html: Vec, [INFO] [stdout] 25 | pub created_at: i64, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `AGORA_RTM_TOKEN_TTL_SECS` is never used [INFO] [stdout] --> src/app.rs:37:11 [INFO] [stdout] | [INFO] [stdout] 37 | pub const AGORA_RTM_TOKEN_TTL_SECS: u32 = 3600; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `token`, `channel`, `uid`, and `expires_in` are never read [INFO] [stdout] --> src/app.rs:58:9 [INFO] [stdout] | [INFO] [stdout] 57 | pub struct TokenInfo { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 58 | pub token: String, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 59 | pub channel: String, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] 60 | pub uid: String, [INFO] [stdout] | ^^^ [INFO] [stdout] 61 | pub expires_in: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `TokenInfo` 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: fields `rtm_client`, `rtm_client_id`, and `rtm_token_expires_at` are never read [INFO] [stdout] --> src/app.rs:103:9 [INFO] [stdout] | [INFO] [stdout] 64 | pub struct App { [INFO] [stdout] | --- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 103 | pub rtm_client: Option, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] 104 | pub rtm_client_id: String, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 108 | pub rtm_token_expires_at: Option, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `ensure_rtm_client`, `handle_rtm_event`, `launch_claude_pty_agent`, and `try_connect_astation` are never used [INFO] [stdout] --> src/app.rs:766:18 [INFO] [stdout] | [INFO] [stdout] 179 | impl App { [INFO] [stdout] | -------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 766 | pub async fn ensure_rtm_client(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 804 | pub fn handle_rtm_event(&mut self, event: RtmEvent) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 1138 | pub async fn launch_claude_pty_agent(&mut self) -> anyhow::Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 1672 | pub async fn try_connect_astation(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `current_timestamp_ms` is never used [INFO] [stdout] --> src/app.rs:2449:8 [INFO] [stdout] | [INFO] [stdout] 2449 | pub fn current_timestamp_ms() -> u64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `received_at_ms` and `kind` are never read [INFO] [stdout] --> src/dispatch.rs:21:9 [INFO] [stdout] | [INFO] [stdout] 19 | pub struct WorkItem { [INFO] [stdout] | -------- fields in this struct [INFO] [stdout] 20 | pub task_id: String, [INFO] [stdout] 21 | pub received_at_ms: u64, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 22 | pub kind: WorkKind, [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `WorkItem` 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: constant `DEFAULT_SERVER_URL` is never used [INFO] [stdout] --> src/auth.rs:6:7 [INFO] [stdout] | [INFO] [stdout] 6 | const DEFAULT_SERVER_URL: &str = "https://station.agora.build"; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `remove` and `cleanup_expired` are never used [INFO] [stdout] --> src/auth.rs:122:12 [INFO] [stdout] | [INFO] [stdout] 66 | impl SessionManager { [INFO] [stdout] | ------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 122 | pub fn remove(&mut self, astation_id: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 133 | pub fn cleanup_expired(&mut self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `open_url` is never used [INFO] [stdout] --> src/auth.rs:180:8 [INFO] [stdout] | [INFO] [stdout] 180 | pub fn open_url(url: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `run_login_flow` is never used [INFO] [stdout] --> src/auth.rs:303:14 [INFO] [stdout] | [INFO] [stdout] 303 | pub async fn run_login_flow(server_url: Option<&str>, astation_id: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `cli_logout_parses` is never used [INFO] [stdout] --> src/cli.rs:1122:8 [INFO] [stdout] | [INFO] [stdout] 1122 | fn cli_logout_parses() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `delete` is never used [INFO] [stdout] --> src/config.rs:547:12 [INFO] [stdout] | [INFO] [stdout] 474 | impl CredentialStore { [INFO] [stdout] | -------------------- associated function in this implementation [INFO] [stdout] ... [INFO] [stdout] 547 | pub fn delete() -> Result<()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `AtemRtmConfig` is never constructed [INFO] [stdout] --> src/rtm_client.rs:17:8 [INFO] [stdout] | [INFO] [stdout] 17 | struct AtemRtmConfig { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `AtemRtmMessageCallback` is never used [INFO] [stdout] --> src/rtm_client.rs:24:6 [INFO] [stdout] | [INFO] [stdout] 24 | type AtemRtmMessageCallback = unsafe extern "C" fn( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `from` and `payload` are never read [INFO] [stdout] --> src/rtm_client.rs:61:9 [INFO] [stdout] | [INFO] [stdout] 60 | pub struct RtmEvent { [INFO] [stdout] | -------- fields in this struct [INFO] [stdout] 61 | pub from: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] 62 | pub payload: String, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `sender` is never read [INFO] [stdout] --> src/rtm_client.rs:66:5 [INFO] [stdout] | [INFO] [stdout] 65 | struct CallbackState { [INFO] [stdout] | ------------- field in this struct [INFO] [stdout] 66 | sender: UnboundedSender, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new` and `as_ptr` are never used [INFO] [stdout] --> src/rtm_client.rs:72:8 [INFO] [stdout] | [INFO] [stdout] 71 | impl OwnedCString { [INFO] [stdout] | ----------------- associated items in this implementation [INFO] [stdout] 72 | fn new(value: CString) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 76 | fn as_ptr(&self) -> *const c_char { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `on_message` is never used [INFO] [stdout] --> src/rtm_client.rs:92:22 [INFO] [stdout] | [INFO] [stdout] 92 | unsafe extern "C" fn on_message( [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `inner`, `receiver`, and `owned_strings` are never read [INFO] [stdout] --> src/rtm_client.rs:121:5 [INFO] [stdout] | [INFO] [stdout] 120 | pub struct RtmClient { [INFO] [stdout] | --------- fields in this struct [INFO] [stdout] 121 | inner: Arc>, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 122 | receiver: Mutex>, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] 123 | _state: *mut CallbackState, [INFO] [stdout] 124 | owned_strings: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `RtmConfig` is never constructed [INFO] [stdout] --> src/rtm_client.rs:154:12 [INFO] [stdout] | [INFO] [stdout] 154 | pub struct RtmConfig { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/rtm_client.rs:162:12 [INFO] [stdout] | [INFO] [stdout] 161 | impl RtmClient { [INFO] [stdout] | -------------- associated items in this implementation [INFO] [stdout] 162 | pub fn new(config: RtmConfig) -> Result { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 212 | pub async fn publish_channel(&self, payload: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 222 | pub async fn login_and_join(&self, token: &str, account: &str, channel: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 247 | pub async fn send_peer(&self, target: &str, payload: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 258 | pub async fn next_event(&self) -> Option { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 263 | pub async fn drain_events(&self) -> Vec { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 276 | pub async fn set_token(&self, token: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 286 | pub async fn subscribe_topic(&self, channel: &str, topic: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 302 | pub async fn disconnect(&self) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_create` is never used [INFO] [stdout] --> src/rtm_client.rs:32:8 [INFO] [stdout] | [INFO] [stdout] 32 | fn atem_rtm_create( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_connect` is never used [INFO] [stdout] --> src/rtm_client.rs:38:8 [INFO] [stdout] | [INFO] [stdout] 38 | fn atem_rtm_connect(client: *mut AtemRtmClient) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_login` is never used [INFO] [stdout] --> src/rtm_client.rs:40:8 [INFO] [stdout] | [INFO] [stdout] 40 | fn atem_rtm_login( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_join_channel` is never used [INFO] [stdout] --> src/rtm_client.rs:45:8 [INFO] [stdout] | [INFO] [stdout] 45 | fn atem_rtm_join_channel(client: *mut AtemRtmClient, channel_id: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_publish_channel` is never used [INFO] [stdout] --> src/rtm_client.rs:46:8 [INFO] [stdout] | [INFO] [stdout] 46 | fn atem_rtm_publish_channel(client: *mut AtemRtmClient, payload: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_send_peer` is never used [INFO] [stdout] --> src/rtm_client.rs:47:8 [INFO] [stdout] | [INFO] [stdout] 47 | fn atem_rtm_send_peer( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_set_token` is never used [INFO] [stdout] --> src/rtm_client.rs:52:8 [INFO] [stdout] | [INFO] [stdout] 52 | fn atem_rtm_set_token(client: *mut AtemRtmClient, token: *const c_char) -> i32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `atem_rtm_subscribe_topic` is never used [INFO] [stdout] --> src/rtm_client.rs:53:8 [INFO] [stdout] | [INFO] [stdout] 53 | fn atem_rtm_subscribe_topic( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `invalidate` is never used [INFO] [stdout] --> src/time_sync.rs:80:12 [INFO] [stdout] | [INFO] [stdout] 11 | impl TimeSync { [INFO] [stdout] | ------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 80 | pub fn invalidate(&mut self) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple methods are never used [INFO] [stdout] --> src/websocket_client.rs:543:18 [INFO] [stdout] | [INFO] [stdout] 263 | impl AstationClient { [INFO] [stdout] | ------------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 543 | pub async fn request_projects(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 547 | pub async fn request_token( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 561 | pub async fn launch_claude(&self, context: Option) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 566 | pub async fn send_user_command( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 578 | pub async fn send_status_update(&self, status: &str) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 590 | pub async fn send_heartbeat(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 601 | pub fn is_connected(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 649 | pub async fn send_codex_task( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 725 | pub async fn send_agent_status( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `JsonRpcNotification` is never constructed [INFO] [stdout] --> src/acp_client.rs:38:12 [INFO] [stdout] | [INFO] [stdout] 38 | pub struct JsonRpcNotification { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `agent_id` is never read [INFO] [stdout] --> src/agent_client.rs:127:9 [INFO] [stdout] | [INFO] [stdout] 121 | pub struct PtyAgentClient { [INFO] [stdout] | -------------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 127 | pub agent_id: String, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 17s [INFO] running `Command { std: "docker" "inspect" "fe3ee49ebee26b9de5638d25e5157994268c6d9d80ec785cfbc5c04393c79960", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "fe3ee49ebee26b9de5638d25e5157994268c6d9d80ec785cfbc5c04393c79960", kill_on_drop: false }` [INFO] [stdout] fe3ee49ebee26b9de5638d25e5157994268c6d9d80ec785cfbc5c04393c79960