[INFO] fetching crate zeph-plugins 0.20.1...
[INFO] checking zeph-plugins-0.20.1 against try#6713fa75964eb229409a9c6f6f5c418423e313ff for pr-133502-22
[INFO] extracting crate zeph-plugins 0.20.1 into /workspace/builds/worker-5-tc2/source
[INFO] started tweaking crates.io crate zeph-plugins 0.20.1
[INFO] finished tweaking crates.io crate zeph-plugins 0.20.1
[INFO] tweaked toml for crates.io crate zeph-plugins 0.20.1 written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate zeph-plugins 0.20.1 on toolchain 6713fa75964eb229409a9c6f6f5c418423e313ff
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+6713fa75964eb229409a9c6f6f5c418423e313ff" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate zeph-plugins 0.20.1 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" "+6713fa75964eb229409a9c6f6f5c418423e313ff" "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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+6713fa75964eb229409a9c6f6f5c418423e313ff" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 81cd19093a31156436ca097f4cc6a6f8ce7d499dc3693dfcf2082b26c3660163
[INFO] running `Command { std: "docker" "start" "-a" "81cd19093a31156436ca097f4cc6a6f8ce7d499dc3693dfcf2082b26c3660163", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "81cd19093a31156436ca097f4cc6a6f8ce7d499dc3693dfcf2082b26c3660163", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "81cd19093a31156436ca097f4cc6a6f8ce7d499dc3693dfcf2082b26c3660163", kill_on_drop: false }`
[INFO] [stdout] 81cd19093a31156436ca097f4cc6a6f8ce7d499dc3693dfcf2082b26c3660163
[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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+6713fa75964eb229409a9c6f6f5c418423e313ff" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a1c462ad3ab515e4c57b89d8dc05c14e717a9c87c5c16b949f392c96fe48ce12
[INFO] running `Command { std: "docker" "start" "-a" "a1c462ad3ab515e4c57b89d8dc05c14e717a9c87c5c16b949f392c96fe48ce12", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.186
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling tree-sitter-language v0.1.7
[INFO] [stderr]     Checking stable_deref_trait v1.2.1
[INFO] [stderr]    Compiling siphasher v1.0.2
[INFO] [stderr]    Compiling fastrand v2.4.1
[INFO] [stderr]    Compiling aws-lc-rs v1.16.3
[INFO] [stderr]     Checking http v1.4.0
[INFO] [stderr]    Compiling zeroize_derive v1.4.3
[INFO] [stderr]    Compiling zerovec-derive v0.11.3
[INFO] [stderr]    Compiling tokio-macros v2.7.0
[INFO] [stderr]    Compiling zerofrom-derive v0.1.7
[INFO] [stderr]    Compiling yoke-derive v0.8.2
[INFO] [stderr]     Checking futures-util v0.3.32
[INFO] [stderr]     Checking rand_core v0.10.1
[INFO] [stderr]    Compiling getrandom v0.4.2
[INFO] [stderr]     Checking hashbrown v0.17.0
[INFO] [stderr]    Compiling rustls v0.23.39
[INFO] [stderr]    Compiling phf_shared v0.13.1
[INFO] [stderr]     Checking cpufeatures v0.3.0
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking iri-string v0.7.12
[INFO] [stderr]     Checking winnow v1.0.2
[INFO] [stderr]    Compiling phf_generator v0.13.1
[INFO] [stderr]    Compiling phf_codegen v0.13.1
[INFO] [stderr]    Compiling string_cache_codegen v0.6.1
[INFO] [stderr]    Compiling phf_macros v0.13.1
[INFO] [stderr]     Checking toml_writer v1.1.1+spec-1.1.0
[INFO] [stderr]     Checking indexmap v2.14.0
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]     Checking streaming-iterator v0.1.9
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]     Checking typenum v1.20.0
[INFO] [stderr]    Compiling cc v1.2.61
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]     Checking dtoa v1.0.11
[INFO] [stderr]    Compiling web_atoms v0.2.4
[INFO] [stderr]     Checking zerofrom v0.1.7
[INFO] [stderr]     Checking tendril v0.5.0
[INFO] [stderr]    Compiling selectors v0.37.0
[INFO] [stderr]     Checking dtoa-short v0.3.5
[INFO] [stderr]     Checking yoke v0.8.2
[INFO] [stderr]     Checking chacha20 v0.10.0
[INFO] [stderr]     Checking phf v0.13.1
[INFO] [stderr]    Compiling cssparser-macros v0.6.1
[INFO] [stderr]     Checking zerovec v0.11.6
[INFO] [stderr]     Checking zerotrie v0.2.4
[INFO] [stderr]    Compiling derive_more-impl v2.1.1
[INFO] [stderr]    Compiling nix v0.31.2
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking servo_arc v0.4.3
[INFO] [stderr]     Checking cssparser v0.36.0
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking mio v1.2.0
[INFO] [stderr]     Checking errno v0.3.14
[INFO] [stderr]     Checking socket2 v0.6.3
[INFO] [stderr]     Checking signal-hook-registry v1.4.8
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking getrandom v0.2.17
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]     Checking string_cache v0.9.0
[INFO] [stderr]     Checking dirs-sys v0.5.0
[INFO] [stderr]     Checking toml_parser v1.1.2+spec-1.1.0
[INFO] [stderr]     Checking tokio v1.52.1
[INFO] [stderr]    Compiling cmake v0.1.58
[INFO] [stderr]     Checking dirs v6.0.0
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]     Checking rand v0.10.1
[INFO] [stderr]     Checking tinystr v0.8.3
[INFO] [stderr]     Checking potential_utf v0.1.5
[INFO] [stderr]     Checking tempfile v3.27.0
[INFO] [stderr]     Checking inotify v0.11.1
[INFO] [stderr]     Checking derive_more v2.1.1
[INFO] [stderr]     Checking icu_collections v2.2.0
[INFO] [stderr]     Checking notify-types v2.1.0
[INFO] [stderr]     Checking icu_locale_core v2.2.0
[INFO] [stderr]    Compiling include_dir_macros v0.7.4
[INFO] [stderr]    Compiling zeph-skills v0.20.1
[INFO] [stderr]     Checking const-oid v0.10.2
[INFO] [stderr]     Checking notify v8.2.0
[INFO] [stderr]     Checking arc-swap v1.9.1
[INFO] [stderr]     Checking rand_distr v0.6.0
[INFO] [stderr]     Checking notify-debouncer-mini v0.7.0
[INFO] [stderr]     Checking include_dir v0.7.4
[INFO] [stderr]    Compiling aws-lc-sys v0.40.0
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling tree-sitter-javascript v0.25.0
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]    Compiling tree-sitter-rust v0.24.2
[INFO] [stderr]    Compiling tree-sitter-typescript v0.23.2
[INFO] [stderr]    Compiling blake3 v1.8.5
[INFO] [stderr]    Compiling tree-sitter-python v0.25.0
[INFO] [stderr]    Compiling tree-sitter-go v0.25.0
[INFO] [stderr]     Checking toml_datetime v1.1.1+spec-1.1.0
[INFO] [stderr]     Checking zeroize v1.8.2
[INFO] [stderr]     Checking icu_provider v2.2.0
[INFO] [stderr]     Checking rustls-pki-types v1.14.1
[INFO] [stderr]     Checking serde_spanned v1.1.1
[INFO] [stderr]     Checking schemars v1.2.1
[INFO] [stderr]     Checking uuid v1.23.1
[INFO] [stderr]     Checking toml_edit v0.25.11+spec-1.1.0
[INFO] [stderr]     Checking toml v1.1.2+spec-1.1.0
[INFO] [stderr]     Checking ordered-float v5.3.0
[INFO] [stderr]     Checking icu_properties v2.2.0
[INFO] [stderr]     Checking icu_normalizer v2.2.0
[INFO] [stderr]     Checking webpki-roots v1.0.7
[INFO] [stderr]     Checking rustls-native-certs v0.8.3
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking futures-executor v0.3.32
[INFO] [stderr]     Checking markup5ever v0.39.0
[INFO] [stderr]    Compiling tree-sitter-json v0.24.8
[INFO] [stderr]    Compiling tree-sitter-bash v0.25.1
[INFO] [stderr]    Compiling tree-sitter-toml-ng v0.7.0
[INFO] [stderr]     Checking hybrid-array v0.4.11
[INFO] [stderr]    Compiling tree-sitter-md v0.5.3
[INFO] [stderr]     Checking futures v0.3.32
[INFO] [stderr]     Checking html5ever v0.39.0
[INFO] [stderr]     Checking eventsource-stream v0.2.3
[INFO] [stderr]     Checking crypto-common v0.2.1
[INFO] [stderr]     Checking block-buffer v0.12.0
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking scrape-core v0.2.6
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]    Compiling tree-sitter v0.26.8
[INFO] [stderr]     Checking digest v0.11.2
[INFO] [stderr]     Checking url v2.5.8
[INFO] [stderr]     Checking sha2 v0.11.0
[INFO] [stderr]     Checking hyper v1.9.0
[INFO] [stderr]     Checking tokio-util v0.7.18
[INFO] [stderr]     Checking tower v0.5.3
[INFO] [stderr]     Checking tokio-stream v0.1.18
[INFO] [stderr]     Checking zeph-common v0.20.1
[INFO] [stderr]     Checking tower-http v0.6.8
[INFO] [stderr]     Checking hyper-util v0.1.20
[INFO] [stderr]     Checking zeph-config v0.20.1
[INFO] [stderr]     Checking rustls-webpki v0.103.13
[INFO] [stderr]     Checking tokio-rustls v0.26.4
[INFO] [stderr]     Checking rustls-platform-verifier v0.7.0
[INFO] [stderr]     Checking hyper-rustls v0.27.9
[INFO] [stderr]     Checking reqwest v0.12.28
[INFO] [stderr]     Checking reqwest v0.13.3
[INFO] [stderr]     Checking ollama-rs v0.3.4
[INFO] [stderr]     Checking zeph-tools v0.20.1
[INFO] [stderr]     Checking zeph-llm v0.20.1
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Vec<f32>, LlmError>> + std::marker::Send == Pin<Box<...>>`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:439:5
[INFO] [stdout]     |
[INFO] [stdout] 439 | /     fn embed(
[INFO] [stdout] 440 | |         &self,
[INFO] [stdout] 441 | |         text: &str,
[INFO] [stdout] 442 | |     ) -> impl std::future::Future<Output = Result<Vec<f32>, LlmError>> + Send {
[INFO] [stdout]     | |_____________________________________________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Vec<f32>, LlmError>> + std::marker::Send == Pin<Box<...>>`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:458:9
[INFO] [stdout]     |
[INFO] [stdout] 458 | /         Box::pin(async move {
[INFO] [stdout] 459 | |             match embed_provider {
[INFO] [stdout] 460 | |                 Some(p) => p.embed(&text).await,
[INFO] [stdout] 461 | |                 None => Err(LlmError::EmbedUnsupported { provider: name }),
[INFO] [stdout] 462 | |             }
[INFO] [stdout] 463 | |         })
[INFO] [stdout]     | |__________^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:458:18: 458:28}>> <: impl futures_core::Future<Output = std::result::Result<Vec<f32>, ...>> + std::marker::Send`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:442:79
[INFO] [stdout]     |
[INFO] [stdout] 442 |       ) -> impl std::future::Future<Output = Result<Vec<f32>, LlmError>> + Send {
[INFO] [stdout]     |  _______________________________________________________________________________^
[INFO] [stdout] 443 | |         // Delegate to the first embedding-capable tier provider, then to the triage provider,
[INFO] [stdout] 444 | |         // so that tool schema filter initialization works when routing = "triage".
[INFO] [stdout] 445 | |         let embed_provider = self
[INFO] [stdout] ...   |
[INFO] [stdout] 463 | |         })
[INFO] [stdout] 464 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Vec<Vec<f32>>, LlmError>> + std::marker::Send == Pin<...>`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:466:5
[INFO] [stdout]     |
[INFO] [stdout] 466 | /     fn embed_batch(
[INFO] [stdout] 467 | |         &self,
[INFO] [stdout] 468 | |         texts: &[&str],
[INFO] [stdout] 469 | |     ) -> impl std::future::Future<Output = Result<Vec<Vec<f32>>, LlmError>> + Send {
[INFO] [stdout]     | |__________________________________________________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Vec<Vec<f32>>, LlmError>> + std::marker::Send == Pin<...>`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:483:9
[INFO] [stdout]     |
[INFO] [stdout] 483 | /         Box::pin(async move {
[INFO] [stdout] 484 | |             match embed_provider {
[INFO] [stdout] 485 | |                 Some(p) => {
[INFO] [stdout] 486 | |                     let refs: Vec<&str> = owned.iter().map(String::as_str).collect();
[INFO] [stdout] ...   |
[INFO] [stdout] 491 | |         })
[INFO] [stdout]     | |__________^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:483:18: 483:28}>> <: impl futures_core::Future<Output = std::result::Result<Vec<Vec<f32>>, ...>> + std::marker::Send`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:469:84
[INFO] [stdout]     |
[INFO] [stdout] 469 |       ) -> impl std::future::Future<Output = Result<Vec<Vec<f32>>, LlmError>> + Send {
[INFO] [stdout]     |  ____________________________________________________________________________________^
[INFO] [stdout] 470 | |         let embed_provider = self
[INFO] [stdout] 471 | |             .tier_providers
[INFO] [stdout] 472 | |             .iter()
[INFO] [stdout] ...   |
[INFO] [stdout] 491 | |         })
[INFO] [stdout] 492 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<std::string::String, LlmError>> + std::marker::Send == Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:502:18: 502:28}>>`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:496:5
[INFO] [stdout]     |
[INFO] [stdout] 496 | /     fn chat(
[INFO] [stdout] 497 | |         &self,
[INFO] [stdout] 498 | |         messages: &[Message],
[INFO] [stdout] 499 | |     ) -> impl std::future::Future<Output = Result<String, LlmError>> + Send {
[INFO] [stdout]     | |___________________________________________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<std::string::String, LlmError>> + std::marker::Send == Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:502:18: 502:28}>>`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:502:9
[INFO] [stdout]     |
[INFO] [stdout] 502 | /         Box::pin(async move {
[INFO] [stdout] 503 | |             let context_tokens: usize = messages.iter().map(|m| estimate_tokens(&m.content)).sum();
[INFO] [stdout] 504 | |             let idx = router.classify(&messages).await;
[INFO] [stdout] 505 | |             let idx = router.maybe_escalate_for_context(idx, context_tokens);
[INFO] [stdout] ...   |
[INFO] [stdout] 514 | |             result
[INFO] [stdout] 515 | |         })
[INFO] [stdout]     | |__________^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:502:18: 502:28}>> <: impl futures_core::Future<Output = std::result::Result<std::string::String, LlmError>> + std::marker::Send`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:499:77
[INFO] [stdout]     |
[INFO] [stdout] 499 |       ) -> impl std::future::Future<Output = Result<String, LlmError>> + Send {
[INFO] [stdout]     |  _____________________________________________________________________________^
[INFO] [stdout] 500 | |         let router = self.clone();
[INFO] [stdout] 501 | |         let messages = messages.to_vec();
[INFO] [stdout] 502 | |         Box::pin(async move {
[INFO] [stdout] ...   |
[INFO] [stdout] 515 | |         })
[INFO] [stdout] 516 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Pin<Box<(dyn Stream<Item = std::result::Result<StreamChunk, ...>> + std::marker::Send + 'static)>>, ...>> + std::marker::Send == ...`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:520:5
[INFO] [stdout]     |
[INFO] [stdout] 520 | /     fn chat_stream(
[INFO] [stdout] 521 | |         &self,
[INFO] [stdout] 522 | |         messages: &[Message],
[INFO] [stdout] 523 | |     ) -> impl std::future::Future<Output = Result<ChatStream, LlmError>> + Send {
[INFO] [stdout]     | |_______________________________________________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Pin<Box<(dyn Stream<Item = std::result::Result<StreamChunk, ...>> + std::marker::Send + 'static)>>, ...>> + std::marker::Send == ...`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:526:9
[INFO] [stdout]     |
[INFO] [stdout] 526 | /         Box::pin(async move {
[INFO] [stdout] 527 | |             let context_tokens: usize = messages.iter().map(|m| estimate_tokens(&m.content)).sum();
[INFO] [stdout] 528 | |             let idx = router.classify(&messages).await;
[INFO] [stdout] 529 | |             let idx = router.maybe_escalate_for_context(idx, context_tokens);
[INFO] [stdout] ...   |
[INFO] [stdout] 538 | |             result
[INFO] [stdout] 539 | |         })
[INFO] [stdout]     | |__________^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:526:18: 526:28}>> <: impl futures_core::Future<Output = std::result::Result<Pin<Box<...>>, ...>> + std::marker::Send`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:523:81
[INFO] [stdout]     |
[INFO] [stdout] 523 |       ) -> impl std::future::Future<Output = Result<ChatStream, LlmError>> + Send {
[INFO] [stdout]     |  _________________________________________________________________________________^
[INFO] [stdout] 524 | |         let router = self.clone();
[INFO] [stdout] 525 | |         let messages = messages.to_vec();
[INFO] [stdout] 526 | |         Box::pin(async move {
[INFO] [stdout] ...   |
[INFO] [stdout] 539 | |         })
[INFO] [stdout] 540 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<ChatResponse, LlmError>> + std::marker::Send == Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:552:18: 552:28}>>`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:544:5
[INFO] [stdout]     |
[INFO] [stdout] 544 | /     fn chat_with_tools(
[INFO] [stdout] 545 | |         &self,
[INFO] [stdout] 546 | |         messages: &[Message],
[INFO] [stdout] 547 | |         tools: &[ToolDefinition],
[INFO] [stdout] 548 | |     ) -> impl std::future::Future<Output = Result<ChatResponse, LlmError>> + Send {
[INFO] [stdout]     | |_________________________________________________________________________________^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<ChatResponse, LlmError>> + std::marker::Send == Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:552:18: 552:28}>>`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:552:9
[INFO] [stdout]     |
[INFO] [stdout] 552 | /         Box::pin(async move {
[INFO] [stdout] 553 | |             let context_tokens: usize = messages.iter().map(|m| estimate_tokens(&m.content)).sum();
[INFO] [stdout] 554 | |             let idx = router.classify(&messages).await;
[INFO] [stdout] 555 | |             let idx = router.maybe_escalate_for_context(idx, context_tokens);
[INFO] [stdout] ...   |
[INFO] [stdout] 564 | |             result
[INFO] [stdout] 565 | |         })
[INFO] [stdout]     | |__________^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:552:18: 552:28}>> <: impl futures_core::Future<Output = std::result::Result<ChatResponse, LlmError>> + std::marker::Send`
[INFO] [stdout]    --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/triage.rs:548:83
[INFO] [stdout]     |
[INFO] [stdout] 548 |       ) -> impl std::future::Future<Output = Result<ChatResponse, LlmError>> + Send {
[INFO] [stdout]     |  ___________________________________________________________________________________^
[INFO] [stdout] 549 | |         let router = self.clone();
[INFO] [stdout] 550 | |         let messages = messages.to_vec();
[INFO] [stdout] 551 | |         let tools = tools.to_vec();
[INFO] [stdout] ...   |
[INFO] [stdout] 565 | |         })
[INFO] [stdout] 566 | |     }
[INFO] [stdout]     | |_____^
[INFO] [stdout]     |
[INFO] [stdout]     = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<std::string::String, LlmError>> + std::marker::Send == Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1446:18: 1446:28}>>`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1436:5
[INFO] [stdout]      |
[INFO] [stdout] 1436 | /     fn chat(
[INFO] [stdout] 1437 | |         &self,
[INFO] [stdout] 1438 | |         messages: &[Message],
[INFO] [stdout] 1439 | |     ) -> impl std::future::Future<Output = Result<String, LlmError>> + Send {
[INFO] [stdout]      | |___________________________________________________________________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<std::string::String, LlmError>> + std::marker::Send == Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1446:18: 1446:28}>>`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1446:9
[INFO] [stdout]      |
[INFO] [stdout] 1446 | /         Box::pin(async move {
[INFO] [stdout] ...    |
[INFO] [stdout] 1597 | |             Err(LlmError::NoProviders)
[INFO] [stdout] 1598 | |         })
[INFO] [stdout]      | |__________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1446:18: 1446:28}>> <: impl futures_core::Future<Output = std::result::Result<std::string::String, LlmError>> + std::marker::Send`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1439:77
[INFO] [stdout]      |
[INFO] [stdout] 1439 |       ) -> impl std::future::Future<Output = Result<String, LlmError>> + Send {
[INFO] [stdout]      |  _____________________________________________________________________________^
[INFO] [stdout] 1440 | |         let status_tx = self.status_tx.clone();
[INFO] [stdout] 1441 | |         let messages = messages.to_vec();
[INFO] [stdout] 1442 | |         let router = self.clone();
[INFO] [stdout] ...    |
[INFO] [stdout] 1598 | |         })
[INFO] [stdout] 1599 | |     }
[INFO] [stdout]      | |_____^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Pin<Box<(dyn Stream<Item = std::result::Result<StreamChunk, ...>> + std::marker::Send + 'static)>>, ...>> + std::marker::Send == ...`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1601:5
[INFO] [stdout]      |
[INFO] [stdout] 1601 | /     fn chat_stream(
[INFO] [stdout] 1602 | |         &self,
[INFO] [stdout] 1603 | |         messages: &[Message],
[INFO] [stdout] 1604 | |     ) -> impl std::future::Future<Output = Result<ChatStream, LlmError>> + Send {
[INFO] [stdout]      | |_______________________________________________________________________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Pin<Box<(dyn Stream<Item = std::result::Result<StreamChunk, ...>> + std::marker::Send + 'static)>>, ...>> + std::marker::Send == ...`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1608:9
[INFO] [stdout]      |
[INFO] [stdout] 1608 | /         Box::pin(async move {
[INFO] [stdout] 1609 | |             // NOTE: see DRY design decision above `chat()` — error path shared via
[INFO] [stdout] 1610 | |             // `record_fallback_error`; success paths diverge intentionally.
[INFO] [stdout] 1611 | |             if router.strategy == RouterStrategy::Cascade {
[INFO] [stdout] ...    |
[INFO] [stdout] 1661 | |             Err(LlmError::NoProviders)
[INFO] [stdout] 1662 | |         })
[INFO] [stdout]      | |__________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1608:18: 1608:28}>> <: impl futures_core::Future<Output = std::result::Result<Pin<Box<...>>, ...>> + std::marker::Send`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1604:81
[INFO] [stdout]      |
[INFO] [stdout] 1604 |       ) -> impl std::future::Future<Output = Result<ChatStream, LlmError>> + Send {
[INFO] [stdout]      |  _________________________________________________________________________________^
[INFO] [stdout] 1605 | |         let status_tx = self.status_tx.clone();
[INFO] [stdout] 1606 | |         let messages = messages.to_vec();
[INFO] [stdout] 1607 | |         let router = self.clone();
[INFO] [stdout] ...    |
[INFO] [stdout] 1662 | |         })
[INFO] [stdout] 1663 | |     }
[INFO] [stdout]      | |_____^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Vec<f32>, LlmError>> + std::marker::Send == Pin<Box<...>>`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1672:5
[INFO] [stdout]      |
[INFO] [stdout] 1672 | /     fn embed(
[INFO] [stdout] 1673 | |         &self,
[INFO] [stdout] 1674 | |         text: &str,
[INFO] [stdout] 1675 | |     ) -> impl std::future::Future<Output = Result<Vec<f32>, LlmError>> + Send {
[INFO] [stdout]      | |_____________________________________________________________________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Vec<f32>, LlmError>> + std::marker::Send == Pin<Box<...>>`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1680:9
[INFO] [stdout]      |
[INFO] [stdout] 1680 | /         Box::pin(async move {
[INFO] [stdout] 1681 | |             for p in &providers {
[INFO] [stdout] 1682 | |                 if !p.supports_embeddings() {
[INFO] [stdout] 1683 | |                     continue;
[INFO] [stdout] ...    |
[INFO] [stdout] 1753 | |             Err(LlmError::NoProviders)
[INFO] [stdout] 1754 | |         })
[INFO] [stdout]      | |__________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1680:18: 1680:28}>> <: impl futures_core::Future<Output = std::result::Result<Vec<f32>, ...>> + std::marker::Send`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1675:79
[INFO] [stdout]      |
[INFO] [stdout] 1675 |       ) -> impl std::future::Future<Output = Result<Vec<f32>, LlmError>> + Send {
[INFO] [stdout]      |  _______________________________________________________________________________^
[INFO] [stdout] 1676 | |         let providers = self.ordered_providers();
[INFO] [stdout] 1677 | |         let status_tx = self.status_tx.clone();
[INFO] [stdout] 1678 | |         let text = text.to_owned();
[INFO] [stdout] ...    |
[INFO] [stdout] 1754 | |         })
[INFO] [stdout] 1755 | |     }
[INFO] [stdout]      | |_____^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Vec<Vec<f32>>, LlmError>> + std::marker::Send == Pin<...>`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1757:5
[INFO] [stdout]      |
[INFO] [stdout] 1757 | /     fn embed_batch(
[INFO] [stdout] 1758 | |         &self,
[INFO] [stdout] 1759 | |         texts: &[&str],
[INFO] [stdout] 1760 | |     ) -> impl std::future::Future<Output = Result<Vec<Vec<f32>>, LlmError>> + Send {
[INFO] [stdout]      | |__________________________________________________________________________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<Vec<Vec<f32>>, LlmError>> + std::marker::Send == Pin<...>`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1766:9
[INFO] [stdout]      |
[INFO] [stdout] 1766 | /         Box::pin(async move {
[INFO] [stdout] 1767 | |             // Acquire embed semaphore permit before any HTTP work to cap concurrency.
[INFO] [stdout] 1768 | |             let _permit = if let Some(ref sem) = semaphore {
[INFO] [stdout] 1769 | |                 Some(sem.acquire().await.map_err(|_| LlmError::NoProviders)?)
[INFO] [stdout] ...    |
[INFO] [stdout] 1848 | |             Err(LlmError::NoProviders)
[INFO] [stdout] 1849 | |         })
[INFO] [stdout]      | |__________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1766:18: 1766:28}>> <: impl futures_core::Future<Output = std::result::Result<Vec<Vec<f32>>, ...>> + std::marker::Send`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1760:84
[INFO] [stdout]      |
[INFO] [stdout] 1760 |       ) -> impl std::future::Future<Output = Result<Vec<Vec<f32>>, LlmError>> + Send {
[INFO] [stdout]      |  ____________________________________________________________________________________^
[INFO] [stdout] 1761 | |         let providers = self.ordered_providers();
[INFO] [stdout] 1762 | |         let status_tx = self.status_tx.clone();
[INFO] [stdout] 1763 | |         let owned = owned_strs(texts);
[INFO] [stdout] ...    |
[INFO] [stdout] 1849 | |         })
[INFO] [stdout] 1850 | |     }
[INFO] [stdout]      | |_____^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<ChatResponse, LlmError>> + std::marker::Send == Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1894:18: 1894:28}>>`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1885:5
[INFO] [stdout]      |
[INFO] [stdout] 1885 | /     fn chat_with_tools(
[INFO] [stdout] 1886 | |         &self,
[INFO] [stdout] 1887 | |         messages: &[Message],
[INFO] [stdout] 1888 | |         tools: &[ToolDefinition],
[INFO] [stdout] 1889 | |     ) -> impl std::future::Future<Output = Result<ChatResponse, LlmError>> + Send {
[INFO] [stdout]      | |_________________________________________________________________________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `impl futures_core::Future<Output = std::result::Result<ChatResponse, LlmError>> + std::marker::Send == Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1894:18: 1894:28}>>`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1894:9
[INFO] [stdout]      |
[INFO] [stdout] 1894 | /         Box::pin(async move {
[INFO] [stdout] 1895 | |             // Bandit routing for tool calls: select a single provider, no quality escalation.
[INFO] [stdout] 1896 | |             if router.strategy == RouterStrategy::Bandit {
[INFO] [stdout] 1897 | |                 let query = messages
[INFO] [stdout] ...    |
[INFO] [stdout] 1963 | |             Err(LlmError::NoProviders)
[INFO] [stdout] 1964 | |         })
[INFO] [stdout]      | |__________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0275]: overflow evaluating the requirement `Pin<Box<{async block@/opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1894:18: 1894:28}>> <: impl futures_core::Future<Output = std::result::Result<ChatResponse, LlmError>> + std::marker::Send`
[INFO] [stdout]     --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/zeph-llm-0.20.1/src/router/mod.rs:1889:83
[INFO] [stdout]      |
[INFO] [stdout] 1889 |       ) -> impl std::future::Future<Output = Result<ChatResponse, LlmError>> + Send {
[INFO] [stdout]      |  ___________________________________________________________________________________^
[INFO] [stdout] 1890 | |         let messages = messages.to_vec();
[INFO] [stdout] 1891 | |         let tools = tools.to_vec();
[INFO] [stdout] 1892 | |         let status_tx = self.status_tx.clone();
[INFO] [stdout] ...    |
[INFO] [stdout] 1964 | |         })
[INFO] [stdout] 1965 | |     }
[INFO] [stdout]      | |_____^
[INFO] [stdout]      |
[INFO] [stdout]      = help: consider increasing the recursion limit by adding a `#![recursion_limit = "256"]` attribute to your crate (`zeph_llm`)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0275`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `zeph-llm` (lib) due to 30 previous errors
[INFO] running `Command { std: "docker" "inspect" "a1c462ad3ab515e4c57b89d8dc05c14e717a9c87c5c16b949f392c96fe48ce12", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a1c462ad3ab515e4c57b89d8dc05c14e717a9c87c5c16b949f392c96fe48ce12", kill_on_drop: false }`
[INFO] [stdout] a1c462ad3ab515e4c57b89d8dc05c14e717a9c87c5c16b949f392c96fe48ce12
