[INFO] fetching crate glory-routing 0.3.0...
[INFO] checking glory-routing-0.3.0 against master#30f74ff0dc4d66debc8b50724c446f817e5f75f4 for pr-121848-1
[INFO] extracting crate glory-routing 0.3.0 into /workspace/builds/worker-7-tc1/source
[INFO] validating manifest of crates.io crate glory-routing 0.3.0 on toolchain 30f74ff0dc4d66debc8b50724c446f817e5f75f4
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate glory-routing 0.3.0
[INFO] finished tweaking crates.io crate glory-routing 0.3.0
[INFO] tweaked toml for crates.io crate glory-routing 0.3.0 written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded cruet v0.14.0
[INFO] [stderr]   Downloaded serde-xml-rs v0.6.0
[INFO] [stderr]   Downloaded salvo v0.58.5
[INFO] [stderr]   Downloaded salvo-utils v0.0.6
[INFO] [stderr]   Downloaded enum-ordinalize-derive v4.3.1
[INFO] [stderr]   Downloaded enum-ordinalize v4.3.0
[INFO] [stderr]   Downloaded salvo_macros v0.60.0
[INFO] [stderr]   Downloaded salvo_macros v0.58.5
[INFO] [stderr]   Downloaded mime-infer v2.0.5
[INFO] [stderr]   Downloaded glory-hot-reload v0.3.1
[INFO] [stderr]   Downloaded rstml v0.11.2
[INFO] [stderr]   Downloaded mime-infer v3.0.0
[INFO] [stderr]   Downloaded educe v0.5.11
[INFO] [stderr]   Downloaded salvo_core v0.60.0
[INFO] [stderr]   Downloaded salvo_core v0.58.5
[INFO] [stderr]   Downloaded glory-core v0.3.1
[INFO] [stderr]   Downloaded base64 v0.22.0
[INFO] [stderr]   Downloaded cookie v0.18.1
[INFO] [stderr]   Downloaded hyper v1.0.0-rc.4
[INFO] [stderr]   Downloaded salvo v0.60.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] aa8ef66b6f6b55c7d0b7a585c068c360de49210ac2810ea35dcae1a9303b96ee
[INFO] running `Command { std: "docker" "start" "-a" "aa8ef66b6f6b55c7d0b7a585c068c360de49210ac2810ea35dcae1a9303b96ee", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "aa8ef66b6f6b55c7d0b7a585c068c360de49210ac2810ea35dcae1a9303b96ee", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "aa8ef66b6f6b55c7d0b7a585c068c360de49210ac2810ea35dcae1a9303b96ee", kill_on_drop: false }`
[INFO] [stdout] aa8ef66b6f6b55c7d0b7a585c068c360de49210ac2810ea35dcae1a9303b96ee
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+30f74ff0dc4d66debc8b50724c446f817e5f75f4" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 96f45b86ef28441f8c008a3cd779446a5e94517914d78230d6ba1ff3f549e4a6
[INFO] running `Command { std: "docker" "start" "-a" "96f45b86ef28441f8c008a3cd779446a5e94517914d78230d6ba1ff3f549e4a6", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.57
[INFO] [stderr]    Compiling wasm-bindgen-shared v0.2.92
[INFO] [stderr]    Compiling proc-macro2 v1.0.79
[INFO] [stderr]     Checking unicode-ident v1.0.12
[INFO] [stderr]    Compiling bumpalo v3.15.4
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling proc-macro2-diagnostics v0.10.1
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling wasm-bindgen v0.2.92
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]     Checking futures-core v0.3.30
[INFO] [stderr]    Compiling parking_lot_core v0.9.9
[INFO] [stderr]    Compiling num-bigint v0.4.4
[INFO] [stderr]     Checking yansi v1.0.1
[INFO] [stderr]    Compiling camino v1.1.6
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]     Checking regex-syntax v0.8.3
[INFO] [stderr]     Checking futures-channel v0.3.30
[INFO] [stderr]     Checking minimal-lexical v0.2.1
[INFO] [stderr]     Checking pathdiff v0.2.1
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking path-slash v0.2.1
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking quote v1.0.35
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]     Checking regex-automata v0.4.6
[INFO] [stderr]    Compiling wasm-bindgen-backend v0.2.92
[INFO] [stderr]     Checking regex v1.10.4
[INFO] [stderr]    Compiling serde_derive v1.0.197
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]    Compiling thiserror-impl v1.0.58
[INFO] [stderr]    Compiling enum-ordinalize-derive v4.3.1
[INFO] [stderr]    Compiling syn_derive v0.1.8
[INFO] [stderr]    Compiling async-trait v0.1.79
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]    Compiling enum-ordinalize v3.1.15
[INFO] [stderr]    Compiling wasm-bindgen-macro-support v0.2.92
[INFO] [stderr]    Compiling wasm-bindgen-macro v0.2.92
[INFO] [stderr]    Compiling educe v0.4.23
[INFO] [stderr]    Compiling enum-ordinalize v4.3.0
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]     Checking thiserror v1.0.58
[INFO] [stderr]    Compiling educe v0.5.11
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking rstml v0.11.2
[INFO] [stderr]     Checking js-sys v0.3.69
[INFO] [stderr]     Checking serde v1.0.197
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]     Checking web-sys v0.3.69
[INFO] [stderr]     Checking toml v0.5.11
[INFO] [stderr]     Checking multimap v0.9.1
[INFO] [stderr]     Checking glory-hot-reload v0.3.1
[INFO] [stderr]     Checking serde_json v1.0.115
[INFO] [stderr]     Checking config v0.13.4
[INFO] [stderr]     Checking glory-core v0.3.1
[INFO] [stderr]     Checking glory-routing v0.3.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::cell::RefCell`
[INFO] [stdout]  --> src/router.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::cell::RefCell;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::routing`
[INFO] [stdout]    --> src/filters/path.rs:893:16
[INFO] [stdout]     |
[INFO] [stdout] 893 |     use crate::routing::{PathFilter, PathState};
[INFO] [stdout]     |                ^^^^^^^ could not find `routing` in the crate root
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `head` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:109:17
[INFO] [stdout]     |
[INFO] [stdout] 109 |         assert!(head() == MethodFilter(Method::HEAD));
[INFO] [stdout]     |                 ^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this function
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use glory_core::web::widgets::head;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Request` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:119:31
[INFO] [stdout]     |
[INFO] [stdout] 119 |         fn has_one(_req: &mut Request, path: &mut PathState) -> bool {
[INFO] [stdout]     |                               ^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing one of these items
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use core::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use std::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Request` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:122:31
[INFO] [stdout]     |
[INFO] [stdout] 122 |         fn has_two(_req: &mut Request, path: &mut PathState) -> bool {
[INFO] [stdout]     |                               ^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing one of these items
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use core::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use std::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Request`
[INFO] [stdout]    --> src/filters/mod.rs:129:23
[INFO] [stdout]     |
[INFO] [stdout] 129 |         let mut req = Request::default();
[INFO] [stdout]     |                       ^^^^^^^ use of undeclared type `Request`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing one of these items
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use core::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use std::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cell::RefCell`
[INFO] [stdout]  --> src/router.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::cell::RefCell;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `indexmap::IndexMap::<K, V, S>::remove`: `remove` disrupts the map order -- use `swap_remove` or `shift_remove` for explicit behavior.
[INFO] [stdout]    --> src/lib.rs:185:62
[INFO] [stdout]     |
[INFO] [stdout] 185 |             stuff = self.stuffs().revise(|mut stuffs| stuffs.remove(graff));
[INFO] [stdout]     |                                                              ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `indexmap::IndexMap::<K, V, S>::remove`: `remove` disrupts the map order -- use `swap_remove` or `shift_remove` for explicit behavior.
[INFO] [stdout]    --> src/lib.rs:195:40
[INFO] [stdout]     |
[INFO] [stdout] 195 |         self.stuff_keys().borrow_mut().remove(graff)
[INFO] [stdout]     |                                        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `get` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:108:17
[INFO] [stdout]     |
[INFO] [stdout] 108 |         assert!(get() == MethodFilter(Method::GET));
[INFO] [stdout]     |                 ^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:108:39
[INFO] [stdout]     |
[INFO] [stdout] 108 |         assert!(get() == MethodFilter(Method::GET));
[INFO] [stdout]     |                                       ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:108:26
[INFO] [stdout]     |
[INFO] [stdout] 108 |         assert!(get() == MethodFilter(Method::GET));
[INFO] [stdout]     |                          ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:109:40
[INFO] [stdout]     |
[INFO] [stdout] 109 |         assert!(head() == MethodFilter(Method::HEAD));
[INFO] [stdout]     |                                        ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:109:27
[INFO] [stdout]     |
[INFO] [stdout] 109 |         assert!(head() == MethodFilter(Method::HEAD));
[INFO] [stdout]     |                           ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `options` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:110:17
[INFO] [stdout]     |
[INFO] [stdout] 110 |         assert!(options() == MethodFilter(Method::OPTIONS));
[INFO] [stdout]     |                 ^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:110:43
[INFO] [stdout]     |
[INFO] [stdout] 110 |         assert!(options() == MethodFilter(Method::OPTIONS));
[INFO] [stdout]     |                                           ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:110:30
[INFO] [stdout]     |
[INFO] [stdout] 110 |         assert!(options() == MethodFilter(Method::OPTIONS));
[INFO] [stdout]     |                              ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `post` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:111:17
[INFO] [stdout]     |
[INFO] [stdout] 111 |         assert!(post() == MethodFilter(Method::POST));
[INFO] [stdout]     |                 ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:111:40
[INFO] [stdout]     |
[INFO] [stdout] 111 |         assert!(post() == MethodFilter(Method::POST));
[INFO] [stdout]     |                                        ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:111:27
[INFO] [stdout]     |
[INFO] [stdout] 111 |         assert!(post() == MethodFilter(Method::POST));
[INFO] [stdout]     |                           ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `patch` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:112:17
[INFO] [stdout]     |
[INFO] [stdout] 98  | pub fn path(path: impl Into<String>) -> PathFilter {
[INFO] [stdout]     | -------------------------------------------------- similarly named function `path` defined here
[INFO] [stdout] ...
[INFO] [stdout] 112 |         assert!(patch() == MethodFilter(Method::PATCH));
[INFO] [stdout]     |                 ^^^^^ help: a function with a similar name exists: `path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:112:41
[INFO] [stdout]     |
[INFO] [stdout] 112 |         assert!(patch() == MethodFilter(Method::PATCH));
[INFO] [stdout]     |                                         ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:112:28
[INFO] [stdout]     |
[INFO] [stdout] 112 |         assert!(patch() == MethodFilter(Method::PATCH));
[INFO] [stdout]     |                            ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `put` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:113:17
[INFO] [stdout]     |
[INFO] [stdout] 113 |         assert!(put() == MethodFilter(Method::PUT));
[INFO] [stdout]     |                 ^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:113:39
[INFO] [stdout]     |
[INFO] [stdout] 113 |         assert!(put() == MethodFilter(Method::PUT));
[INFO] [stdout]     |                                       ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:113:26
[INFO] [stdout]     |
[INFO] [stdout] 113 |         assert!(put() == MethodFilter(Method::PUT));
[INFO] [stdout]     |                          ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `delete` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:114:17
[INFO] [stdout]     |
[INFO] [stdout] 114 |         assert!(delete() == MethodFilter(Method::DELETE));
[INFO] [stdout]     |                 ^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:114:42
[INFO] [stdout]     |
[INFO] [stdout] 114 |         assert!(delete() == MethodFilter(Method::DELETE));
[INFO] [stdout]     |                                          ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:114:29
[INFO] [stdout]     |
[INFO] [stdout] 114 |         assert!(delete() == MethodFilter(Method::DELETE));
[INFO] [stdout]     |                             ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:131:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 131 |         assert!(one_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_two}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:132:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 132 |         assert!(!two_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or_else` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:133:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or_else` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 133 |         assert!(one_filter.or_else(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or_else`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #3: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:134:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 134 |         assert!(one_filter.or(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::error::ParseError`
[INFO] [stdout]             candidate #3: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 3 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and_then` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:135:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and_then` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 135 |         assert!(!one_filter.and_then(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and_then`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout]             candidate #3: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #4: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:136:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 136 |         assert!(!one_filter.and(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:139:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 139 |         assert!(one_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_two}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:140:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 140 |         assert!(two_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or_else` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:141:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or_else` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 141 |         assert!(one_filter.or_else(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or_else`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #3: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:142:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 142 |         assert!(one_filter.or(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::error::ParseError`
[INFO] [stdout]             candidate #3: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and_then` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:143:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and_then` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 143 |         assert!(one_filter.and_then(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and_then`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout]             candidate #3: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #4: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:144:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 144 |         assert!(one_filter.and(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:147:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 147 |         assert!(!one_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_two}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:148:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 148 |         assert!(two_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/30f74ff0dc4d66debc8b50724c446f817e5f75f4/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or_else` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:149:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or_else` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 149 |         assert!(one_filter.or_else(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or_else`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #3: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:150:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 150 |         assert!(one_filter.or(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::error::ParseError`
[INFO] [stdout]             candidate #3: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and_then` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:151:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and_then` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 151 |         assert!(!one_filter.and_then(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and_then`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout]             candidate #3: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #4: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:152:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 152 |         assert!(!one_filter.and(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `indexmap::IndexMap::<K, V, S>::remove`: `remove` disrupts the map order -- use `swap_remove` or `shift_remove` for explicit behavior.
[INFO] [stdout]    --> src/lib.rs:185:62
[INFO] [stdout]     |
[INFO] [stdout] 185 |             stuff = self.stuffs().revise(|mut stuffs| stuffs.remove(graff));
[INFO] [stdout]     |                                                              ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `indexmap::IndexMap::<K, V, S>::remove`: `remove` disrupts the map order -- use `swap_remove` or `shift_remove` for explicit behavior.
[INFO] [stdout]    --> src/lib.rs:195:40
[INFO] [stdout]     |
[INFO] [stdout] 195 |         self.stuff_keys().borrow_mut().remove(graff)
[INFO] [stdout]     |                                        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 43 previous errors; 3 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0412, E0425, E0432, E0433, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0412`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `glory-routing` (lib test) due to 44 previous errors; 3 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "96f45b86ef28441f8c008a3cd779446a5e94517914d78230d6ba1ff3f549e4a6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "96f45b86ef28441f8c008a3cd779446a5e94517914d78230d6ba1ff3f549e4a6", kill_on_drop: false }`
[INFO] [stdout] 96f45b86ef28441f8c008a3cd779446a5e94517914d78230d6ba1ff3f549e4a6
[INFO] checking glory-routing-0.3.0 against try#72eda894eb3548c7ba774079ce0afab42958d4ee for pr-121848-1
[INFO] extracting crate glory-routing 0.3.0 into /workspace/builds/worker-7-tc2/source
[INFO] validating manifest of crates.io crate glory-routing 0.3.0 on toolchain 72eda894eb3548c7ba774079ce0afab42958d4ee
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate glory-routing 0.3.0
[INFO] finished tweaking crates.io crate glory-routing 0.3.0
[INFO] tweaked toml for crates.io crate glory-routing 0.3.0 written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] b3151792d64336ea8bb722361dbbefd21955239fca1a1394b11b7a2a99c57a8d
[INFO] running `Command { std: "docker" "start" "-a" "b3151792d64336ea8bb722361dbbefd21955239fca1a1394b11b7a2a99c57a8d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "b3151792d64336ea8bb722361dbbefd21955239fca1a1394b11b7a2a99c57a8d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b3151792d64336ea8bb722361dbbefd21955239fca1a1394b11b7a2a99c57a8d", kill_on_drop: false }`
[INFO] [stdout] b3151792d64336ea8bb722361dbbefd21955239fca1a1394b11b7a2a99c57a8d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+72eda894eb3548c7ba774079ce0afab42958d4ee" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 994e28815b126833fdf7790a7a5cdeee7042347321facb0d334bcc7ae20ed6d1
[INFO] running `Command { std: "docker" "start" "-a" "994e28815b126833fdf7790a7a5cdeee7042347321facb0d334bcc7ae20ed6d1", kill_on_drop: false }`
[INFO] [stderr]    Compiling wasm-bindgen-shared v0.2.92
[INFO] [stderr]    Compiling proc-macro2 v1.0.79
[INFO] [stderr]     Checking unicode-ident v1.0.12
[INFO] [stderr]    Compiling bumpalo v3.15.4
[INFO] [stderr]    Compiling proc-macro-error v1.0.4
[INFO] [stderr]    Compiling proc-macro2-diagnostics v0.10.1
[INFO] [stderr]    Compiling wasm-bindgen v0.2.92
[INFO] [stderr]     Checking futures-core v0.3.30
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling syn v2.0.57
[INFO] [stderr]    Compiling proc-macro-error-attr v1.0.4
[INFO] [stderr]    Compiling parking_lot_core v0.9.9
[INFO] [stderr]    Compiling num-bigint v0.4.4
[INFO] [stderr]    Compiling camino v1.1.6
[INFO] [stderr]     Checking yansi v1.0.1
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]     Checking regex-syntax v0.8.3
[INFO] [stderr]     Checking futures-channel v0.3.30
[INFO] [stderr]     Checking minimal-lexical v0.2.1
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking pathdiff v0.2.1
[INFO] [stderr]     Checking path-slash v0.2.1
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking quote v1.0.35
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]     Checking regex-automata v0.4.6
[INFO] [stderr]    Compiling wasm-bindgen-backend v0.2.92
[INFO] [stderr]     Checking regex v1.10.4
[INFO] [stderr]    Compiling serde_derive v1.0.197
[INFO] [stderr]    Compiling futures-macro v0.3.30
[INFO] [stderr]    Compiling thiserror-impl v1.0.58
[INFO] [stderr]    Compiling syn_derive v0.1.8
[INFO] [stderr]    Compiling enum-ordinalize-derive v4.3.1
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]    Compiling async-trait v0.1.79
[INFO] [stderr]    Compiling enum-ordinalize v3.1.15
[INFO] [stderr]    Compiling wasm-bindgen-macro-support v0.2.92
[INFO] [stderr]    Compiling educe v0.4.23
[INFO] [stderr]    Compiling wasm-bindgen-macro v0.2.92
[INFO] [stderr]    Compiling enum-ordinalize v4.3.0
[INFO] [stderr]     Checking futures-util v0.3.30
[INFO] [stderr]    Compiling educe v0.5.11
[INFO] [stderr]     Checking thiserror v1.0.58
[INFO] [stderr]     Checking rstml v0.11.2
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking js-sys v0.3.69
[INFO] [stderr]     Checking serde v1.0.197
[INFO] [stderr]     Checking futures-executor v0.3.30
[INFO] [stderr]     Checking futures v0.3.30
[INFO] [stderr]     Checking web-sys v0.3.69
[INFO] [stderr]     Checking toml v0.5.11
[INFO] [stderr]     Checking serde_json v1.0.115
[INFO] [stderr]     Checking glory-hot-reload v0.3.1
[INFO] [stderr]     Checking multimap v0.9.1
[INFO] [stderr]     Checking config v0.13.4
[INFO] [stderr]     Checking glory-core v0.3.1
[INFO] [stderr]     Checking glory-routing v0.3.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::cell::RefCell`
[INFO] [stdout]  --> src/router.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::cell::RefCell;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0432]: unresolved import `crate::routing`
[INFO] [stdout]    --> src/filters/path.rs:893:16
[INFO] [stdout]     |
[INFO] [stdout] 893 |     use crate::routing::{PathFilter, PathState};
[INFO] [stdout]     |                ^^^^^^^ could not find `routing` in the crate root
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `head` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:109:17
[INFO] [stdout]     |
[INFO] [stdout] 109 |         assert!(head() == MethodFilter(Method::HEAD));
[INFO] [stdout]     |                 ^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing this function
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use glory_core::web::widgets::head;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Request` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:119:31
[INFO] [stdout]     |
[INFO] [stdout] 119 |         fn has_one(_req: &mut Request, path: &mut PathState) -> bool {
[INFO] [stdout]     |                               ^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing one of these items
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use core::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use std::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Request` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:122:31
[INFO] [stdout]     |
[INFO] [stdout] 122 |         fn has_two(_req: &mut Request, path: &mut PathState) -> bool {
[INFO] [stdout]     |                               ^^^^^^^ not found in this scope
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing one of these items
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use core::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use std::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Request`
[INFO] [stdout]    --> src/filters/mod.rs:129:23
[INFO] [stdout]     |
[INFO] [stdout] 129 |         let mut req = Request::default();
[INFO] [stdout]     |                       ^^^^^^^ use of undeclared type `Request`
[INFO] [stdout]     |
[INFO] [stdout] help: consider importing one of these items
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use core::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 104 +     use std::error::Request;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cell::RefCell`
[INFO] [stdout]  --> src/router.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::cell::RefCell;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `indexmap::IndexMap::<K, V, S>::remove`: `remove` disrupts the map order -- use `swap_remove` or `shift_remove` for explicit behavior.
[INFO] [stdout]    --> src/lib.rs:185:62
[INFO] [stdout]     |
[INFO] [stdout] 185 |             stuff = self.stuffs().revise(|mut stuffs| stuffs.remove(graff));
[INFO] [stdout]     |                                                              ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `indexmap::IndexMap::<K, V, S>::remove`: `remove` disrupts the map order -- use `swap_remove` or `shift_remove` for explicit behavior.
[INFO] [stdout]    --> src/lib.rs:195:40
[INFO] [stdout]     |
[INFO] [stdout] 195 |         self.stuff_keys().borrow_mut().remove(graff)
[INFO] [stdout]     |                                        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `get` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:108:17
[INFO] [stdout]     |
[INFO] [stdout] 108 |         assert!(get() == MethodFilter(Method::GET));
[INFO] [stdout]     |                 ^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:108:39
[INFO] [stdout]     |
[INFO] [stdout] 108 |         assert!(get() == MethodFilter(Method::GET));
[INFO] [stdout]     |                                       ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:108:26
[INFO] [stdout]     |
[INFO] [stdout] 108 |         assert!(get() == MethodFilter(Method::GET));
[INFO] [stdout]     |                          ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:109:40
[INFO] [stdout]     |
[INFO] [stdout] 109 |         assert!(head() == MethodFilter(Method::HEAD));
[INFO] [stdout]     |                                        ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:109:27
[INFO] [stdout]     |
[INFO] [stdout] 109 |         assert!(head() == MethodFilter(Method::HEAD));
[INFO] [stdout]     |                           ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `options` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:110:17
[INFO] [stdout]     |
[INFO] [stdout] 110 |         assert!(options() == MethodFilter(Method::OPTIONS));
[INFO] [stdout]     |                 ^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:110:43
[INFO] [stdout]     |
[INFO] [stdout] 110 |         assert!(options() == MethodFilter(Method::OPTIONS));
[INFO] [stdout]     |                                           ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:110:30
[INFO] [stdout]     |
[INFO] [stdout] 110 |         assert!(options() == MethodFilter(Method::OPTIONS));
[INFO] [stdout]     |                              ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `post` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:111:17
[INFO] [stdout]     |
[INFO] [stdout] 111 |         assert!(post() == MethodFilter(Method::POST));
[INFO] [stdout]     |                 ^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:111:40
[INFO] [stdout]     |
[INFO] [stdout] 111 |         assert!(post() == MethodFilter(Method::POST));
[INFO] [stdout]     |                                        ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:111:27
[INFO] [stdout]     |
[INFO] [stdout] 111 |         assert!(post() == MethodFilter(Method::POST));
[INFO] [stdout]     |                           ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `patch` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:112:17
[INFO] [stdout]     |
[INFO] [stdout] 98  | pub fn path(path: impl Into<String>) -> PathFilter {
[INFO] [stdout]     | -------------------------------------------------- similarly named function `path` defined here
[INFO] [stdout] ...
[INFO] [stdout] 112 |         assert!(patch() == MethodFilter(Method::PATCH));
[INFO] [stdout]     |                 ^^^^^ help: a function with a similar name exists: `path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:112:41
[INFO] [stdout]     |
[INFO] [stdout] 112 |         assert!(patch() == MethodFilter(Method::PATCH));
[INFO] [stdout]     |                                         ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:112:28
[INFO] [stdout]     |
[INFO] [stdout] 112 |         assert!(patch() == MethodFilter(Method::PATCH));
[INFO] [stdout]     |                            ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `put` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:113:17
[INFO] [stdout]     |
[INFO] [stdout] 113 |         assert!(put() == MethodFilter(Method::PUT));
[INFO] [stdout]     |                 ^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:113:39
[INFO] [stdout]     |
[INFO] [stdout] 113 |         assert!(put() == MethodFilter(Method::PUT));
[INFO] [stdout]     |                                       ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:113:26
[INFO] [stdout]     |
[INFO] [stdout] 113 |         assert!(put() == MethodFilter(Method::PUT));
[INFO] [stdout]     |                          ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function `delete` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:114:17
[INFO] [stdout]     |
[INFO] [stdout] 114 |         assert!(delete() == MethodFilter(Method::DELETE));
[INFO] [stdout]     |                 ^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0433]: failed to resolve: use of undeclared type `Method`
[INFO] [stdout]    --> src/filters/mod.rs:114:42
[INFO] [stdout]     |
[INFO] [stdout] 114 |         assert!(delete() == MethodFilter(Method::DELETE));
[INFO] [stdout]     |                                          ^^^^^^ use of undeclared type `Method`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0425]: cannot find function, tuple struct or tuple variant `MethodFilter` in this scope
[INFO] [stdout]    --> src/filters/mod.rs:114:29
[INFO] [stdout]     |
[INFO] [stdout] 114 |         assert!(delete() == MethodFilter(Method::DELETE));
[INFO] [stdout]     |                             ^^^^^^^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:131:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 131 |         assert!(one_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_two}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:132:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 132 |         assert!(!two_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or_else` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:133:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or_else` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 133 |         assert!(one_filter.or_else(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or_else`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #3: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:134:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 134 |         assert!(one_filter.or(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::error::ParseError`
[INFO] [stdout]             candidate #3: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and_then` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:135:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and_then` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 135 |         assert!(!one_filter.and_then(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and_then`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout]             candidate #3: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #4: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 3 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:136:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 136 |         assert!(!one_filter.and(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:139:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 139 |         assert!(one_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_two}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:140:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 140 |         assert!(two_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or_else` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:141:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or_else` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 141 |         assert!(one_filter.or_else(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or_else`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #3: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:142:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 142 |         assert!(one_filter.or(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::error::ParseError`
[INFO] [stdout]             candidate #3: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and_then` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:143:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and_then` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 143 |         assert!(one_filter.and_then(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and_then`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout]             candidate #3: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #4: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:144:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 144 |         assert!(one_filter.and(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:147:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 147 |         assert!(!one_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `filter` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_two}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:148:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `filter` not found for this struct because it doesn't satisfy `_: Filter` or `_: Iterator`
[INFO] [stdout] ...
[INFO] [stdout] 148 |         assert!(two_filter.filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = note: the following trait bounds were not satisfied:
[INFO] [stdout]             `filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout]             which is required by `&mut filters::FnFilter<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_two}>: Iterator`
[INFO] [stdout] note: the trait `Iterator` must be implemented
[INFO] [stdout]    --> /rustc/72eda894eb3548c7ba774079ce0afab42958d4ee/library/core/src/iter/traits/iterator.rs:44:1
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `filter`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `Iterator`
[INFO] [stdout]             candidate #3: `futures_util::stream::stream::StreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or_else` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:149:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or_else` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 149 |         assert!(one_filter.or_else(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or_else`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #3: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `or` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:150:28
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `or` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 150 |         assert!(one_filter.or(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                            ^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `or`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::error::ParseError`
[INFO] [stdout]             candidate #3: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and_then` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:151:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and_then` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 151 |         assert!(!one_filter.and_then(has_two).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^^^^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and_then`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout]             candidate #3: `futures_util::future::try_future::TryFutureExt`
[INFO] [stdout]             candidate #4: `futures_util::stream::try_stream::TryStreamExt`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0599]: the method `and` exists for struct `FnFilter<fn(&mut {type error}, &mut PathState) -> bool {has_one}>`, but its trait bounds were not satisfied
[INFO] [stdout]    --> src/filters/mod.rs:152:29
[INFO] [stdout]     |
[INFO] [stdout] 77  | pub struct FnFilter<F>(pub F);
[INFO] [stdout]     | ---------------------- method `and` not found for this struct because it doesn't satisfy `_: Filter`
[INFO] [stdout] ...
[INFO] [stdout] 152 |         assert!(!one_filter.and(two_filter).filter(&mut req, &mut path_state));
[INFO] [stdout]     |                             ^^^ method cannot be called due to unsatisfied trait bounds
[INFO] [stdout]     |
[INFO] [stdout] note: the following trait bounds were not satisfied:
[INFO] [stdout]       `<for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one} as FnOnce<(&ssr::Url, &Truck, &mut PathState)>>::Output = bool`
[INFO] [stdout]       `for<'a, 'b> fn(&'a mut {type error}, &'b mut PathState) -> bool {has_one}: Fn<(&ssr::Url, &Truck, &mut PathState)>`
[INFO] [stdout]    --> src/filters/mod.rs:81:8
[INFO] [stdout]     |
[INFO] [stdout] 79  | impl<F> Filter for FnFilter<F>
[INFO] [stdout]     |         ------     -----------
[INFO] [stdout] 80  | where
[INFO] [stdout] 81  |     F: Fn(&Url, &Truck, &mut PathState) -> bool + 'static,
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |        |                                   |
[INFO] [stdout]     |        |                                   unsatisfied trait bound introduced here
[INFO] [stdout]     |        unsatisfied trait bound introduced here
[INFO] [stdout]     = help: items from traits can only be used if the trait is implemented and in scope
[INFO] [stdout]     = note: the following traits define an item `and`, perhaps you need to implement one of them:
[INFO] [stdout]             candidate #1: `filters::Filter`
[INFO] [stdout]             candidate #2: `nom::internal::Parser`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `indexmap::IndexMap::<K, V, S>::remove`: `remove` disrupts the map order -- use `swap_remove` or `shift_remove` for explicit behavior.
[INFO] [stdout]    --> src/lib.rs:185:62
[INFO] [stdout]     |
[INFO] [stdout] 185 |             stuff = self.stuffs().revise(|mut stuffs| stuffs.remove(graff));
[INFO] [stdout]     |                                                              ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `indexmap::IndexMap::<K, V, S>::remove`: `remove` disrupts the map order -- use `swap_remove` or `shift_remove` for explicit behavior.
[INFO] [stdout]    --> src/lib.rs:195:40
[INFO] [stdout]     |
[INFO] [stdout] 195 |         self.stuff_keys().borrow_mut().remove(graff)
[INFO] [stdout]     |                                        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 43 previous errors; 3 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0412, E0425, E0432, E0433, E0599.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0412`.
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `glory-routing` (lib test) due to 44 previous errors; 3 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "994e28815b126833fdf7790a7a5cdeee7042347321facb0d334bcc7ae20ed6d1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "994e28815b126833fdf7790a7a5cdeee7042347321facb0d334bcc7ae20ed6d1", kill_on_drop: false }`
[INFO] [stdout] 994e28815b126833fdf7790a7a5cdeee7042347321facb0d334bcc7ae20ed6d1
