[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<RtmClient>,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 104 |     pub rtm_client_id: String,
[INFO] [stdout]     |         ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 108 |     pub rtm_token_expires_at: Option<Instant>,
[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<String>,
[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<String> {
[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<AuthSession> {
[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<RtmEvent>,
[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<Mutex<RtmInner>>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 122 |     receiver: Mutex<UnboundedReceiver<RtmEvent>>,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 123 |     _state: *mut CallbackState,
[INFO] [stdout] 124 |     owned_strings: Vec<OwnedCString>,
[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<Self> {
[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<RtmEvent> {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     pub async fn drain_events(&self) -> Vec<RtmEvent> {
[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<String>) -> 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<AgentEvent> {
[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<AgentInfo> {
[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<u8>,
[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<RtmClient>,
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 104 |     pub rtm_client_id: String,
[INFO] [stdout]     |         ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 108 |     pub rtm_token_expires_at: Option<Instant>,
[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<String> {
[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<AuthSession> {
[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<RtmEvent>,
[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<Mutex<RtmInner>>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 122 |     receiver: Mutex<UnboundedReceiver<RtmEvent>>,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 123 |     _state: *mut CallbackState,
[INFO] [stdout] 124 |     owned_strings: Vec<OwnedCString>,
[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<Self> {
[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<RtmEvent> {
[INFO] [stdout]     |                  ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     pub async fn drain_events(&self) -> Vec<RtmEvent> {
[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<String>) -> 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
