[INFO] cloning repository https://github.com/emj-lang/clex [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/emj-lang/clex" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Femj-lang%2Fclex", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Femj-lang%2Fclex'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 82efe9636b722d6eeb4558ca67feefaf44faad85 [INFO] checking emj-lang/clex against try#8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8 for pr-82565 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Femj-lang%2Fclex" "/workspace/builds/worker-11/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-11/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/emj-lang/clex on toolchain 8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/emj-lang/clex [INFO] finished tweaking git repo https://github.com/emj-lang/clex [INFO] tweaked toml for git repo https://github.com/emj-lang/clex written to /workspace/builds/worker-11/source/Cargo.toml [INFO] crate git repo https://github.com/emj-lang/clex already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-11/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-11/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" "rustops/crates-build-env@sha256:f2f6bcd4b43ebee4e173f653a26493129bdb64017c85f916b780ca7fbdbaa79d" "/opt/rustwide/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 3345d89cf395616d3139cd9dc2a6e55e435fec3384c11d326cc2d00d31d5fbbc [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "3345d89cf395616d3139cd9dc2a6e55e435fec3384c11d326cc2d00d31d5fbbc", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "3345d89cf395616d3139cd9dc2a6e55e435fec3384c11d326cc2d00d31d5fbbc", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "3345d89cf395616d3139cd9dc2a6e55e435fec3384c11d326cc2d00d31d5fbbc", kill_on_drop: false }` [INFO] [stdout] 3345d89cf395616d3139cd9dc2a6e55e435fec3384c11d326cc2d00d31d5fbbc [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-11/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-11/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" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "rustops/crates-build-env@sha256:f2f6bcd4b43ebee4e173f653a26493129bdb64017c85f916b780ca7fbdbaa79d" "/opt/rustwide/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 5b572f2c72489c3e86e95414deb20ff6745fd97fabe9a7e49e4d10fa9e191ddf [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "5b572f2c72489c3e86e95414deb20ff6745fd97fabe9a7e49e4d10fa9e191ddf", kill_on_drop: false }` [INFO] [stderr] Checking clex v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/basic.rs:38:35 [INFO] [stdout] | [INFO] [stdout] 38 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/basic.rs:58:35 [INFO] [stdout] | [INFO] [stdout] 58 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/basic.rs:79:35 [INFO] [stdout] | [INFO] [stdout] 79 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/basic.rs:102:13 [INFO] [stdout] | [INFO] [stdout] 102 | try!(write!(f, "%")); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/matchers/basic.rs:105:22 [INFO] [stdout] | [INFO] [stdout] 105 | b @ 0x20 ... 0x7E => write!(f, "{}", b as char), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/basic.rs:112:35 [INFO] [stdout] | [INFO] [stdout] 112 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/group.rs:12:23 [INFO] [stdout] | [INFO] [stdout] 12 | children: Vec>, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/group.rs:25:45 [INFO] [stdout] | [INFO] [stdout] 25 | pub fn push_child(&mut self, child: Box) { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/group.rs:32:40 [INFO] [stdout] | [INFO] [stdout] 32 | fn compare_next(&self, state: &mut MatchState, next: Option<&Next>) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/group.rs:53:9 [INFO] [stdout] | [INFO] [stdout] 53 | try!(write!(f, "(")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/group.rs:55:13 [INFO] [stdout] | [INFO] [stdout] 55 | try!(write!(f, "*")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/group.rs:58:13 [INFO] [stdout] | [INFO] [stdout] 58 | try!(write!(f, "<")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/group.rs:61:13 [INFO] [stdout] | [INFO] [stdout] 61 | try!(write!(f, "{}", c)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:9:15 [INFO] [stdout] | [INFO] [stdout] 9 | next: Box, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:15:12 [INFO] [stdout] | [INFO] [stdout] 15 | PE(Box), [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:16:20 [INFO] [stdout] | [INFO] [stdout] 16 | R { lower: Box, upper: Box }, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:16:48 [INFO] [stdout] | [INFO] [stdout] 16 | R { lower: Box, upper: Box }, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:20:26 [INFO] [stdout] | [INFO] [stdout] 20 | pub fn new(next: Box, elements: Vec, negated: bool) -> Set { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:26:35 [INFO] [stdout] | [INFO] [stdout] 26 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:86:9 [INFO] [stdout] | [INFO] [stdout] 86 | try!(write!(f, "[")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:88:13 [INFO] [stdout] | [INFO] [stdout] 88 | try!(write!(f, "*")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:92:46 [INFO] [stdout] | [INFO] [stdout] 92 | &SetElement::PE(ref pe) => { try!(write!(f, "{}", pe)); }, [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:94:21 [INFO] [stdout] | [INFO] [stdout] 94 | try!(write!(f, "{}", lower)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:95:21 [INFO] [stdout] | [INFO] [stdout] 95 | try!(write!(f, ":")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:96:21 [INFO] [stdout] | [INFO] [stdout] 96 | try!(write!(f, "{}", upper)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:100:9 [INFO] [stdout] | [INFO] [stdout] 100 | try!(write!(f, "]")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:113:20 [INFO] [stdout] | [INFO] [stdout] 113 | state: &'a mut MatchState, [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:119:27 [INFO] [stdout] | [INFO] [stdout] 119 | fn new(state: &'a mut MatchState) -> MatchStateProxy<'a> { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:183:54 [INFO] [stdout] | [INFO] [stdout] 183 | fn get_ud(&mut self) -> &mut HashMap> { [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Any` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/quantifiers.rs:17:21 [INFO] [stdout] | [INFO] [stdout] 17 | quantified: Box, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/quantifiers.rs:18:15 [INFO] [stdout] | [INFO] [stdout] 18 | next: Box, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/quantifiers.rs:22:64 [INFO] [stdout] | [INFO] [stdout] 22 | pub fn new(quantification: Quantification, quantified: Box, next: Box) -> Quantifier { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/quantifiers.rs:22:91 [INFO] [stdout] | [INFO] [stdout] 22 | pub fn new(quantification: Quantification, quantified: Box, next: Box) -> Quantifier { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/quantifiers.rs:28:35 [INFO] [stdout] | [INFO] [stdout] 28 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/quantifiers.rs:85:9 [INFO] [stdout] | [INFO] [stdout] 85 | try!(write!(f, "{}", self.quantified)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/quantifiers.rs:87:39 [INFO] [stdout] | [INFO] [stdout] 87 | Quantification::Greedy => try!(write!(f, "+")), [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/quantifiers.rs:88:42 [INFO] [stdout] | [INFO] [stdout] 88 | Quantification::NonGreedy => try!(write!(f, "-")), [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/quantifiers.rs:89:41 [INFO] [stdout] | [INFO] [stdout] 89 | Quantification::Optional => try!(write!(f, "?")), [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/root.rs:9:23 [INFO] [stdout] | [INFO] [stdout] 9 | children: Vec>, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/root.rs:13:34 [INFO] [stdout] | [INFO] [stdout] 13 | pub fn new(children: Vec>) -> Root { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/root.rs:17:45 [INFO] [stdout] | [INFO] [stdout] 17 | pub fn push_child(&mut self, child: Box) { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/root.rs:25:35 [INFO] [stdout] | [INFO] [stdout] 25 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/root.rs:36:13 [INFO] [stdout] | [INFO] [stdout] 36 | try!(write!(f, "{}", c)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/slice.rs:7:21 [INFO] [stdout] | [INFO] [stdout] 7 | slice: &'a [Box], [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/slice.rs:14:32 [INFO] [stdout] | [INFO] [stdout] 14 | pub fn new(slice: &'a [Box], capture: bool, startpos: usize, backmatch: bool) -> Slice<'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/slice.rs:18:35 [INFO] [stdout] | [INFO] [stdout] 18 | pub fn simple(slice: &'a [Box]) -> Slice<'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/slice.rs:30:40 [INFO] [stdout] | [INFO] [stdout] 30 | fn compare_next(&self, state: &mut MatchState, next: Option<&Next>) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchstate.rs:11:35 [INFO] [stdout] | [INFO] [stdout] 11 | userdata: HashMap>, [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Any` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchstate.rs:74:54 [INFO] [stdout] | [INFO] [stdout] 74 | fn get_ud(&mut self) -> &mut HashMap> { [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Any` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:20:54 [INFO] [stdout] | [INFO] [stdout] 20 | fn get_ud(&mut self) -> &mut HashMap>; [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Any` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:37:18 [INFO] [stdout] | [INFO] [stdout] 37 | element: &'a PatternElement, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:42:29 [INFO] [stdout] | [INFO] [stdout] 42 | pub fn new(element: &'a PatternElement, next: Option<&'b Next>) -> Next<'a, 'b> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:46:31 [INFO] [stdout] | [INFO] [stdout] 46 | pub fn element(&self) -> &PatternElement { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:54:39 [INFO] [stdout] | [INFO] [stdout] 54 | pub fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:60:35 [INFO] [stdout] | [INFO] [stdout] 60 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:64:40 [INFO] [stdout] | [INFO] [stdout] 64 | fn compare_next(&self, state: &mut MatchState, Option<&Next>) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:73:44 [INFO] [stdout] | [INFO] [stdout] 73 | pub fn parse(pattern: &[u8]) -> Result, String> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/lib.rs:82:38 [INFO] [stdout] | [INFO] [stdout] 82 | ... c @ b'A' ... b'Z' | c @ b'a' ... b'z' => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/lib.rs:82:58 [INFO] [stdout] | [INFO] [stdout] 82 | ... c @ b'A' ... b'Z' | c @ b'a' ... b'z' => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/basic.rs:38:35 [INFO] [stdout] | [INFO] [stdout] 38 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/basic.rs:58:35 [INFO] [stdout] | [INFO] [stdout] 58 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/basic.rs:79:35 [INFO] [stdout] | [INFO] [stdout] 79 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/basic.rs:102:13 [INFO] [stdout] | [INFO] [stdout] 102 | try!(write!(f, "%")); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/matchers/basic.rs:105:22 [INFO] [stdout] | [INFO] [stdout] 105 | b @ 0x20 ... 0x7E => write!(f, "{}", b as char), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/basic.rs:112:35 [INFO] [stdout] | [INFO] [stdout] 112 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/group.rs:12:23 [INFO] [stdout] | [INFO] [stdout] 12 | children: Vec>, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/group.rs:25:45 [INFO] [stdout] | [INFO] [stdout] 25 | pub fn push_child(&mut self, child: Box) { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/group.rs:32:40 [INFO] [stdout] | [INFO] [stdout] 32 | fn compare_next(&self, state: &mut MatchState, next: Option<&Next>) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/group.rs:53:9 [INFO] [stdout] | [INFO] [stdout] 53 | try!(write!(f, "(")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/group.rs:55:13 [INFO] [stdout] | [INFO] [stdout] 55 | try!(write!(f, "*")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/group.rs:58:13 [INFO] [stdout] | [INFO] [stdout] 58 | try!(write!(f, "<")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/group.rs:61:13 [INFO] [stdout] | [INFO] [stdout] 61 | try!(write!(f, "{}", c)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:9:15 [INFO] [stdout] | [INFO] [stdout] 9 | next: Box, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:15:12 [INFO] [stdout] | [INFO] [stdout] 15 | PE(Box), [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:16:20 [INFO] [stdout] | [INFO] [stdout] 16 | R { lower: Box, upper: Box }, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:16:48 [INFO] [stdout] | [INFO] [stdout] 16 | R { lower: Box, upper: Box }, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:20:26 [INFO] [stdout] | [INFO] [stdout] 20 | pub fn new(next: Box, elements: Vec, negated: bool) -> Set { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:26:35 [INFO] [stdout] | [INFO] [stdout] 26 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:86:9 [INFO] [stdout] | [INFO] [stdout] 86 | try!(write!(f, "[")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:88:13 [INFO] [stdout] | [INFO] [stdout] 88 | try!(write!(f, "*")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:92:46 [INFO] [stdout] | [INFO] [stdout] 92 | &SetElement::PE(ref pe) => { try!(write!(f, "{}", pe)); }, [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:94:21 [INFO] [stdout] | [INFO] [stdout] 94 | try!(write!(f, "{}", lower)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:95:21 [INFO] [stdout] | [INFO] [stdout] 95 | try!(write!(f, ":")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:96:21 [INFO] [stdout] | [INFO] [stdout] 96 | try!(write!(f, "{}", upper)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/set.rs:100:9 [INFO] [stdout] | [INFO] [stdout] 100 | try!(write!(f, "]")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:113:20 [INFO] [stdout] | [INFO] [stdout] 113 | state: &'a mut MatchState, [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:119:27 [INFO] [stdout] | [INFO] [stdout] 119 | fn new(state: &'a mut MatchState) -> MatchStateProxy<'a> { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/set.rs:183:54 [INFO] [stdout] | [INFO] [stdout] 183 | fn get_ud(&mut self) -> &mut HashMap> { [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Any` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/quantifiers.rs:17:21 [INFO] [stdout] | [INFO] [stdout] 17 | quantified: Box, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/quantifiers.rs:18:15 [INFO] [stdout] | [INFO] [stdout] 18 | next: Box, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/quantifiers.rs:22:64 [INFO] [stdout] | [INFO] [stdout] 22 | pub fn new(quantification: Quantification, quantified: Box, next: Box) -> Quantifier { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/quantifiers.rs:22:91 [INFO] [stdout] | [INFO] [stdout] 22 | pub fn new(quantification: Quantification, quantified: Box, next: Box) -> Quantifier { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/quantifiers.rs:28:35 [INFO] [stdout] | [INFO] [stdout] 28 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/quantifiers.rs:85:9 [INFO] [stdout] | [INFO] [stdout] 85 | try!(write!(f, "{}", self.quantified)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/quantifiers.rs:87:39 [INFO] [stdout] | [INFO] [stdout] 87 | Quantification::Greedy => try!(write!(f, "+")), [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/quantifiers.rs:88:42 [INFO] [stdout] | [INFO] [stdout] 88 | Quantification::NonGreedy => try!(write!(f, "-")), [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/quantifiers.rs:89:41 [INFO] [stdout] | [INFO] [stdout] 89 | Quantification::Optional => try!(write!(f, "?")), [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/root.rs:9:23 [INFO] [stdout] | [INFO] [stdout] 9 | children: Vec>, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/root.rs:13:34 [INFO] [stdout] | [INFO] [stdout] 13 | pub fn new(children: Vec>) -> Root { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/root.rs:17:45 [INFO] [stdout] | [INFO] [stdout] 17 | pub fn push_child(&mut self, child: Box) { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/root.rs:25:35 [INFO] [stdout] | [INFO] [stdout] 25 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/matchers/root.rs:36:13 [INFO] [stdout] | [INFO] [stdout] 36 | try!(write!(f, "{}", c)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/slice.rs:7:21 [INFO] [stdout] | [INFO] [stdout] 7 | slice: &'a [Box], [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/slice.rs:14:32 [INFO] [stdout] | [INFO] [stdout] 14 | pub fn new(slice: &'a [Box], capture: bool, startpos: usize, backmatch: bool) -> Slice<'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/slice.rs:18:35 [INFO] [stdout] | [INFO] [stdout] 18 | pub fn simple(slice: &'a [Box]) -> Slice<'a> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchers/slice.rs:30:40 [INFO] [stdout] | [INFO] [stdout] 30 | fn compare_next(&self, state: &mut MatchState, next: Option<&Next>) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchstate.rs:11:35 [INFO] [stdout] | [INFO] [stdout] 11 | userdata: HashMap>, [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Any` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/matchstate.rs:74:54 [INFO] [stdout] | [INFO] [stdout] 74 | fn get_ud(&mut self) -> &mut HashMap> { [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Any` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:20:54 [INFO] [stdout] | [INFO] [stdout] 20 | fn get_ud(&mut self) -> &mut HashMap>; [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Any` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:37:18 [INFO] [stdout] | [INFO] [stdout] 37 | element: &'a PatternElement, [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:42:29 [INFO] [stdout] | [INFO] [stdout] 42 | pub fn new(element: &'a PatternElement, next: Option<&'b Next>) -> Next<'a, 'b> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:46:31 [INFO] [stdout] | [INFO] [stdout] 46 | pub fn element(&self) -> &PatternElement { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:54:39 [INFO] [stdout] | [INFO] [stdout] 54 | pub fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:60:35 [INFO] [stdout] | [INFO] [stdout] 60 | fn compare(&self, state: &mut MatchState) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:64:40 [INFO] [stdout] | [INFO] [stdout] 64 | fn compare_next(&self, state: &mut MatchState, Option<&Next>) -> CompareResult { [INFO] [stdout] | ^^^^^^^^^^ help: use `dyn`: `dyn MatchState` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:73:44 [INFO] [stdout] | [INFO] [stdout] 73 | pub fn parse(pattern: &[u8]) -> Result, String> { [INFO] [stdout] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn PatternElement` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/lib.rs:82:38 [INFO] [stdout] | [INFO] [stdout] 82 | ... c @ b'A' ... b'Z' | c @ b'a' ... b'z' => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/lib.rs:82:58 [INFO] [stdout] | [INFO] [stdout] 82 | ... c @ b'A' ... b'Z' | c @ b'a' ... b'z' => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 59 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 59 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 0.80s [INFO] running `Command { std: "docker" "inspect" "5b572f2c72489c3e86e95414deb20ff6745fd97fabe9a7e49e4d10fa9e191ddf", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5b572f2c72489c3e86e95414deb20ff6745fd97fabe9a7e49e4d10fa9e191ddf", kill_on_drop: false }` [INFO] [stdout] 5b572f2c72489c3e86e95414deb20ff6745fd97fabe9a7e49e4d10fa9e191ddf