[INFO] crate peruse 0.3.0 is already in cache
[INFO] checking peruse-0.3.0 against master#bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc for pr-70917
[INFO] extracting crate peruse 0.3.0 into /workspace/builds/worker-8/source
[INFO] validating manifest of crates.io crate peruse 0.3.0 on toolchain bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking crates.io crate peruse 0.3.0
[INFO] finished tweaking crates.io crate peruse 0.3.0
[INFO] tweaked toml for crates.io crate peruse 0.3.0 written to /workspace/builds/worker-8/source/Cargo.toml
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"`
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-8/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "check" "--frozen" "--all" "--all-targets"`
[INFO] [stdout] 06d641f8787aea1b3f56dbc6459924c0701cdb2d3e53642b20f9f8101a9c4433
[INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
[INFO] running `"docker" "start" "-a" "06d641f8787aea1b3f56dbc6459924c0701cdb2d3e53642b20f9f8101a9c4433"`
[INFO] [stderr]     Checking peruse v0.3.0 (/opt/rustwide/workdir)
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/peruse/parsers.rs:62:46
[INFO] [stderr]    |
[INFO] [stderr] 62 | pub fn recursive<I:?Sized,O, F:  Fn() -> Box<Parser<I=I,O=O>>>(f: F) -> RecursiveParser<I,O,F> {
[INFO] [stderr]    |                                              ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/peruse/parsers.rs:75:34
[INFO] [stderr]    |
[INFO] [stderr] 75 | pub fn boxed<I: ?Sized,O>(b: Box<Parser<I=I, O=O>>) -> BoxedParser<I,O> {
[INFO] [stderr]    |                                  ^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I, O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:152:18
[INFO] [stderr]     |
[INFO] [stderr] 152 |   mapper: Rc<Box<Fn(P::O) -> T>>,
[INFO] [stderr]     |                  ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(P::O) -> T`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:222:66
[INFO] [stderr]     |
[INFO] [stderr] 222 | pub struct RecursiveParser<I: ?Sized, O, F> where F: Fn() -> Box<Parser<I=I,O=O>>{
[INFO] [stderr]     |                                                                  ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:226:79
[INFO] [stderr]     |
[INFO] [stderr] 226 | impl<I:?Sized, O, F> Parser for RecursiveParser<I, O, F> where F: Fn() -> Box<Parser<I=I,O=O>> {
[INFO] [stderr]     |                                                                               ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:237:89
[INFO] [stderr]     |
[INFO] [stderr] 237 | impl<I:?Sized, O, F> ParserCombinator for RecursiveParser<I, O, F> where F: Fn() -> Box<Parser<I=I,O=O>> {}
[INFO] [stderr]     |                                                                                         ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:239:79
[INFO] [stderr]     |
[INFO] [stderr] 239 | impl<I: ?Sized, O, F> Clone for RecursiveParser<I, O, F> where F: Fn() -> Box<Parser<I=I,O=O>> {
[INFO] [stderr]     |                                                                               ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:330:18
[INFO] [stderr]     |
[INFO] [stderr] 330 |   parser: Rc<Box<Parser<I=I,O=O>>>
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/peruse/slice_parsers.rs:4:29
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub type SliceParser<I,O> = Parser<I=[I], O=O>;
[INFO] [stderr]   |                             ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=[I], O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/peruse/slice_parsers.rs:49:19
[INFO] [stderr]    |
[INFO] [stderr] 49 |   matcher: Rc<Box<Fn(T) -> Option<U>>>
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(T) -> Option<U>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/peruse/string_parsers.rs:7:28
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub type StringParser<T> = Parser<I=str, O=T>;
[INFO] [stderr]   |                            ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=str, O=T>`
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `parsers::*`
[INFO] [stderr]  --> src/peruse/slice_parser_tests.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use parsers::*;
[INFO] [stderr]   |     ^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `slice_parsers::*`
[INFO] [stderr]  --> src/peruse/slice_parser_tests.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use slice_parsers::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `parsers::*`
[INFO] [stderr]  --> src/peruse/string_parser_tests.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use parsers::*;
[INFO] [stderr]   |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `string_parsers::*`
[INFO] [stderr]  --> src/peruse/string_parser_tests.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use string_parsers::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::str::FromStr`
[INFO] [stderr]  --> src/peruse/string_parser_tests.rs:3:5
[INFO] [stderr]   |
[INFO] [stderr] 3 | use std::str::FromStr;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/peruse/parsers.rs:62:46
[INFO] [stderr]    |
[INFO] [stderr] 62 | pub fn recursive<I:?Sized,O, F:  Fn() -> Box<Parser<I=I,O=O>>>(f: F) -> RecursiveParser<I,O,F> {
[INFO] [stderr]    |                                              ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/peruse/parsers.rs:75:34
[INFO] [stderr]    |
[INFO] [stderr] 75 | pub fn boxed<I: ?Sized,O>(b: Box<Parser<I=I, O=O>>) -> BoxedParser<I,O> {
[INFO] [stderr]    |                                  ^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I, O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:152:18
[INFO] [stderr]     |
[INFO] [stderr] 152 |   mapper: Rc<Box<Fn(P::O) -> T>>,
[INFO] [stderr]     |                  ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(P::O) -> T`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:222:66
[INFO] [stderr]     |
[INFO] [stderr] 222 | pub struct RecursiveParser<I: ?Sized, O, F> where F: Fn() -> Box<Parser<I=I,O=O>>{
[INFO] [stderr]     |                                                                  ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:226:79
[INFO] [stderr]     |
[INFO] [stderr] 226 | impl<I:?Sized, O, F> Parser for RecursiveParser<I, O, F> where F: Fn() -> Box<Parser<I=I,O=O>> {
[INFO] [stderr]     |                                                                               ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:237:89
[INFO] [stderr]     |
[INFO] [stderr] 237 | impl<I:?Sized, O, F> ParserCombinator for RecursiveParser<I, O, F> where F: Fn() -> Box<Parser<I=I,O=O>> {}
[INFO] [stderr]     |                                                                                         ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:239:79
[INFO] [stderr]     |
[INFO] [stderr] 239 | impl<I: ?Sized, O, F> Clone for RecursiveParser<I, O, F> where F: Fn() -> Box<Parser<I=I,O=O>> {
[INFO] [stderr]     |                                                                               ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/parsers.rs:330:18
[INFO] [stderr]     |
[INFO] [stderr] 330 |   parser: Rc<Box<Parser<I=I,O=O>>>
[INFO] [stderr]     |                  ^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=I,O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/peruse/slice_parsers.rs:4:29
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub type SliceParser<I,O> = Parser<I=[I], O=O>;
[INFO] [stderr]   |                             ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=[I], O=O>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/peruse/slice_parsers.rs:49:19
[INFO] [stderr]    |
[INFO] [stderr] 49 |   matcher: Rc<Box<Fn(T) -> Option<U>>>
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn(T) -> Option<U>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]  --> src/peruse/string_parsers.rs:7:28
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub type StringParser<T> = Parser<I=str, O=T>;
[INFO] [stderr]   |                            ^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=str, O=T>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/peruse/slice_parser_tests.rs:57:23
[INFO] [stderr]    |
[INFO] [stderr] 57 |   fn recurse() -> Box<Parser<I=[i32], O=i32>> {
[INFO] [stderr]    |                       ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=[i32], O=i32>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/peruse/slice_parser_tests.rs:179:26
[INFO] [stderr]     |
[INFO] [stderr] 179 |   fn expression() -> Box<Parser<I=[Token], O=Expression>> {
[INFO] [stderr]     |                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Parser<I=[Token], O=Expression>`
[INFO] [stderr] 
[INFO] [stderr]     Finished dev [unoptimized + debuginfo] target(s) in 1.08s
[INFO] running `"docker" "inspect" "06d641f8787aea1b3f56dbc6459924c0701cdb2d3e53642b20f9f8101a9c4433"`
[INFO] running `"docker" "rm" "-f" "06d641f8787aea1b3f56dbc6459924c0701cdb2d3e53642b20f9f8101a9c4433"`
[INFO] [stdout] 06d641f8787aea1b3f56dbc6459924c0701cdb2d3e53642b20f9f8101a9c4433
