[INFO] cloning repository https://github.com/anuramat/vicode
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/anuramat/vicode" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fanuramat%2Fvicode", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fanuramat%2Fvicode'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 7711343e2e0a57a4f61d69136ff4708c1c517340
[INFO] checking anuramat/vicode against try#012cd62c9add58ab3910e44c137d87db3ab70f61 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fanuramat%2Fvicode" "/workspace/builds/worker-0-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/anuramat/vicode
[INFO] finished tweaking git repo https://github.com/anuramat/vicode
[INFO] tweaked toml for git repo https://github.com/anuramat/vicode written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/anuramat/vicode on toolchain 012cd62c9add58ab3910e44c137d87db3ab70f61
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/anuramat/vicode 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" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 3924cd974a9a8d6191131fe7b04dc12dc36a296cb1ada824e5f9eeb648b39862
[INFO] running `Command { std: "docker" "start" "-a" "3924cd974a9a8d6191131fe7b04dc12dc36a296cb1ada824e5f9eeb648b39862", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "3924cd974a9a8d6191131fe7b04dc12dc36a296cb1ada824e5f9eeb648b39862", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3924cd974a9a8d6191131fe7b04dc12dc36a296cb1ada824e5f9eeb648b39862", kill_on_drop: false }`
[INFO] [stdout] 3924cd974a9a8d6191131fe7b04dc12dc36a296cb1ada824e5f9eeb648b39862
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1e0ea3d9891665efd94962305ab957be36eea83e6e069a862db8f7165cb7a85e
[INFO] running `Command { std: "docker" "start" "-a" "1e0ea3d9891665efd94962305ab957be36eea83e6e069a862db8f7165cb7a85e", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.103
[INFO] [stderr]    Compiling quote v1.0.42
[INFO] [stderr]    Compiling unicode-ident v1.0.22
[INFO] [stderr]     Checking memchr v2.7.6
[INFO] [stderr]     Checking bitflags v2.10.0
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]     Checking slab v0.4.11
[INFO] [stderr]     Checking regex-syntax v0.8.8
[INFO] [stderr]     Checking mio v1.1.0
[INFO] [stderr]     Checking socket2 v0.6.1
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling icu_properties_data v2.1.1
[INFO] [stderr]     Checking http v1.3.1
[INFO] [stderr]     Checking deranged v0.5.5
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]     Checking time-core v0.1.6
[INFO] [stderr]    Compiling libz-sys v1.1.23
[INFO] [stderr]    Compiling rustls v0.23.37
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]     Checking signal-hook v0.3.18
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]     Checking linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling toml_parser v1.0.4
[INFO] [stderr]     Checking hashbrown v0.16.0
[INFO] [stderr]    Compiling indexmap v2.12.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]     Checking signal-hook-mio v0.2.5
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]     Checking itertools v0.13.0
[INFO] [stderr]    Compiling libssh2-sys v0.3.1
[INFO] [stderr]    Compiling onig_sys v69.9.1
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking sync_wrapper v1.0.2
[INFO] [stderr]     Checking compact_str v0.8.1
[INFO] [stderr]     Checking anstyle-parse v0.2.7
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking lru v0.12.5
[INFO] [stderr]     Checking time v0.3.44
[INFO] [stderr]    Compiling toml_edit v0.23.7
[INFO] [stderr]     Checking rand_core v0.9.3
[INFO] [stderr]     Checking simd-adler32 v0.3.7
[INFO] [stderr]     Checking crossterm v0.28.1
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]    Compiling syn v2.0.110
[INFO] [stderr]     Checking iri-string v0.7.9
[INFO] [stderr]     Checking cassowary v0.3.0
[INFO] [stderr]     Checking anstream v0.6.21
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking rand_chacha v0.9.0
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking unicode-truncate v1.1.0
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]     Checking quick-xml v0.38.4
[INFO] [stderr]    Compiling proc-macro-crate v3.4.0
[INFO] [stderr]    Compiling libgit2-sys v0.18.3+1.9.2
[INFO] [stderr]    Compiling ref-cast v1.0.25
[INFO] [stderr]    Compiling pulldown-cmark v0.13.0
[INFO] [stderr]    Compiling erased-serde v0.4.9
[INFO] [stderr]     Checking bit-set v0.5.3
[INFO] [stderr]     Checking eventsource-stream v0.2.3
[INFO] [stderr]     Checking clap_builder v4.5.60
[INFO] [stderr]    Compiling petname v2.0.2
[INFO] [stderr]     Checking flate2 v1.1.5
[INFO] [stderr]     Checking rand v0.9.2
[INFO] [stderr]     Checking dirs-sys v0.5.0
[INFO] [stderr]     Checking getopts v0.2.24
[INFO] [stderr]     Checking raw-cpuid v11.6.0
[INFO] [stderr]     Checking itertools v0.14.0
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]     Checking pulldown-cmark-escape v0.11.0
[INFO] [stderr]    Compiling typetag v0.2.21
[INFO] [stderr]     Checking winnow v0.7.14
[INFO] [stderr]     Checking dashmap v6.1.0
[INFO] [stderr]     Checking inotify v0.11.0
[INFO] [stderr]     Checking dirs v6.0.0
[INFO] [stderr]     Checking dirs-sys v0.4.1
[INFO] [stderr]     Checking itertools v0.10.5
[INFO] [stderr]     Checking serde_spanned v1.0.3
[INFO] [stderr]     Checking toml_datetime v0.7.3
[INFO] [stderr]     Checking toml_writer v1.0.4
[INFO] [stderr]     Checking dissimilar v1.0.10
[INFO] [stderr]     Checking inventory v0.3.21
[INFO] [stderr]     Checking notify-types v2.0.0
[INFO] [stderr]     Checking fastrand v2.3.0
[INFO] [stderr]     Checking dyn-clone v1.0.20
[INFO] [stderr]     Checking sha1_smol v1.0.1
[INFO] [stderr]     Checking notify v8.2.0
[INFO] [stderr]     Checking dirs v5.0.1
[INFO] [stderr]     Checking shellexpand v3.1.1
[INFO] [stderr]     Checking nucleo-matcher v0.3.1
[INFO] [stderr]     Checking bstr v1.12.1
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking fancy-regex v0.13.0
[INFO] [stderr]     Checking regex v1.12.2
[INFO] [stderr]     Checking similar v2.7.0
[INFO] [stderr]     Checking fs_extra v1.3.0
[INFO] [stderr]     Checking self_cell v1.2.1
[INFO] [stderr]     Checking colored-diff v0.2.3
[INFO] [stderr]     Checking xdg v3.0.0
[INFO] [stderr]     Checking globset v0.4.18
[INFO] [stderr]     Checking tiktoken-rs v0.9.1
[INFO] [stderr]     Checking quanta v0.12.6
[INFO] [stderr]     Checking rustls-webpki v0.103.9
[INFO] [stderr]     Checking onig v6.5.1
[INFO] [stderr]     Checking ignore v0.4.25
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling serde_derive_internals v0.29.1
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling ref-cast-impl v1.0.25
[INFO] [stderr]     Checking tokio v1.48.0
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]    Compiling clap_derive v4.5.55
[INFO] [stderr]     Checking tracing-subscriber v0.3.22
[INFO] [stderr]    Compiling schemars_derive v1.1.0
[INFO] [stderr]    Compiling typetag-impl v0.2.21
[INFO] [stderr]    Compiling derive_more-impl v2.0.1
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking yoke v0.8.1
[INFO] [stderr]     Checking thiserror v2.0.18
[INFO] [stderr]     Checking zerovec v0.11.5
[INFO] [stderr]     Checking zerotrie v0.2.3
[INFO] [stderr]     Checking partition-identity v0.3.1
[INFO] [stderr]    Compiling async-openai-macros v0.1.1 (https://github.com/anuramat/async-openai#dd12a06c)
[INFO] [stderr]    Compiling strum_macros v0.27.2
[INFO] [stderr]    Compiling rstest_macros v0.26.1
[INFO] [stderr]     Checking proc-mounts v0.3.0
[INFO] [stderr]     Checking tracing-appender v0.2.4
[INFO] [stderr]     Checking toml v0.9.8
[INFO] [stderr]     Checking tinystr v0.8.2
[INFO] [stderr]     Checking potential_utf v0.1.4
[INFO] [stderr]     Checking icu_locale_core v2.1.1
[INFO] [stderr]     Checking icu_collections v2.1.1
[INFO] [stderr]    Compiling smart-default v0.7.1
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]     Checking clap v4.5.60
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking governor v0.10.4
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling derive_builder_core v0.20.2
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking derive_more v2.0.1
[INFO] [stderr]     Checking ratatui v0.29.0
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]     Checking strum v0.27.2
[INFO] [stderr]    Compiling derive_builder_macro v0.20.2
[INFO] [stderr]     Checking icu_properties v2.1.1
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking plist v1.8.0
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]     Checking derive_builder v0.20.2
[INFO] [stderr]     Checking secrecy v0.10.3
[INFO] [stderr]     Checking uuid v1.18.1
[INFO] [stderr]     Checking serde_plain v1.0.2
[INFO] [stderr]     Checking schemars v1.1.0
[INFO] [stderr]     Checking syntect v5.3.0
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking rstest v0.26.1
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking url v2.5.7
[INFO] [stderr]     Checking ansi-to-tui v7.0.0
[INFO] [stderr]     Checking tui-textarea v0.7.0
[INFO] [stderr]     Checking hyper v1.8.1
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking tokio-rustls v0.26.4
[INFO] [stderr]     Checking tokio-util v0.7.17
[INFO] [stderr]     Checking backoff v0.4.0
[INFO] [stderr]     Checking tokio-stream v0.1.17
[INFO] [stderr]     Checking backon v1.6.0
[INFO] [stderr]     Checking tui-markdown v0.3.6
[INFO] [stderr]     Checking tower-http v0.6.6
[INFO] [stderr]     Checking hyper-util v0.1.20
[INFO] [stderr]     Checking git2 v0.20.2
[INFO] [stderr]     Checking hyper-rustls v0.27.7
[INFO] [stderr]     Checking reqwest v0.12.24
[INFO] [stderr]     Checking reqwest-eventsource v0.6.0
[INFO] [stderr]     Checking async-openai v0.33.0 (https://github.com/anuramat/async-openai#dd12a06c)
[INFO] [stderr]     Checking vicode v0.0.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: use of deprecated method `ratatui::widgets::block::Title::<'a>::alignment`: use Block::title_top() or Block::title_bottom() instead. This will be removed in a future release.
[INFO] [stdout]    --> src/tools/bash/widget.rs:147:50
[INFO] [stdout]     |
[INFO] [stdout] 147 |                 Title::from(status_line.clone()).alignment(ratatui::layout::Alignment::Right);
[INFO] [stdout]     |                                                  ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `ratatui::widgets::block::Title::<'a>::alignment`: use Block::title_top() or Block::title_bottom() instead. This will be removed in a future release.
[INFO] [stdout]    --> src/tools/bash/widget.rs:147:50
[INFO] [stdout]     |
[INFO] [stdout] 147 |                 Title::from(status_line.clone()).alignment(ratatui::layout::Alignment::Right);
[INFO] [stdout]     |                                                  ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `kind` is never read
[INFO] [stdout]   --> src/tui/app/mod.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct Notification {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 37 |     pub kind: NotificationKind,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `themeset` is never read
[INFO] [stdout]   --> src/tui/widgets/syntax.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Highlighter {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] 16 |     set: SyntaxSet,
[INFO] [stdout] 17 |     themeset: ThemeSet,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/agent/handle.rs:135:9
[INFO] [stdout]     |
[INFO] [stdout] 135 |         self.state.context.history.handle(generation, event.clone());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 135 |         let _ = self.state.context.history.handle(generation, event.clone());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: feature `type_alias_impl_trait` is declared but not used
[INFO] [stdout]  --> src/main.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | #![feature(type_alias_impl_trait)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_features)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: feature `iterator_try_collect` is declared but not used
[INFO] [stdout]  --> src/main.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | #![feature(iterator_try_collect)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_INSTRUCTIONS` is never used
[INFO] [stdout]   --> src/config.rs:15:7
[INFO] [stdout]    |
[INFO] [stdout] 15 | const DEFAULT_INSTRUCTIONS: &str =
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `INSTRUCTIONS_FILENAME` is never used
[INFO] [stdout]   --> src/config.rs:20:7
[INFO] [stdout]    |
[INFO] [stdout] 20 | const INSTRUCTIONS_FILENAME: &str = "AGENTS.md"; // in config dir
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `kind` is never read
[INFO] [stdout]   --> src/tui/app/mod.rs:37:9
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct Notification {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] 37 |     pub kind: NotificationKind,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/tui/widgets/logo.rs:48:8
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl LogoVariant {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 48 |     fn new(text: String) -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/tui/widgets/logo.rs:82:8
[INFO] [stdout]    |
[INFO] [stdout] 63 | impl Logo {
[INFO] [stdout]    | --------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 82 |     fn new() -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LOGO_66X12` is never used
[INFO] [stdout]   --> src/tui/widgets/logo.rs:92:7
[INFO] [stdout]    |
[INFO] [stdout] 92 | const LOGO_66X12: &str = r#"
[INFO] [stdout]    |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LOGO_23X12` is never used
[INFO] [stdout]    --> src/tui/widgets/logo.rs:107:7
[INFO] [stdout]     |
[INFO] [stdout] 107 | const LOGO_23X12: &str = r#"
[INFO] [stdout]     |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `themeset` is never read
[INFO] [stdout]   --> src/tui/widgets/syntax.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct Highlighter {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] 16 |     set: SyntaxSet,
[INFO] [stdout] 17 |     themeset: ThemeSet,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/agent/handle.rs:135:9
[INFO] [stdout]     |
[INFO] [stdout] 135 |         self.state.context.history.handle(generation, event.clone());
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 135 |         let _ = self.state.context.history.handle(generation, event.clone());
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:349:9
[INFO] [stdout]     |
[INFO] [stdout] 349 |         history.handle(0, HistoryEvent::ResponseFailed("oops".into()));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 349 |         let _ = history.handle(0, HistoryEvent::ResponseFailed("oops".into()));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:366:9
[INFO] [stdout]     |
[INFO] [stdout] 366 |         history.handle(0, HistoryEvent::ResponseAborted);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 366 |         let _ = history.handle(0, HistoryEvent::ResponseAborted);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:373:9
[INFO] [stdout]     |
[INFO] [stdout] 373 |         history.handle(0, HistoryEvent::ResponseStarted(7));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 373 |         let _ = history.handle(0, HistoryEvent::ResponseStarted(7));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:394:9
[INFO] [stdout]     |
[INFO] [stdout] 394 |         history.handle(0, HistoryEvent::ResponseStarted(1));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 394 |         let _ = history.handle(0, HistoryEvent::ResponseStarted(1));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:395:9
[INFO] [stdout]     |
[INFO] [stdout] 395 | /         history.handle(
[INFO] [stdout] 396 | |             1,
[INFO] [stdout] 397 | |             HistoryEvent::ResponseItem(Box::new(AssistantItem::Output(OutputItem {
[INFO] [stdout] 398 | |                 id: "out".into(),
[INFO] [stdout] ...   |
[INFO] [stdout] 401 | |             }))),
[INFO] [stdout] 402 | |         );
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 395 |         let _ = history.handle(
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:412:9
[INFO] [stdout]     |
[INFO] [stdout] 412 |         history.handle(0, HistoryEvent::ResponseStarted(1));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 412 |         let _ = history.handle(0, HistoryEvent::ResponseStarted(1));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:413:9
[INFO] [stdout]     |
[INFO] [stdout] 413 | /         history.handle(
[INFO] [stdout] 414 | |             1,
[INFO] [stdout] 415 | |             HistoryEvent::ResponseItem(Box::new(AssistantItem::Output(OutputItem {
[INFO] [stdout] 416 | |                 id: "out".into(),
[INFO] [stdout] ...   |
[INFO] [stdout] 422 | |             }))),
[INFO] [stdout] 423 | |         );
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 413 |         let _ = history.handle(
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:433:9
[INFO] [stdout]     |
[INFO] [stdout] 433 |         history.handle(0, HistoryEvent::ResponseStarted(1));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 433 |         let _ = history.handle(0, HistoryEvent::ResponseStarted(1));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:434:9
[INFO] [stdout]     |
[INFO] [stdout] 434 | /         history.handle(
[INFO] [stdout] 435 | |             1,
[INFO] [stdout] 436 | |             HistoryEvent::ResponseItem(Box::new(AssistantItem::Output(OutputItem {
[INFO] [stdout] 437 | |                 id: "out".into(),
[INFO] [stdout] ...   |
[INFO] [stdout] 440 | |             }))),
[INFO] [stdout] 441 | |         );
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 434 |         let _ = history.handle(
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:442:9
[INFO] [stdout]     |
[INFO] [stdout] 442 | /         history.handle(
[INFO] [stdout] 443 | |             1,
[INFO] [stdout] 444 | |             HistoryEvent::ResponseDelta(Delta {
[INFO] [stdout] 445 | |                 id: "out".into(),
[INFO] [stdout] 446 | |                 delta: crate::llm::delta::DeltaContent::Output("hello".into()),
[INFO] [stdout] 447 | |             }),
[INFO] [stdout] 448 | |         );
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 442 |         let _ = history.handle(
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:464:9
[INFO] [stdout]     |
[INFO] [stdout] 464 | /         history.handle(
[INFO] [stdout] 465 | |             0,
[INFO] [stdout] 466 | |             HistoryEvent::ResponseItem(Box::new(AssistantItem::Output(OutputItem {
[INFO] [stdout] 467 | |                 id: "out".into(),
[INFO] [stdout] ...   |
[INFO] [stdout] 470 | |             }))),
[INFO] [stdout] 471 | |         );
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 464 |         let _ = history.handle(
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:488:9
[INFO] [stdout]     |
[INFO] [stdout] 488 |         history.handle(0, HistoryEvent::ResponseCompleted(vec![]));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 488 |         let _ = history.handle(0, HistoryEvent::ResponseCompleted(vec![]));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:502:9
[INFO] [stdout]     |
[INFO] [stdout] 502 |         history.handle(0, HistoryEvent::ResponseStarted(0));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 502 |         let _ = history.handle(0, HistoryEvent::ResponseStarted(0));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:503:9
[INFO] [stdout]     |
[INFO] [stdout] 503 | /         history.handle(
[INFO] [stdout] 504 | |             1,
[INFO] [stdout] 505 | |             HistoryEvent::ResponseItem(Box::new(AssistantItem::Output(OutputItem {
[INFO] [stdout] 506 | |                 id: "out".into(),
[INFO] [stdout] ...   |
[INFO] [stdout] 509 | |             }))),
[INFO] [stdout] 510 | |         );
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 503 |         let _ = history.handle(
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:511:9
[INFO] [stdout]     |
[INFO] [stdout] 511 | /         history.handle(
[INFO] [stdout] 512 | |             1,
[INFO] [stdout] 513 | |             HistoryEvent::ResponseCompleted(vec![AssistantItem::Output(OutputItem {
[INFO] [stdout] 514 | |                 id: "out".into(),
[INFO] [stdout] ...   |
[INFO] [stdout] 520 | |             })]),
[INFO] [stdout] 521 | |         );
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 511 |         let _ = history.handle(
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:537:9
[INFO] [stdout]     |
[INFO] [stdout] 537 |         history.handle(0, HistoryEvent::ResponseStarted(0));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 537 |         let _ = history.handle(0, HistoryEvent::ResponseStarted(0));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:538:9
[INFO] [stdout]     |
[INFO] [stdout] 538 |         history.handle(1, HistoryEvent::ResponseAborted);
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 538 |         let _ = history.handle(1, HistoryEvent::ResponseAborted);
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:555:9
[INFO] [stdout]     |
[INFO] [stdout] 555 |         history.handle(0, HistoryEvent::UserMessage("hello".into()));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 555 |         let _ = history.handle(0, HistoryEvent::UserMessage("hello".into()));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:562:9
[INFO] [stdout]     |
[INFO] [stdout] 562 |         history.handle(0, HistoryEvent::ResponseStarted(1));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 562 |         let _ = history.handle(0, HistoryEvent::ResponseStarted(1));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:564:9
[INFO] [stdout]     |
[INFO] [stdout] 564 | /         history.handle(
[INFO] [stdout] 565 | |             1,
[INFO] [stdout] 566 | |             HistoryEvent::ResponseItem(Box::new(AssistantItem::Output(OutputItem {
[INFO] [stdout] 567 | |                 id: "out".into(),
[INFO] [stdout] ...   |
[INFO] [stdout] 570 | |             }))),
[INFO] [stdout] 571 | |         );
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 564 |         let _ = history.handle(
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:573:9
[INFO] [stdout]     |
[INFO] [stdout] 573 | /         history.handle(
[INFO] [stdout] 574 | |             1,
[INFO] [stdout] 575 | |             HistoryEvent::ResponseDelta(Delta {
[INFO] [stdout] 576 | |                 id: "out".into(),
[INFO] [stdout] 577 | |                 delta: crate::llm::delta::DeltaContent::Output("hello".into()),
[INFO] [stdout] 578 | |             }),
[INFO] [stdout] 579 | |         );
[INFO] [stdout]     | |_________^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 573 |         let _ = history.handle(
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/llm/history.rs:586:9
[INFO] [stdout]     |
[INFO] [stdout] 586 |         history.handle(0, HistoryEvent::UserMessage("hello".into()));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 586 |         let _ = history.handle(0, HistoryEvent::UserMessage("hello".into()));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: feature `type_alias_impl_trait` is declared but not used
[INFO] [stdout]  --> src/main.rs:2:12
[INFO] [stdout]   |
[INFO] [stdout] 2 | #![feature(type_alias_impl_trait)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_features)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: feature `iterator_try_collect` is declared but not used
[INFO] [stdout]  --> src/main.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | #![feature(iterator_try_collect)]
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 31s
[INFO] running `Command { std: "docker" "inspect" "1e0ea3d9891665efd94962305ab957be36eea83e6e069a862db8f7165cb7a85e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1e0ea3d9891665efd94962305ab957be36eea83e6e069a862db8f7165cb7a85e", kill_on_drop: false }`
[INFO] [stdout] 1e0ea3d9891665efd94962305ab957be36eea83e6e069a862db8f7165cb7a85e
