[INFO] fetching crate happy 0.1.1...
[INFO] checking happy-0.1.1 against master#5518eaa946291f00471af8b254b2a1715f234882 for pr-120393
[INFO] extracting crate happy 0.1.1 into /workspace/builds/worker-7-tc1/source
[INFO] validating manifest of crates.io crate happy 0.1.1 on toolchain 5518eaa946291f00471af8b254b2a1715f234882
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+5518eaa946291f00471af8b254b2a1715f234882" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate happy 0.1.1
[INFO] finished tweaking crates.io crate happy 0.1.1
[INFO] tweaked toml for crates.io crate happy 0.1.1 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" "+5518eaa946291f00471af8b254b2a1715f234882" "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" "+5518eaa946291f00471af8b254b2a1715f234882" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded relay v0.1.1
[INFO] [stderr]   Downloaded slab v0.3.0
[INFO] [stderr]   Downloaded take v0.1.0
[INFO] [stderr]   Downloaded want v0.0.4
[INFO] [stderr]   Downloaded ascii v0.7.1
[INFO] [stderr]   Downloaded try-lock v0.1.0
[INFO] [stderr]   Downloaded hyper v0.11.27
[INFO] [stderr]   Downloaded smallvec v0.2.1
[INFO] [stderr]   Downloaded tokio-service v0.1.0
[INFO] [stderr]   Downloaded combine v2.4.0
[INFO] [stderr]   Downloaded tokio-proto v0.1.1
[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" "+5518eaa946291f00471af8b254b2a1715f234882" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7f4623d2008b1e86878fe06ee53656765bde026258f4b29a424ec0e847a3f797
[INFO] running `Command { std: "docker" "start" "-a" "7f4623d2008b1e86878fe06ee53656765bde026258f4b29a424ec0e847a3f797", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7f4623d2008b1e86878fe06ee53656765bde026258f4b29a424ec0e847a3f797", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7f4623d2008b1e86878fe06ee53656765bde026258f4b29a424ec0e847a3f797", kill_on_drop: false }`
[INFO] [stdout] 7f4623d2008b1e86878fe06ee53656765bde026258f4b29a424ec0e847a3f797
[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" "+5518eaa946291f00471af8b254b2a1715f234882" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 034ee7748d2760cbb4e3d9999b5548a62781e4b267c1237cdeb6fec5795edcbd
[INFO] running `Command { std: "docker" "start" "-a" "034ee7748d2760cbb4e3d9999b5548a62781e4b267c1237cdeb6fec5795edcbd", kill_on_drop: false }`
[INFO] [stderr]     Checking tokio-service v0.1.0
[INFO] [stderr]     Checking log v0.3.9
[INFO] [stderr]     Checking mio v0.6.23
[INFO] [stderr]     Checking rand v0.3.23
[INFO] [stderr]    Compiling regex v0.2.11
[INFO] [stderr]     Checking slab v0.3.0
[INFO] [stderr]     Checking tokio-io v0.1.13
[INFO] [stderr]     Checking try-lock v0.1.0
[INFO] [stderr]     Checking ucd-util v0.1.10
[INFO] [stderr]     Checking tokio-threadpool v0.1.18
[INFO] [stderr]     Checking take v0.1.0
[INFO] [stderr]     Checking safemem v0.3.3
[INFO] [stderr]     Checking smallvec v0.2.1
[INFO] [stderr]     Checking aho-corasick v0.6.10
[INFO] [stderr]     Checking futures-cpupool v0.1.8
[INFO] [stderr]     Checking relay v0.1.1
[INFO] [stderr]     Checking thread_local v0.3.6
[INFO] [stderr]     Checking language-tags v0.2.2
[INFO] [stderr]     Checking want v0.0.4
[INFO] [stderr]     Checking ascii v0.7.1
[INFO] [stderr]     Checking base64 v0.9.3
[INFO] [stderr]     Checking utf8-ranges v1.0.5
[INFO] [stderr]     Checking regex-syntax v0.5.6
[INFO] [stderr]     Checking void v1.0.2
[INFO] [stderr]     Checking combine v2.4.0
[INFO] [stderr]     Checking tokio-codec v0.1.2
[INFO] [stderr]     Checking tokio-fs v0.1.7
[INFO] [stderr]     Checking tokio-reactor v0.1.12
[INFO] [stderr]     Checking mio-uds v0.6.8
[INFO] [stderr]     Checking tokio-udp v0.1.6
[INFO] [stderr]     Checking tokio-tcp v0.1.4
[INFO] [stderr]     Checking tokio-uds v0.2.7
[INFO] [stderr]     Checking tokio v0.1.22
[INFO] [stderr]     Checking tokio-core v0.1.18
[INFO] [stderr]     Checking tokio-proto v0.1.1
[INFO] [stderr]     Checking hyper v0.11.27
[INFO] [stderr]     Checking happy v0.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/api.rs:26:23
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  _______________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout]    | |________^
[INFO] [stdout] ...
[INFO] [stdout] 30 |            hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout]    |                                   ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 ~ type Handler = Box<Fn((hyper::Method, 
[INFO] [stdout] 27 |          hyper::Uri, 
[INFO] [stdout] 28 |          hyper::HttpVersion, 
[INFO] [stdout] 29 ~          hyper::header::Headers), Vec<u8>) -> 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]   --> src/api.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 5  | use futures::{BoxFuture, Future};
[INFO] [stdout]    |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 81 |         use futures::Future;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]    --> src/api.rs:179:13
[INFO] [stdout]     |
[INFO] [stdout] 5   | use futures::{BoxFuture, Future};
[INFO] [stdout]     |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 179 |         use futures::Future;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]   --> src/parse_route.rs:91:9
[INFO] [stdout]    |
[INFO] [stdout] 1  | use combine::{self, Parser}; 
[INFO] [stdout]    |                     ------ the item `Parser` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 91 |     use combine::Parser;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/api.rs:26:23
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  _______________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout]    | |________^
[INFO] [stdout] ...
[INFO] [stdout] 30 |            hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout]    |                                   ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 ~ type Handler = Box<Fn((hyper::Method, 
[INFO] [stdout] 27 |          hyper::Uri, 
[INFO] [stdout] 28 |          hyper::HttpVersion, 
[INFO] [stdout] 29 ~          hyper::header::Headers), Vec<u8>) -> 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]   --> src/api.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 5  | use futures::{BoxFuture, Future};
[INFO] [stdout]    |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 81 |         use futures::Future;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]    --> src/api.rs:179:13
[INFO] [stdout]     |
[INFO] [stdout] 5   | use futures::{BoxFuture, Future};
[INFO] [stdout]     |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 179 |         use futures::Future;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]   --> src/parse_route.rs:91:9
[INFO] [stdout]    |
[INFO] [stdout] 1  | use combine::{self, Parser}; 
[INFO] [stdout]    |                     ------ the item `Parser` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 91 |     use combine::Parser;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]  --> src/api.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use futures::{BoxFuture, Future};
[INFO] [stdout]   |               ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    |             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |           F: Fn(Request) -> BoxFuture<Response, ErrorKind> + Send + Sync + 'static {
[INFO] [stdout]     |                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:174:19
[INFO] [stdout]     |
[INFO] [stdout] 174 |     type Future = BoxFuture<Response, ::hyper::Error>;
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::ascii::AsciiExt::eq_ignore_ascii_case`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:62:40
[INFO] [stdout]    |
[INFO] [stdout] 62 |         string_cmp(s, |a, b| AsciiExt::eq_ignore_ascii_case(&a, &b))
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated trait `std::ascii::AsciiExt`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:48:21
[INFO] [stdout]    |
[INFO] [stdout] 48 |     use std::ascii::AsciiExt;
[INFO] [stdout]    |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]  --> src/static_file.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use mime_guess::guess_mime_type;
[INFO] [stdout]   |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]   --> src/static_file.rs:30:24
[INFO] [stdout]    |
[INFO] [stdout] 30 |             let mime = guess_mime_type(&local_path);
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<Error + Send + 'static>),
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<dyn Error + Send + 'static>),
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:26:20
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  ____________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout] 28 | |          hyper::Uri, 
[INFO] [stdout] 29 | |          hyper::HttpVersion, 
[INFO] [stdout] 30 | |          hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout] 31 | |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    | |________________________________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 26 | type Handler = Box<dyn Fn((
[INFO] [stdout]    |                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/parse_route.rs:21:25
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = dyn combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]  --> src/api.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use futures::{BoxFuture, Future};
[INFO] [stdout]   |               ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    |             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |           F: Fn(Request) -> BoxFuture<Response, ErrorKind> + Send + Sync + 'static {
[INFO] [stdout]     |                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:174:19
[INFO] [stdout]     |
[INFO] [stdout] 174 |     type Future = BoxFuture<Response, ::hyper::Error>;
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::ascii::AsciiExt::eq_ignore_ascii_case`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:62:40
[INFO] [stdout]    |
[INFO] [stdout] 62 |         string_cmp(s, |a, b| AsciiExt::eq_ignore_ascii_case(&a, &b))
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated trait `std::ascii::AsciiExt`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:48:21
[INFO] [stdout]    |
[INFO] [stdout] 48 |     use std::ascii::AsciiExt;
[INFO] [stdout]    |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]  --> src/static_file.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use mime_guess::guess_mime_type;
[INFO] [stdout]   |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]   --> src/static_file.rs:30:24
[INFO] [stdout]    |
[INFO] [stdout] 30 |             let mime = guess_mime_type(&local_path);
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<Error + Send + 'static>),
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<dyn Error + Send + 'static>),
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:26:20
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  ____________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout] 28 | |          hyper::Uri, 
[INFO] [stdout] 29 | |          hyper::HttpVersion, 
[INFO] [stdout] 30 | |          hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout] 31 | |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    | |________________________________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 26 | type Handler = Box<dyn Fn((
[INFO] [stdout]    |                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/parse_route.rs:21:25
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = dyn combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:89:65
[INFO] [stdout]    |
[INFO] [stdout] 89 |                 Err(e) => return err(ErrorKind::Deserialize(e)).boxed(),
[INFO] [stdout]    |                                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:108:16
[INFO] [stdout]     |
[INFO] [stdout] 108 |             }).boxed()
[INFO] [stdout]     |                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:89:65
[INFO] [stdout]    |
[INFO] [stdout] 89 |                 Err(e) => return err(ErrorKind::Deserialize(e)).boxed(),
[INFO] [stdout]    |                                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:191:33
[INFO] [stdout]     |
[INFO] [stdout] 191 |             return ok(response).boxed()
[INFO] [stdout]     |                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:108:16
[INFO] [stdout]     |
[INFO] [stdout] 108 |             }).boxed()
[INFO] [stdout]     |                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:235:20
[INFO] [stdout]     |
[INFO] [stdout] 235 |             result.boxed()
[INFO] [stdout]     |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:243:21
[INFO] [stdout]     |
[INFO] [stdout] 243 |             ok(res).boxed()
[INFO] [stdout]     |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:191:33
[INFO] [stdout]     |
[INFO] [stdout] 191 |             return ok(response).boxed()
[INFO] [stdout]     |                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:235:20
[INFO] [stdout]     |
[INFO] [stdout] 235 |             result.boxed()
[INFO] [stdout]     |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:243:21
[INFO] [stdout]     |
[INFO] [stdout] 243 |             ok(res).boxed()
[INFO] [stdout]     |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn verb<'a>() -> Box<StrParser<'a, Option<Method>>> {
[INFO] [stdout]    |         -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 69 |     optional(verbs_and_space).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn verb<'a>() -> Box<StrParser<'a, Option<Method>>> {
[INFO] [stdout]    |         -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 69 |     optional(verbs_and_space).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | fn segment_piece<'a>() -> Box<StrParser<'a, SegmentPiece>> {
[INFO] [stdout]    |                  -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 78 |     literal.map(|r| SegmentPiece::Literal(r)).or(pattern).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 81 | fn segment<'a>() -> Box<StrParser<'a, Segment>> {
[INFO] [stdout]    |            -- lifetime `'a` defined here
[INFO] [stdout] 82 |     many1(segment_piece()).map(Segment).and(optional(token('/'))).map(|(v, _)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn url<'a>() -> Box<StrParser<'a, Vec<Segment>>> {
[INFO] [stdout]    |        -- lifetime `'a` defined here
[INFO] [stdout] 86 |     optional(token('/')).and(many1(segment())).map(|(_, v)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | fn segment_piece<'a>() -> Box<StrParser<'a, SegmentPiece>> {
[INFO] [stdout]    |                  -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 78 |     literal.map(|r| SegmentPiece::Literal(r)).or(pattern).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 81 | fn segment<'a>() -> Box<StrParser<'a, Segment>> {
[INFO] [stdout]    |            -- lifetime `'a` defined here
[INFO] [stdout] 82 |     many1(segment_piece()).map(Segment).and(optional(token('/'))).map(|(v, _)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn url<'a>() -> Box<StrParser<'a, Vec<Segment>>> {
[INFO] [stdout]    |        -- lifetime `'a` defined here
[INFO] [stdout] 86 |     optional(token('/')).and(many1(segment())).map(|(_, v)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 4 previous errors; 20 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `happy` (lib) due to 5 previous errors; 20 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error: aborting due to 4 previous errors; 20 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `happy` (lib test) due to 5 previous errors; 20 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "034ee7748d2760cbb4e3d9999b5548a62781e4b267c1237cdeb6fec5795edcbd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "034ee7748d2760cbb4e3d9999b5548a62781e4b267c1237cdeb6fec5795edcbd", kill_on_drop: false }`
[INFO] [stdout] 034ee7748d2760cbb4e3d9999b5548a62781e4b267c1237cdeb6fec5795edcbd
[INFO] checking happy-0.1.1 against try#7622c0f807a4e13c4db886a1681bf343795692df+rustflags=-Dnon_local_definitions for pr-120393
[INFO] extracting crate happy 0.1.1 into /workspace/builds/worker-7-tc2/source
[INFO] validating manifest of crates.io crate happy 0.1.1 on toolchain 7622c0f807a4e13c4db886a1681bf343795692df
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+7622c0f807a4e13c4db886a1681bf343795692df" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate happy 0.1.1
[INFO] finished tweaking crates.io crate happy 0.1.1
[INFO] tweaked toml for crates.io crate happy 0.1.1 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" "+7622c0f807a4e13c4db886a1681bf343795692df" "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" "+7622c0f807a4e13c4db886a1681bf343795692df" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[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" "+7622c0f807a4e13c4db886a1681bf343795692df" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 22dc09341b3d445286f46dae3b5eeedc62fa90a04931750381ef5420b80c3bc2
[INFO] running `Command { std: "docker" "start" "-a" "22dc09341b3d445286f46dae3b5eeedc62fa90a04931750381ef5420b80c3bc2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "22dc09341b3d445286f46dae3b5eeedc62fa90a04931750381ef5420b80c3bc2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "22dc09341b3d445286f46dae3b5eeedc62fa90a04931750381ef5420b80c3bc2", kill_on_drop: false }`
[INFO] [stdout] 22dc09341b3d445286f46dae3b5eeedc62fa90a04931750381ef5420b80c3bc2
[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 -Dnon_local_definitions" "-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" "+7622c0f807a4e13c4db886a1681bf343795692df" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0f6574a650913133bf4c839c3598995ebde6822ad425b3cd6bbdadea57366e9d
[INFO] running `Command { std: "docker" "start" "-a" "0f6574a650913133bf4c839c3598995ebde6822ad425b3cd6bbdadea57366e9d", kill_on_drop: false }`
[INFO] [stderr]     Checking log v0.3.9
[INFO] [stderr]     Checking tokio-service v0.1.0
[INFO] [stderr]     Checking smallvec v0.2.1
[INFO] [stderr]     Checking mio v0.6.23
[INFO] [stderr]     Checking rand v0.3.23
[INFO] [stderr]     Checking try-lock v0.1.0
[INFO] [stderr]     Checking safemem v0.3.3
[INFO] [stderr]     Checking take v0.1.0
[INFO] [stderr]     Checking tokio-io v0.1.13
[INFO] [stderr]     Checking ucd-util v0.1.10
[INFO] [stderr]     Checking tokio-threadpool v0.1.18
[INFO] [stderr]    Compiling regex v0.2.11
[INFO] [stderr]     Checking slab v0.3.0
[INFO] [stderr]     Checking aho-corasick v0.6.10
[INFO] [stderr]     Checking futures-cpupool v0.1.8
[INFO] [stderr]     Checking relay v0.1.1
[INFO] [stderr]     Checking thread_local v0.3.6
[INFO] [stderr]     Checking want v0.0.4
[INFO] [stderr]     Checking language-tags v0.2.2
[INFO] [stderr]     Checking base64 v0.9.3
[INFO] [stderr]     Checking utf8-ranges v1.0.5
[INFO] [stderr]     Checking regex-syntax v0.5.6
[INFO] [stderr]     Checking ascii v0.7.1
[INFO] [stderr]     Checking void v1.0.2
[INFO] [stderr]     Checking combine v2.4.0
[INFO] [stderr]     Checking tokio-codec v0.1.2
[INFO] [stderr]     Checking tokio-fs v0.1.7
[INFO] [stderr]     Checking tokio-reactor v0.1.12
[INFO] [stderr]     Checking mio-uds v0.6.8
[INFO] [stderr]     Checking tokio-uds v0.2.7
[INFO] [stderr]     Checking tokio-tcp v0.1.4
[INFO] [stderr]     Checking tokio-udp v0.1.6
[INFO] [stderr]     Checking tokio v0.1.22
[INFO] [stderr]     Checking tokio-core v0.1.18
[INFO] [stderr]     Checking tokio-proto v0.1.1
[INFO] [stderr]     Checking hyper v0.11.27
[INFO] [stderr]     Checking happy v0.1.1 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/api.rs:26:23
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  _______________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout]    | |________^
[INFO] [stdout] ...
[INFO] [stdout] 30 |            hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout]    |                                   ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 ~ type Handler = Box<Fn((hyper::Method, 
[INFO] [stdout] 27 |          hyper::Uri, 
[INFO] [stdout] 28 |          hyper::HttpVersion, 
[INFO] [stdout] 29 ~          hyper::header::Headers), Vec<u8>) -> 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]   --> src/api.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 5  | use futures::{BoxFuture, Future};
[INFO] [stdout]    |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 81 |         use futures::Future;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]    --> src/api.rs:179:13
[INFO] [stdout]     |
[INFO] [stdout] 5   | use futures::{BoxFuture, Future};
[INFO] [stdout]     |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 179 |         use futures::Future;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]   --> src/parse_route.rs:91:9
[INFO] [stdout]    |
[INFO] [stdout] 1  | use combine::{self, Parser}; 
[INFO] [stdout]    |                     ------ the item `Parser` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 91 |     use combine::Parser;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/api.rs:26:23
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  _______________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout]    | |________^
[INFO] [stdout] ...
[INFO] [stdout] 30 |            hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout]    |                                   ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 26 ~ type Handler = Box<Fn((hyper::Method, 
[INFO] [stdout] 27 |          hyper::Uri, 
[INFO] [stdout] 28 |          hyper::HttpVersion, 
[INFO] [stdout] 29 ~          hyper::header::Headers), Vec<u8>) -> 
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]   --> src/api.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 5  | use futures::{BoxFuture, Future};
[INFO] [stdout]    |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 81 |         use futures::Future;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Future` is imported redundantly
[INFO] [stdout]    --> src/api.rs:179:13
[INFO] [stdout]     |
[INFO] [stdout] 5   | use futures::{BoxFuture, Future};
[INFO] [stdout]     |                          ------ the item `Future` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 179 |         use futures::Future;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `Parser` is imported redundantly
[INFO] [stdout]   --> src/parse_route.rs:91:9
[INFO] [stdout]    |
[INFO] [stdout] 1  | use combine::{self, Parser}; 
[INFO] [stdout]    |                     ------ the item `Parser` is already imported here
[INFO] [stdout] ...
[INFO] [stdout] 91 |     use combine::Parser;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]  --> src/api.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use futures::{BoxFuture, Future};
[INFO] [stdout]   |               ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    |             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |           F: Fn(Request) -> BoxFuture<Response, ErrorKind> + Send + Sync + 'static {
[INFO] [stdout]     |                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:174:19
[INFO] [stdout]     |
[INFO] [stdout] 174 |     type Future = BoxFuture<Response, ::hyper::Error>;
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::ascii::AsciiExt::eq_ignore_ascii_case`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:62:40
[INFO] [stdout]    |
[INFO] [stdout] 62 |         string_cmp(s, |a, b| AsciiExt::eq_ignore_ascii_case(&a, &b))
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated trait `std::ascii::AsciiExt`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:48:21
[INFO] [stdout]    |
[INFO] [stdout] 48 |     use std::ascii::AsciiExt;
[INFO] [stdout]    |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]  --> src/static_file.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use mime_guess::guess_mime_type;
[INFO] [stdout]   |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]   --> src/static_file.rs:30:24
[INFO] [stdout]    |
[INFO] [stdout] 30 |             let mime = guess_mime_type(&local_path);
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<Error + Send + 'static>),
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<dyn Error + Send + 'static>),
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:26:20
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  ____________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout] 28 | |          hyper::Uri, 
[INFO] [stdout] 29 | |          hyper::HttpVersion, 
[INFO] [stdout] 30 | |          hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout] 31 | |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    | |________________________________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 26 | type Handler = Box<dyn Fn((
[INFO] [stdout]    |                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/parse_route.rs:21:25
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = dyn combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]  --> src/api.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use futures::{BoxFuture, Future};
[INFO] [stdout]   |               ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:31:13
[INFO] [stdout]    |
[INFO] [stdout] 31 |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    |             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:115:29
[INFO] [stdout]     |
[INFO] [stdout] 115 |           F: Fn(Request) -> BoxFuture<Response, ErrorKind> + Send + Sync + 'static {
[INFO] [stdout]     |                             ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated type alias `futures::BoxFuture`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:174:19
[INFO] [stdout]     |
[INFO] [stdout] 174 |     type Future = BoxFuture<Response, ::hyper::Error>;
[INFO] [stdout]     |                   ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `std::ascii::AsciiExt::eq_ignore_ascii_case`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:62:40
[INFO] [stdout]    |
[INFO] [stdout] 62 |         string_cmp(s, |a, b| AsciiExt::eq_ignore_ascii_case(&a, &b))
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated trait `std::ascii::AsciiExt`: use inherent methods instead
[INFO] [stdout]   --> src/parse_route.rs:48:21
[INFO] [stdout]    |
[INFO] [stdout] 48 |     use std::ascii::AsciiExt;
[INFO] [stdout]    |                     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]  --> src/static_file.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use mime_guess::guess_mime_type;
[INFO] [stdout]   |                 ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `mime_guess::guess_mime_type`: Use `from_path(path).first_or_octet_stream()` instead
[INFO] [stdout]   --> src/static_file.rs:30:24
[INFO] [stdout]    |
[INFO] [stdout] 30 |             let mime = guess_mime_type(&local_path);
[INFO] [stdout]    |                        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:23:14
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<Error + Send + 'static>),
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 23 |     User(Box<dyn Error + Send + 'static>),
[INFO] [stdout]    |              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/api.rs:26:20
[INFO] [stdout]    |
[INFO] [stdout] 26 |   type Handler = Box<Fn((
[INFO] [stdout]    |  ____________________^
[INFO] [stdout] 27 | |         (hyper::Method, 
[INFO] [stdout] 28 | |          hyper::Uri, 
[INFO] [stdout] 29 | |          hyper::HttpVersion, 
[INFO] [stdout] 30 | |          hyper::header::Headers)), Vec<u8>) -> 
[INFO] [stdout] 31 | |             BoxFuture<Response, ErrorKind> + Send + Sync> ;
[INFO] [stdout]    | |________________________________________________________^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 26 | type Handler = Box<dyn Fn((
[INFO] [stdout]    |                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]   --> src/parse_route.rs:21:25
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = warning: this is accepted in the current edition (Rust 2015) but is a hard error in Rust 2021!
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout] help: use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 21 | type StrParser<'a, R> = dyn combine::Parser<Output=R, Input=&'a str>;
[INFO] [stdout]    |                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:89:65
[INFO] [stdout]    |
[INFO] [stdout] 89 |                 Err(e) => return err(ErrorKind::Deserialize(e)).boxed(),
[INFO] [stdout]    |                                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:108:16
[INFO] [stdout]     |
[INFO] [stdout] 108 |             }).boxed()
[INFO] [stdout]     |                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:191:33
[INFO] [stdout]     |
[INFO] [stdout] 191 |             return ok(response).boxed()
[INFO] [stdout]     |                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]   --> src/api.rs:89:65
[INFO] [stdout]    |
[INFO] [stdout] 89 |                 Err(e) => return err(ErrorKind::Deserialize(e)).boxed(),
[INFO] [stdout]    |                                                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:108:16
[INFO] [stdout]     |
[INFO] [stdout] 108 |             }).boxed()
[INFO] [stdout]     |                ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:191:33
[INFO] [stdout]     |
[INFO] [stdout] 191 |             return ok(response).boxed()
[INFO] [stdout]     |                                 ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:235:20
[INFO] [stdout]     |
[INFO] [stdout] 235 |             result.boxed()
[INFO] [stdout]     |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:235:20
[INFO] [stdout]     |
[INFO] [stdout] 235 |             result.boxed()
[INFO] [stdout]     |                    ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:243:21
[INFO] [stdout]     |
[INFO] [stdout] 243 |             ok(res).boxed()
[INFO] [stdout]     |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `futures::Future::boxed`: removed without replacement, recommended to use a local extension trait or function if needed, more details in https://github.com/rust-lang-nursery/futures-rs/issues/228
[INFO] [stdout]    --> src/api.rs:243:21
[INFO] [stdout]     |
[INFO] [stdout] 243 |             ok(res).boxed()
[INFO] [stdout]     |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn verb<'a>() -> Box<StrParser<'a, Option<Method>>> {
[INFO] [stdout]    |         -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 69 |     optional(verbs_and_space).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn verb<'a>() -> Box<StrParser<'a, Option<Method>>> {
[INFO] [stdout]    |         -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 69 |     optional(verbs_and_space).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | fn segment_piece<'a>() -> Box<StrParser<'a, SegmentPiece>> {
[INFO] [stdout]    |                  -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 78 |     literal.map(|r| SegmentPiece::Literal(r)).or(pattern).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | fn segment_piece<'a>() -> Box<StrParser<'a, SegmentPiece>> {
[INFO] [stdout]    |                  -- lifetime `'a` defined here
[INFO] [stdout] ...
[INFO] [stdout] 78 |     literal.map(|r| SegmentPiece::Literal(r)).or(pattern).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 81 | fn segment<'a>() -> Box<StrParser<'a, Segment>> {
[INFO] [stdout]    |            -- lifetime `'a` defined here
[INFO] [stdout] 82 |     many1(segment_piece()).map(Segment).and(optional(token('/'))).map(|(v, _)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:82:5
[INFO] [stdout]    |
[INFO] [stdout] 81 | fn segment<'a>() -> Box<StrParser<'a, Segment>> {
[INFO] [stdout]    |            -- lifetime `'a` defined here
[INFO] [stdout] 82 |     many1(segment_piece()).map(Segment).and(optional(token('/'))).map(|(v, _)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn url<'a>() -> Box<StrParser<'a, Vec<Segment>>> {
[INFO] [stdout]    |        -- lifetime `'a` defined here
[INFO] [stdout] 86 |     optional(token('/')).and(many1(segment())).map(|(_, v)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: lifetime may not live long enough
[INFO] [stdout]   --> src/parse_route.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 85 | fn url<'a>() -> Box<StrParser<'a, Vec<Segment>>> {
[INFO] [stdout]    |        -- lifetime `'a` defined here
[INFO] [stdout] 86 |     optional(token('/')).and(many1(segment())).map(|(_, v)| v).boxed()
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ returning this value requires that `'a` must outlive `'static`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error: aborting due to 4 previous errors; 20 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `happy` (lib) due to 5 previous errors; 20 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error: aborting due to 4 previous errors; 20 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `happy` (lib test) due to 5 previous errors; 20 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "0f6574a650913133bf4c839c3598995ebde6822ad425b3cd6bbdadea57366e9d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0f6574a650913133bf4c839c3598995ebde6822ad425b3cd6bbdadea57366e9d", kill_on_drop: false }`
[INFO] [stdout] 0f6574a650913133bf4c839c3598995ebde6822ad425b3cd6bbdadea57366e9d
