[INFO] fetching crate happy 0.1.1...
[INFO] checking happy-0.1.1 against master#c2f2db79ca3024f68d22b45aa22b570775c2c4ad for pr-124157
[INFO] extracting crate happy 0.1.1 into /workspace/builds/worker-1-tc1/source
[INFO] validating manifest of crates.io crate happy 0.1.1 on toolchain c2f2db79ca3024f68d22b45aa22b570775c2c4ad
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2f2db79ca3024f68d22b45aa22b570775c2c4ad" "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-1-tc1/source/Cargo.toml
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2f2db79ca3024f68d22b45aa22b570775c2c4ad" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 106 packages to latest compatible versions
[INFO] [stderr]       Adding aho-corasick v0.6.10 (latest: v1.1.3)
[INFO] [stderr]       Adding ascii v0.7.1 (latest: v1.1.0)
[INFO] [stderr]       Adding base64 v0.9.3 (latest: v0.22.1)
[INFO] [stderr]       Adding bitflags v1.3.2 (latest: v2.5.0)
[INFO] [stderr]       Adding bytes v0.4.12 (latest: v1.6.0)
[INFO] [stderr]       Adding cfg-if v0.1.10 (latest: v1.0.0)
[INFO] [stderr]       Adding cloudabi v0.0.3 (latest: v0.1.0)
[INFO] [stderr]       Adding combine v2.4.0 (latest: v4.6.7)
[INFO] [stderr]       Adding crossbeam-deque v0.7.4 (latest: v0.8.5)
[INFO] [stderr]       Adding crossbeam-epoch v0.8.2 (latest: v0.9.18)
[INFO] [stderr]       Adding crossbeam-queue v0.2.3 (latest: v0.3.11)
[INFO] [stderr]       Adding crossbeam-utils v0.7.2 (latest: v0.8.19)
[INFO] [stderr]       Adding futures v0.1.31 (latest: v0.3.30)
[INFO] [stderr]       Adding hyper v0.11.27 (latest: v1.3.1)
[INFO] [stderr]       Adding language-tags v0.2.2 (latest: v0.3.2)
[INFO] [stderr]       Adding lock_api v0.3.4 (latest: v0.4.12)
[INFO] [stderr]       Adding log v0.3.9 (latest: v0.4.21)
[INFO] [stderr]       Adding memoffset v0.5.6 (latest: v0.9.1)
[INFO] [stderr]       Adding mio v0.6.23 (latest: v0.8.11)
[INFO] [stderr]       Adding miow v0.2.2 (latest: v0.6.0)
[INFO] [stderr]       Adding parking_lot v0.9.0 (latest: v0.12.2)
[INFO] [stderr]       Adding parking_lot_core v0.6.3 (latest: v0.9.10)
[INFO] [stderr]       Adding percent-encoding v1.0.1 (latest: v2.3.1)
[INFO] [stderr]       Adding rand v0.3.23 (latest: v0.8.5)
[INFO] [stderr]       Adding rand v0.4.6 (latest: v0.8.5)
[INFO] [stderr]       Adding rand_core v0.3.1 (latest: v0.6.4)
[INFO] [stderr]       Adding rand_core v0.4.2 (latest: v0.6.4)
[INFO] [stderr]       Adding rdrand v0.4.0 (latest: v0.8.3)
[INFO] [stderr]       Adding redox_syscall v0.1.57 (latest: v0.5.1)
[INFO] [stderr]       Adding regex v0.2.11 (latest: v1.10.4)
[INFO] [stderr]       Adding regex-syntax v0.5.6 (latest: v0.8.3)
[INFO] [stderr]       Adding rustc_version v0.2.3 (latest: v0.4.0)
[INFO] [stderr]       Adding scoped-tls v0.1.2 (latest: v1.0.1)
[INFO] [stderr]       Adding semver v0.9.0 (latest: v1.0.22)
[INFO] [stderr]       Adding semver-parser v0.7.0 (latest: v0.10.2)
[INFO] [stderr]       Adding slab v0.3.0 (latest: v0.4.9)
[INFO] [stderr]       Adding smallvec v0.2.1 (latest: v1.13.2)
[INFO] [stderr]       Adding smallvec v0.6.14 (latest: v1.13.2)
[INFO] [stderr]       Adding thread_local v0.3.6 (latest: v1.1.8)
[INFO] [stderr]       Adding time v0.1.45 (latest: v0.3.36)
[INFO] [stderr]       Adding tokio v0.1.22 (latest: v1.37.0)
[INFO] [stderr]       Adding try-lock v0.1.0 (latest: v0.2.5)
[INFO] [stderr]       Adding ucd-util v0.1.10 (latest: v0.2.1)
[INFO] [stderr]       Adding want v0.0.4 (latest: v0.3.1)
[INFO] [stderr]       Adding wasi v0.10.0+wasi-snapshot-preview1 (latest: v0.13.0+wasi-0.2.0)
[INFO] [stderr]       Adding winapi v0.2.8 (latest: v0.3.9)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2f2db79ca3024f68d22b45aa22b570775c2c4ad" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded combine v2.4.0
[INFO] [stderr]   Downloaded ascii v0.7.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:99613afd962a8cfa530ec1899472a458bd015a1ab0af876cf7eb06f6006d81ea" "/opt/rustwide/cargo-home/bin/cargo" "+c2f2db79ca3024f68d22b45aa22b570775c2c4ad" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 253f4aca7dae23826c425e7d7dc7deea634c2e2f44ce9ae947c4fa0343a320bc
[INFO] running `Command { std: "docker" "start" "-a" "253f4aca7dae23826c425e7d7dc7deea634c2e2f44ce9ae947c4fa0343a320bc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "253f4aca7dae23826c425e7d7dc7deea634c2e2f44ce9ae947c4fa0343a320bc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "253f4aca7dae23826c425e7d7dc7deea634c2e2f44ce9ae947c4fa0343a320bc", kill_on_drop: false }`
[INFO] [stdout] 253f4aca7dae23826c425e7d7dc7deea634c2e2f44ce9ae947c4fa0343a320bc
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:99613afd962a8cfa530ec1899472a458bd015a1ab0af876cf7eb06f6006d81ea" "/opt/rustwide/cargo-home/bin/cargo" "+c2f2db79ca3024f68d22b45aa22b570775c2c4ad" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 025cdd2d63ba2128249fe8382171280d61ce454d419f0f142a5a3d716a35a0f4
[INFO] running `Command { std: "docker" "start" "-a" "025cdd2d63ba2128249fe8382171280d61ce454d419f0f142a5a3d716a35a0f4", kill_on_drop: false }`
[INFO] [stderr]     Checking futures v0.1.31
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]     Checking log v0.4.21
[INFO] [stderr]    Compiling semver-parser v0.7.0
[INFO] [stderr]     Checking iovec v0.1.4
[INFO] [stderr]     Checking num_cpus v1.16.0
[INFO] [stderr]     Checking net2 v0.2.39
[INFO] [stderr]     Checking smallvec v0.6.14
[INFO] [stderr]     Checking bytes v0.4.12
[INFO] [stderr]    Compiling memoffset v0.5.6
[INFO] [stderr]     Checking lock_api v0.3.4
[INFO] [stderr]    Compiling semver v0.9.0
[INFO] [stderr]     Checking mio v0.6.23
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]    Compiling rustc_version v0.2.3
[INFO] [stderr]    Compiling unicase v2.7.0
[INFO] [stderr]     Checking rand v0.4.6
[INFO] [stderr]     Checking scoped-tls v0.1.2
[INFO] [stderr]     Checking log v0.3.9
[INFO] [stderr]    Compiling parking_lot_core v0.6.3
[INFO] [stderr]    Compiling parking_lot v0.9.0
[INFO] [stderr]     Checking slab v0.3.0
[INFO] [stderr]     Checking take v0.1.0
[INFO] [stderr]     Checking mio-uds v0.6.8
[INFO] [stderr]     Checking crossbeam-queue v0.2.3
[INFO] [stderr]     Checking safemem v0.3.3
[INFO] [stderr]     Checking smallvec v0.2.1
[INFO] [stderr]    Compiling regex v0.2.11
[INFO] [stderr]    Compiling mime_guess v2.0.4
[INFO] [stderr]     Checking try-lock v0.1.0
[INFO] [stderr]     Checking rand v0.3.23
[INFO] [stderr]     Checking tokio-executor v0.1.10
[INFO] [stderr]     Checking tokio-io v0.1.13
[INFO] [stderr]     Checking tokio-sync v0.1.8
[INFO] [stderr]     Checking crossbeam-deque v0.7.4
[INFO] [stderr]     Checking tokio-service v0.1.0
[INFO] [stderr]     Checking ucd-util v0.1.10
[INFO] [stderr]     Checking want v0.0.4
[INFO] [stderr]     Checking tokio-timer v0.2.13
[INFO] [stderr]     Checking tokio-current-thread v0.1.7
[INFO] [stderr]     Checking relay v0.1.1
[INFO] [stderr]     Checking tokio-threadpool v0.1.18
[INFO] [stderr]     Checking futures-cpupool v0.1.8
[INFO] [stderr]     Checking regex-syntax v0.5.6
[INFO] [stderr]     Checking aho-corasick v0.6.10
[INFO] [stderr]     Checking base64 v0.9.3
[INFO] [stderr]     Checking time v0.1.45
[INFO] [stderr]     Checking tokio-reactor v0.1.12
[INFO] [stderr]     Checking tokio-codec v0.1.2
[INFO] [stderr]     Checking thread_local v0.3.6
[INFO] [stderr]     Checking language-tags v0.2.2
[INFO] [stderr]     Checking ascii v0.7.1
[INFO] [stderr]     Checking utf8-ranges v1.0.5
[INFO] [stderr]     Checking tokio-udp v0.1.6
[INFO] [stderr]     Checking tokio-tcp v0.1.4
[INFO] [stderr]     Checking tokio-fs v0.1.7
[INFO] [stderr]     Checking tokio-uds v0.2.7
[INFO] [stderr]     Checking combine v2.4.0
[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: 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: 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: if this is an object-safe trait, 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: if this is an object-safe trait, use `dyn`
[INFO] [stdout]    |
[INFO] [stdout] 26 | type Handler = Box<dyn Fn((
[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: if this is an object-safe trait, 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: if this is an object-safe trait, 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: if this is an object-safe trait, 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: 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: if this is an object-safe trait, 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: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: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] 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: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: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: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; 17 warnings emitted
[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] [stderr] error: could not compile `happy` (lib) due to 5 previous errors; 17 warnings emitted
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] error: aborting due to 4 previous errors; 17 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `happy` (lib test) due to 5 previous errors; 17 warnings emitted
[INFO] running `Command { std: "docker" "inspect" "025cdd2d63ba2128249fe8382171280d61ce454d419f0f142a5a3d716a35a0f4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "025cdd2d63ba2128249fe8382171280d61ce454d419f0f142a5a3d716a35a0f4", kill_on_drop: false }`
[INFO] [stdout] 025cdd2d63ba2128249fe8382171280d61ce454d419f0f142a5a3d716a35a0f4
