[INFO] fetching crate xtalk 0.0.1-alpha.3...
[INFO] checking xtalk-0.0.1-alpha.3 against try#b1f2594eac607c1f051534800237eeedb5590a49 for pr-139493-3
[INFO] extracting crate xtalk 0.0.1-alpha.3 into /workspace/builds/worker-5-tc2/source
[INFO] started tweaking crates.io crate xtalk 0.0.1-alpha.3
[INFO] finished tweaking crates.io crate xtalk 0.0.1-alpha.3
[INFO] tweaked toml for crates.io crate xtalk 0.0.1-alpha.3 written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate xtalk 0.0.1-alpha.3 on toolchain b1f2594eac607c1f051534800237eeedb5590a49
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b1f2594eac607c1f051534800237eeedb5590a49" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate xtalk 0.0.1-alpha.3 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" "+b1f2594eac607c1f051534800237eeedb5590a49" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+b1f2594eac607c1f051534800237eeedb5590a49" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 27835ccea2a3c7fb5810ded67916ae1f0bf1fee0db6d9058cd7c0dd6708adb54
[INFO] running `Command { std: "docker" "start" "-a" "27835ccea2a3c7fb5810ded67916ae1f0bf1fee0db6d9058cd7c0dd6708adb54", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "27835ccea2a3c7fb5810ded67916ae1f0bf1fee0db6d9058cd7c0dd6708adb54", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "27835ccea2a3c7fb5810ded67916ae1f0bf1fee0db6d9058cd7c0dd6708adb54", kill_on_drop: false }`
[INFO] [stdout] 27835ccea2a3c7fb5810ded67916ae1f0bf1fee0db6d9058cd7c0dd6708adb54
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+b1f2594eac607c1f051534800237eeedb5590a49" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c4cb9145cde1198cb91f2703089d313e72e0ad02c02119654d97685c82eb4dc1
[INFO] running `Command { std: "docker" "start" "-a" "c4cb9145cde1198cb91f2703089d313e72e0ad02c02119654d97685c82eb4dc1", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.85
[INFO] [stderr]    Compiling cc v1.0.99
[INFO] [stderr]     Checking litemap v0.7.3
[INFO] [stderr]     Checking signal-hook-registry v1.4.2
[INFO] [stderr]     Checking mio v0.8.11
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking socket2 v0.5.7
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]    Compiling signal-hook v0.3.17
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]    Compiling thiserror v1.0.63
[INFO] [stderr]     Checking winnow v0.6.18
[INFO] [stderr]     Checking rustls-pki-types v1.7.0
[INFO] [stderr]     Checking either v1.13.0
[INFO] [stderr]     Checking clap_builder v4.5.9
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking nu-ansi-term v0.50.0
[INFO] [stderr]     Checking unicode-segmentation v1.11.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking rustls-pemfile v2.1.2
[INFO] [stderr]     Checking itertools v0.12.1
[INFO] [stderr]     Checking signal-hook-mio v0.2.3
[INFO] [stderr]    Compiling quote v1.0.36
[INFO] [stderr]    Compiling syn v2.0.66
[INFO] [stderr]    Compiling vte_generate_state_changes v0.1.2
[INFO] [stderr]    Compiling openssl-sys v0.9.102
[INFO] [stderr]     Checking vte v0.11.1
[INFO] [stderr]    Compiling openssl v0.10.64
[INFO] [stderr]    Compiling native-tls v0.2.12
[INFO] [stderr]     Checking strip-ansi-escapes v0.2.0
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling serde_derive v1.0.203
[INFO] [stderr]    Compiling zerofrom-derive v0.1.4
[INFO] [stderr]    Compiling yoke-derive v0.7.4
[INFO] [stderr]    Compiling zerovec-derive v0.10.2
[INFO] [stderr]    Compiling displaydoc v0.2.4
[INFO] [stderr]    Compiling tokio-macros v2.3.0
[INFO] [stderr]    Compiling icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling pin-project-internal v1.1.5
[INFO] [stderr]    Compiling zerocopy-derive v0.6.6
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling thiserror-impl v1.0.63
[INFO] [stderr]    Compiling clap_derive v4.5.8
[INFO] [stderr]    Compiling async-trait v0.1.80
[INFO] [stderr]     Checking zerocopy v0.6.6
[INFO] [stderr]     Checking tokio v1.38.0
[INFO] [stderr]     Checking zerofrom v0.1.4
[INFO] [stderr]     Checking yoke v0.7.4
[INFO] [stderr]     Checking pin-project v1.1.5
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]     Checking ppv-lite86 v0.2.18
[INFO] [stderr]     Checking zerovec v0.10.2
[INFO] [stderr]     Checking clap v4.5.9
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking tinystr v0.7.6
[INFO] [stderr]     Checking icu_collections v1.5.0
[INFO] [stderr]     Checking icu_locid v1.5.0
[INFO] [stderr]     Checking serde v1.0.203
[INFO] [stderr]     Checking icu_provider v1.5.0
[INFO] [stderr]     Checking icu_locid_transform v1.5.0
[INFO] [stderr]     Checking icu_properties v1.5.0
[INFO] [stderr]     Checking bitflags v2.5.0
[INFO] [stderr]     Checking toml_datetime v0.6.8
[INFO] [stderr]     Checking serde_spanned v0.6.7
[INFO] [stderr]     Checking serde_json v1.0.117
[INFO] [stderr]     Checking chrono v0.4.38
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking rustix v0.38.34
[INFO] [stderr]     Checking crossterm v0.27.0
[INFO] [stderr]     Checking toml_edit v0.22.20
[INFO] [stderr]     Checking tokio-util v0.7.11
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking icu_normalizer v1.5.0
[INFO] [stderr]     Checking h2 v0.4.5
[INFO] [stderr]     Checking idna v1.0.0
[INFO] [stderr]     Checking url v2.5.1
[INFO] [stderr]     Checking toml v0.8.19
[INFO] [stderr]     Checking fd-lock v4.0.2
[INFO] [stderr]     Checking reedline v0.32.0
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking hyper v1.3.1
[INFO] [stderr]     Checking hyper-util v0.1.5
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking reqwest v0.12.4
[INFO] [stderr]     Checking xtalk v0.0.1-alpha.3 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Color`
[INFO] [stdout]  --> src/cli/chat/prompt.rs:3:11
[INFO] [stdout]   |
[INFO] [stdout] 3 |     self, Color, PromptEditMode, PromptHistorySearch, PromptHistorySearchStatus, PromptViMode,
[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: `Keybindings`
[INFO] [stdout]  --> src/cli/chat/repl.rs:9:19
[INFO] [stdout]   |
[INFO] [stdout] 9 |     KeyModifiers, Keybindings, ReedlineEvent, ReedlineMenu,
[INFO] [stdout]   |                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DefaultPromptSegment` and `DefaultPrompt`
[INFO] [stdout]   --> src/cli/chat/repl.rs:12:67
[INFO] [stdout]    |
[INFO] [stdout] 12 |     default_vi_insert_keybindings, default_vi_normal_keybindings, DefaultPrompt,
[INFO] [stdout]    |                                                                   ^^^^^^^^^^^^^
[INFO] [stdout] 13 |     DefaultPromptSegment, EditCommand, MenuBuilder, Reedline, Signal, Vi,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]   --> src/cli/chat/repl.rs:18:21
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crate::{config, warn};
[INFO] [stdout]    |                     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> src/cli/chat.rs:20:33
[INFO] [stdout]    |
[INFO] [stdout] 20 | use crate::registry::registry::{self, ModelSpec, Registry};
[INFO] [stdout]    |                                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::default`
[INFO] [stdout]  --> src/config.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::default;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> src/providers/ollama/api.rs:239:9
[INFO] [stdout]     |
[INFO] [stdout] 239 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> src/providers/openai/api.rs:313:9
[INFO] [stdout]     |
[INFO] [stdout] 313 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json`
[INFO] [stdout]    --> src/providers/openai/api.rs:314:9
[INFO] [stdout]     |
[INFO] [stdout] 314 |     use serde_json;
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::default`
[INFO] [stdout]  --> src/registry/registry.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::default;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ModelResolver`, `ModelSpec`, `ProvidedDefaultModel`, `ProvidedModel`, and `Registry`
[INFO] [stdout]   --> src/registry.rs:33:16
[INFO] [stdout]    |
[INFO] [stdout] 33 | use registry::{ModelResolver, ModelSpec, ProvidedDefaultModel, ProvidedModel, Registry};
[INFO] [stdout]    |                ^^^^^^^^^^^^^  ^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Color`
[INFO] [stdout]  --> src/cli/chat/prompt.rs:3:11
[INFO] [stdout]   |
[INFO] [stdout] 3 |     self, Color, PromptEditMode, PromptHistorySearch, PromptHistorySearchStatus, PromptViMode,
[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: `Keybindings`
[INFO] [stdout]  --> src/cli/chat/repl.rs:9:19
[INFO] [stdout]   |
[INFO] [stdout] 9 |     KeyModifiers, Keybindings, ReedlineEvent, ReedlineMenu,
[INFO] [stdout]   |                   ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DefaultPromptSegment` and `DefaultPrompt`
[INFO] [stdout]   --> src/cli/chat/repl.rs:12:67
[INFO] [stdout]    |
[INFO] [stdout] 12 |     default_vi_insert_keybindings, default_vi_normal_keybindings, DefaultPrompt,
[INFO] [stdout]    |                                                                   ^^^^^^^^^^^^^
[INFO] [stdout] 13 |     DefaultPromptSegment, EditCommand, MenuBuilder, Reedline, Signal, Vi,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]   --> src/cli/chat/repl.rs:18:21
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crate::{config, warn};
[INFO] [stdout]    |                     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> src/cli/chat.rs:20:33
[INFO] [stdout]    |
[INFO] [stdout] 20 | use crate::registry::registry::{self, ModelSpec, Registry};
[INFO] [stdout]    |                                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::default`
[INFO] [stdout]  --> src/config.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::default;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::result`
[INFO] [stdout]    --> src/providers/apireq/json_stream_parser.rs:301:9
[INFO] [stdout]     |
[INFO] [stdout] 301 |     use std::result;
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json`
[INFO] [stdout]    --> src/providers/openai/api.rs:314:9
[INFO] [stdout]     |
[INFO] [stdout] 314 |     use serde_json;
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::default`
[INFO] [stdout]  --> src/registry/registry.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::default;
[INFO] [stdout]   |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ModelResolver`, `ModelSpec`, `ProvidedDefaultModel`, `ProvidedModel`, and `Registry`
[INFO] [stdout]   --> src/registry.rs:33:16
[INFO] [stdout]    |
[INFO] [stdout] 33 | use registry::{ModelResolver, ModelSpec, ProvidedDefaultModel, ProvidedModel, Registry};
[INFO] [stdout]    |                ^^^^^^^^^^^^^  ^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cursor`
[INFO] [stdout]  --> src/cli/chat/highlighter.rs:7:37
[INFO] [stdout]   |
[INFO] [stdout] 7 |     fn highlight(&self, line: &str, cursor: usize) -> reedline::StyledText {
[INFO] [stdout]   |                                     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_cursor`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cursor`
[INFO] [stdout]  --> src/cli/chat/highlighter.rs:7:37
[INFO] [stdout]   |
[INFO] [stdout] 7 |     fn highlight(&self, line: &str, cursor: usize) -> reedline::StyledText {
[INFO] [stdout]   |                                     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_cursor`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Standard` is never constructed
[INFO] [stdout]   --> src/cli/chat.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub(crate) enum Severity {
[INFO] [stdout]    |                 -------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 29 |     Standard,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `output`, `model`, and `system` are never used
[INFO] [stdout]   --> src/cli/chat.rs:47:19
[INFO] [stdout]    |
[INFO] [stdout] 38 | impl Message {
[INFO] [stdout]    | ------------ associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub(crate) fn output(msg: String) -> Message {
[INFO] [stdout]    |                   ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub(crate) fn model(msg: String, model_id: String) -> Message {
[INFO] [stdout]    |                   ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub(crate) fn system(msg: String) -> Message {
[INFO] [stdout]    |                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `with_style` are never used
[INFO] [stdout]   --> src/cli/list/table.rs:45:19
[INFO] [stdout]    |
[INFO] [stdout] 44 | impl Cell {
[INFO] [stdout]    | --------- associated items in this implementation
[INFO] [stdout] 45 |     pub(crate) fn new(content: String, style: Style) -> Cell {
[INFO] [stdout]    |                   ^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub(crate) fn with_style(mut self, style: Style) -> Self {
[INFO] [stdout]    |                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `IntoCell` is never used
[INFO] [stdout]    --> src/cli/list/table.rs:295:18
[INFO] [stdout]     |
[INFO] [stdout] 295 | pub(crate) trait IntoCell: Into<Cell> + Sized {
[INFO] [stdout]     |                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ContextExceeded` is never constructed
[INFO] [stdout]   --> src/providers.rs:77:5
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub(crate) enum ErrorKind {
[INFO] [stdout]    |                 --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 77 |     ContextExceeded,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ErrorKind` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_kind` is never used
[INFO] [stdout]   --> src/providers.rs:89:19
[INFO] [stdout]    |
[INFO] [stdout] 88 | impl Error {
[INFO] [stdout]    | ---------- associated function in this implementation
[INFO] [stdout] 89 |     pub(crate) fn from_kind(kind: ErrorKind) -> Error {
[INFO] [stdout]    |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `role` is never read
[INFO] [stdout]    --> src/providers.rs:150:9
[INFO] [stdout]     |
[INFO] [stdout] 148 | pub(crate) struct MessageDelta {
[INFO] [stdout]     |                   ------------ field in this struct
[INFO] [stdout] 149 |     /// The role of the message.
[INFO] [stdout] 150 |     pub role: Role,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MessageDelta` 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 `prompt_tokens` and `completion_tokens` are never read
[INFO] [stdout]    --> src/providers.rs:159:5
[INFO] [stdout]     |
[INFO] [stdout] 157 | pub(crate) struct Usage {
[INFO] [stdout]     |                   ----- fields in this struct
[INFO] [stdout] 158 |     /// The number of tokens in the prompt.
[INFO] [stdout] 159 |     prompt_tokens: Option<usize>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 160 |     /// The number of tokens in the response.
[INFO] [stdout] 161 |     completion_tokens: Option<usize>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Usage` 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 `finish_reason` and `usage` are never used
[INFO] [stdout]    --> src/providers.rs:172:8
[INFO] [stdout]     |
[INFO] [stdout] 166 | pub(crate) trait AsyncMessageIterator {
[INFO] [stdout]     |                  -------------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 172 |     fn finish_reason(&self) -> FinishReason;
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 176 |     fn usage(&self) -> &Usage;
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `typ` is never read
[INFO] [stdout]    --> src/providers/openai/api.rs:225:5
[INFO] [stdout]     |
[INFO] [stdout] 222 | pub(super) struct ApiErrorPayload {
[INFO] [stdout]     |                   --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 225 |     typ: String,
[INFO] [stdout]     |     ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ApiErrorPayload` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `env_api_key` is never used
[INFO] [stdout]    --> src/providers/openai/api.rs:316:8
[INFO] [stdout]     |
[INFO] [stdout] 316 |     fn env_api_key() -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/providers/openai/provider.rs:50:19
[INFO] [stdout]    |
[INFO] [stdout] 49 | impl OpenAIProvider {
[INFO] [stdout]    | ------------------- associated function in this implementation
[INFO] [stdout] 50 |     pub(crate) fn new<U: IntoUrl>(api_key: &str, api_base: U) -> Result<OpenAIProvider, Error> {
[INFO] [stdout]    |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `provider` and `model` are never used
[INFO] [stdout]    --> src/registry/registry.rs:112:19
[INFO] [stdout]     |
[INFO] [stdout]  85 | impl ModelSpec {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub(crate) fn provider(&self) -> Option<ProviderIdentifier> {
[INFO] [stdout]     |                   ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 116 |     pub(crate) fn model(&self) -> Option<&str> {
[INFO] [stdout]     |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/cli/chat/prompt.rs:60:27
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn render_prompt_left(&self) -> std::borrow::Cow<str> {
[INFO] [stdout]    |                           ^^^^^     ^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                           |
[INFO] [stdout]    |                           the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn render_prompt_left(&self) -> std::borrow::Cow<'_, str> {
[INFO] [stdout]    |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/cli/chat/prompt.rs:64:28
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn render_prompt_right(&self) -> std::borrow::Cow<str> {
[INFO] [stdout]    |                            ^^^^^     ^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn render_prompt_right(&self) -> std::borrow::Cow<'_, str> {
[INFO] [stdout]    |                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/cli/chat/prompt.rs:68:32
[INFO] [stdout]    |
[INFO] [stdout] 68 |     fn render_prompt_indicator(&self, prompt_mode: reedline::PromptEditMode) -> Cow<str> {
[INFO] [stdout]    |                                ^^^^^ the lifetime is elided here                ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 68 |     fn render_prompt_indicator(&self, prompt_mode: reedline::PromptEditMode) -> Cow<'_, str> {
[INFO] [stdout]    |                                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/cli/chat/prompt.rs:79:42
[INFO] [stdout]    |
[INFO] [stdout] 79 |     fn render_prompt_multiline_indicator(&self) -> Cow<str> {
[INFO] [stdout]    |                                          ^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                          |
[INFO] [stdout]    |                                          the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 79 |     fn render_prompt_multiline_indicator(&self) -> Cow<'_, str> {
[INFO] [stdout]    |                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/cli/chat/prompt.rs:84:9
[INFO] [stdout]    |
[INFO] [stdout] 84 |         &self,
[INFO] [stdout]    |         ^^^^^ the lifetime is elided here
[INFO] [stdout] 85 |         history_search: PromptHistorySearch,
[INFO] [stdout] 86 |     ) -> Cow<str> {
[INFO] [stdout]    |          ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 86 |     ) -> Cow<'_, str> {
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> src/color.rs:24:13
[INFO] [stdout]    |
[INFO] [stdout] 24 |             USE_COLOR.store(true, Ordering::Relaxed);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout]    = note: `#[warn(static_mut_refs)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> src/color.rs:27:13
[INFO] [stdout]    |
[INFO] [stdout] 27 |             USE_COLOR.store(false, Ordering::Relaxed);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> src/color.rs:33:20
[INFO] [stdout]    |
[INFO] [stdout] 33 |     match unsafe { USE_COLOR.load(Ordering::Relaxed) } {
[INFO] [stdout]    |                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Standard` is never constructed
[INFO] [stdout]   --> src/cli/chat.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub(crate) enum Severity {
[INFO] [stdout]    |                 -------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 29 |     Standard,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `output`, `model`, and `system` are never used
[INFO] [stdout]   --> src/cli/chat.rs:47:19
[INFO] [stdout]    |
[INFO] [stdout] 38 | impl Message {
[INFO] [stdout]    | ------------ associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub(crate) fn output(msg: String) -> Message {
[INFO] [stdout]    |                   ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub(crate) fn model(msg: String, model_id: String) -> Message {
[INFO] [stdout]    |                   ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub(crate) fn system(msg: String) -> Message {
[INFO] [stdout]    |                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `ContextExceeded` is never constructed
[INFO] [stdout]   --> src/providers.rs:77:5
[INFO] [stdout]    |
[INFO] [stdout] 47 | pub(crate) enum ErrorKind {
[INFO] [stdout]    |                 --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 77 |     ContextExceeded,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ErrorKind` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_kind` is never used
[INFO] [stdout]   --> src/providers.rs:89:19
[INFO] [stdout]    |
[INFO] [stdout] 88 | impl Error {
[INFO] [stdout]    | ---------- associated function in this implementation
[INFO] [stdout] 89 |     pub(crate) fn from_kind(kind: ErrorKind) -> Error {
[INFO] [stdout]    |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `role` is never read
[INFO] [stdout]    --> src/providers.rs:150:9
[INFO] [stdout]     |
[INFO] [stdout] 148 | pub(crate) struct MessageDelta {
[INFO] [stdout]     |                   ------------ field in this struct
[INFO] [stdout] 149 |     /// The role of the message.
[INFO] [stdout] 150 |     pub role: Role,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `MessageDelta` 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 `prompt_tokens` and `completion_tokens` are never read
[INFO] [stdout]    --> src/providers.rs:159:5
[INFO] [stdout]     |
[INFO] [stdout] 157 | pub(crate) struct Usage {
[INFO] [stdout]     |                   ----- fields in this struct
[INFO] [stdout] 158 |     /// The number of tokens in the prompt.
[INFO] [stdout] 159 |     prompt_tokens: Option<usize>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 160 |     /// The number of tokens in the response.
[INFO] [stdout] 161 |     completion_tokens: Option<usize>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Usage` 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 `finish_reason` and `usage` are never used
[INFO] [stdout]    --> src/providers.rs:172:8
[INFO] [stdout]     |
[INFO] [stdout] 166 | pub(crate) trait AsyncMessageIterator {
[INFO] [stdout]     |                  -------------------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 172 |     fn finish_reason(&self) -> FinishReason;
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 176 |     fn usage(&self) -> &Usage;
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `done` is never read
[INFO] [stdout]    --> src/providers/apireq/json_stream_parser.rs:396:9
[INFO] [stdout]     |
[INFO] [stdout] 394 |     struct ModelJson<'c> {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] 395 |         model: &'c str,
[INFO] [stdout] 396 |         done: bool,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ModelJson` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `typ` is never read
[INFO] [stdout]    --> src/providers/openai/api.rs:225:5
[INFO] [stdout]     |
[INFO] [stdout] 222 | pub(super) struct ApiErrorPayload {
[INFO] [stdout]     |                   --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 225 |     typ: String,
[INFO] [stdout]     |     ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ApiErrorPayload` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/providers/openai/provider.rs:50:19
[INFO] [stdout]    |
[INFO] [stdout] 49 | impl OpenAIProvider {
[INFO] [stdout]    | ------------------- associated function in this implementation
[INFO] [stdout] 50 |     pub(crate) fn new<U: IntoUrl>(api_key: &str, api_base: U) -> Result<OpenAIProvider, Error> {
[INFO] [stdout]    |                   ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `provider` and `model` are never used
[INFO] [stdout]    --> src/registry/registry.rs:112:19
[INFO] [stdout]     |
[INFO] [stdout]  85 | impl ModelSpec {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub(crate) fn provider(&self) -> Option<ProviderIdentifier> {
[INFO] [stdout]     |                   ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 116 |     pub(crate) fn model(&self) -> Option<&str> {
[INFO] [stdout]     |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/cli/chat/prompt.rs:60:27
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn render_prompt_left(&self) -> std::borrow::Cow<str> {
[INFO] [stdout]    |                           ^^^^^     ^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                           |
[INFO] [stdout]    |                           the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn render_prompt_left(&self) -> std::borrow::Cow<'_, str> {
[INFO] [stdout]    |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/cli/chat/prompt.rs:64:28
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn render_prompt_right(&self) -> std::borrow::Cow<str> {
[INFO] [stdout]    |                            ^^^^^     ^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                            |
[INFO] [stdout]    |                            the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 64 |     fn render_prompt_right(&self) -> std::borrow::Cow<'_, str> {
[INFO] [stdout]    |                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/cli/chat/prompt.rs:68:32
[INFO] [stdout]    |
[INFO] [stdout] 68 |     fn render_prompt_indicator(&self, prompt_mode: reedline::PromptEditMode) -> Cow<str> {
[INFO] [stdout]    |                                ^^^^^ the lifetime is elided here                ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 68 |     fn render_prompt_indicator(&self, prompt_mode: reedline::PromptEditMode) -> Cow<'_, str> {
[INFO] [stdout]    |                                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/cli/chat/prompt.rs:79:42
[INFO] [stdout]    |
[INFO] [stdout] 79 |     fn render_prompt_multiline_indicator(&self) -> Cow<str> {
[INFO] [stdout]    |                                          ^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                          |
[INFO] [stdout]    |                                          the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 79 |     fn render_prompt_multiline_indicator(&self) -> Cow<'_, str> {
[INFO] [stdout]    |                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/cli/chat/prompt.rs:84:9
[INFO] [stdout]    |
[INFO] [stdout] 84 |         &self,
[INFO] [stdout]    |         ^^^^^ the lifetime is elided here
[INFO] [stdout] 85 |         history_search: PromptHistorySearch,
[INFO] [stdout] 86 |     ) -> Cow<str> {
[INFO] [stdout]    |          ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 86 |     ) -> Cow<'_, str> {
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> src/color.rs:24:13
[INFO] [stdout]    |
[INFO] [stdout] 24 |             USE_COLOR.store(true, Ordering::Relaxed);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout]    = note: `#[warn(static_mut_refs)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> src/color.rs:27:13
[INFO] [stdout]    |
[INFO] [stdout] 27 |             USE_COLOR.store(false, Ordering::Relaxed);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]   --> src/color.rs:33:20
[INFO] [stdout]    |
[INFO] [stdout] 33 |     match unsafe { USE_COLOR.load(Ordering::Relaxed) } {
[INFO] [stdout]    |                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]    |
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]    = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 20.65s
[INFO] running `Command { std: "docker" "inspect" "c4cb9145cde1198cb91f2703089d313e72e0ad02c02119654d97685c82eb4dc1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c4cb9145cde1198cb91f2703089d313e72e0ad02c02119654d97685c82eb4dc1", kill_on_drop: false }`
[INFO] [stdout] c4cb9145cde1198cb91f2703089d313e72e0ad02c02119654d97685c82eb4dc1
