[INFO] fetching crate grammar-utils 0.2.0...
[INFO] testing grammar-utils-0.2.0 against master#c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38 for pr-146098-7
[INFO] extracting crate grammar-utils 0.2.0 into /workspace/builds/worker-0-tc1/source
[INFO] started tweaking crates.io crate grammar-utils 0.2.0
[INFO] finished tweaking crates.io crate grammar-utils 0.2.0
[INFO] tweaked toml for crates.io crate grammar-utils 0.2.0 written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate grammar-utils 0.2.0 on toolchain c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate grammar-utils 0.2.0 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c98a20810662baabf22e7c6db13a5bc33458acd2b49149f8186c2d2736ed486e
[INFO] running `Command { std: "docker" "start" "-a" "c98a20810662baabf22e7c6db13a5bc33458acd2b49149f8186c2d2736ed486e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c98a20810662baabf22e7c6db13a5bc33458acd2b49149f8186c2d2736ed486e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c98a20810662baabf22e7c6db13a5bc33458acd2b49149f8186c2d2736ed486e", kill_on_drop: false }`
[INFO] [stdout] c98a20810662baabf22e7c6db13a5bc33458acd2b49149f8186c2d2736ed486e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a3d2831fa3cb9798721d7a9592b522e206ee5d037877eb233a11b6b753986a18
[INFO] running `Command { std: "docker" "start" "-a" "a3d2831fa3cb9798721d7a9592b522e206ee5d037877eb233a11b6b753986a18", kill_on_drop: false }`
[INFO] [stderr]    Compiling grammar-utils v0.2.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr0/table.rs:146:22
[INFO] [stdout]     |
[INFO] [stdout] 146 |     pub fn conflicts(&self) -> Vec<Conflict> {
[INFO] [stdout]     |                      ^^^^^         ^^^^^^^^
[INFO] [stdout]     |                      |             |
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 146 |     pub fn conflicts(&self) -> Vec<Conflict<'_>> {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr0/table.rs:201:18
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub fn state(&self) -> &'t State {
[INFO] [stdout]     |                  ^^^^^         ^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub fn state(&self) -> &'t State<'_> {
[INFO] [stdout]     |                                     ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr1/table.rs:169:22
[INFO] [stdout]     |
[INFO] [stdout] 169 |     pub fn conflicts(&self) -> Vec<Conflict> {
[INFO] [stdout]     |                      ^^^^^         ^^^^^^^^
[INFO] [stdout]     |                      |             |
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 169 |     pub fn conflicts(&self) -> Vec<Conflict<'_>> {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr1/table.rs:224:18
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn state(&self) -> &'t State {
[INFO] [stdout]     |                  ^^^^^         ^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn state(&self) -> &'t State<'_> {
[INFO] [stdout]     |                                     ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:212:20
[INFO] [stdout]     |
[INFO] [stdout] 212 |     pub fn symbols(&self) -> Vec<Symbol> {
[INFO] [stdout]     |                    ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 212 |     pub fn symbols(&self) -> Vec<Symbol<'_>> {
[INFO] [stdout]     |                                        ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:224:22
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn terminals(&self) -> Vec<Symbol> {
[INFO] [stdout]     |                      ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn terminals(&self) -> Vec<Symbol<'_>> {
[INFO] [stdout]     |                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:235:25
[INFO] [stdout]     |
[INFO] [stdout] 235 |     pub fn nonterminals(&self) -> Vec<Symbol> {
[INFO] [stdout]     |                         ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 235 |     pub fn nonterminals(&self) -> Vec<Symbol<'_>> {
[INFO] [stdout]     |                                             ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:246:18
[INFO] [stdout]     |
[INFO] [stdout] 246 |     pub fn rules(&self) -> Vec<Rule> {
[INFO] [stdout]     |                  ^^^^^         ^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 246 |     pub fn rules(&self) -> Vec<Rule<'_>> {
[INFO] [stdout]     |                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:258:34
[INFO] [stdout]     |
[INFO] [stdout] 258 |     pub fn symbol<S: AsRef<str>>(&self, name: S) -> Option<Symbol> {
[INFO] [stdout]     |                                  ^^^^^                     ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 258 |     pub fn symbol<S: AsRef<str>>(&self, name: S) -> Option<Symbol<'_>> {
[INFO] [stdout]     |                                                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1.22s
[INFO] running `Command { std: "docker" "inspect" "a3d2831fa3cb9798721d7a9592b522e206ee5d037877eb233a11b6b753986a18", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a3d2831fa3cb9798721d7a9592b522e206ee5d037877eb233a11b6b753986a18", kill_on_drop: false }`
[INFO] [stdout] a3d2831fa3cb9798721d7a9592b522e206ee5d037877eb233a11b6b753986a18
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] ff3fb63b2fdbfd5206755e067973532283a9d3c11ca85795f9f1770c09951876
[INFO] running `Command { std: "docker" "start" "-a" "ff3fb63b2fdbfd5206755e067973532283a9d3c11ca85795f9f1770c09951876", kill_on_drop: false }`
[INFO] [stderr]    Compiling grammar-utils v0.2.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr0/table.rs:146:22
[INFO] [stdout]     |
[INFO] [stdout] 146 |     pub fn conflicts(&self) -> Vec<Conflict> {
[INFO] [stdout]     |                      ^^^^^         ^^^^^^^^
[INFO] [stdout]     |                      |             |
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 146 |     pub fn conflicts(&self) -> Vec<Conflict<'_>> {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr0/table.rs:201:18
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub fn state(&self) -> &'t State {
[INFO] [stdout]     |                  ^^^^^         ^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub fn state(&self) -> &'t State<'_> {
[INFO] [stdout]     |                                     ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr1/table.rs:169:22
[INFO] [stdout]     |
[INFO] [stdout] 169 |     pub fn conflicts(&self) -> Vec<Conflict> {
[INFO] [stdout]     |                      ^^^^^         ^^^^^^^^
[INFO] [stdout]     |                      |             |
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 169 |     pub fn conflicts(&self) -> Vec<Conflict<'_>> {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr1/table.rs:224:18
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn state(&self) -> &'t State {
[INFO] [stdout]     |                  ^^^^^         ^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn state(&self) -> &'t State<'_> {
[INFO] [stdout]     |                                     ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:212:20
[INFO] [stdout]     |
[INFO] [stdout] 212 |     pub fn symbols(&self) -> Vec<Symbol> {
[INFO] [stdout]     |                    ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 212 |     pub fn symbols(&self) -> Vec<Symbol<'_>> {
[INFO] [stdout]     |                                        ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:224:22
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn terminals(&self) -> Vec<Symbol> {
[INFO] [stdout]     |                      ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn terminals(&self) -> Vec<Symbol<'_>> {
[INFO] [stdout]     |                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:235:25
[INFO] [stdout]     |
[INFO] [stdout] 235 |     pub fn nonterminals(&self) -> Vec<Symbol> {
[INFO] [stdout]     |                         ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 235 |     pub fn nonterminals(&self) -> Vec<Symbol<'_>> {
[INFO] [stdout]     |                                             ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:246:18
[INFO] [stdout]     |
[INFO] [stdout] 246 |     pub fn rules(&self) -> Vec<Rule> {
[INFO] [stdout]     |                  ^^^^^         ^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 246 |     pub fn rules(&self) -> Vec<Rule<'_>> {
[INFO] [stdout]     |                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:258:34
[INFO] [stdout]     |
[INFO] [stdout] 258 |     pub fn symbol<S: AsRef<str>>(&self, name: S) -> Option<Symbol> {
[INFO] [stdout]     |                                  ^^^^^                     ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 258 |     pub fn symbol<S: AsRef<str>>(&self, name: S) -> Option<Symbol<'_>> {
[INFO] [stdout]     |                                                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr0/table.rs:146:22
[INFO] [stdout]     |
[INFO] [stdout] 146 |     pub fn conflicts(&self) -> Vec<Conflict> {
[INFO] [stdout]     |                      ^^^^^         ^^^^^^^^
[INFO] [stdout]     |                      |             |
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 146 |     pub fn conflicts(&self) -> Vec<Conflict<'_>> {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr0/table.rs:201:18
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub fn state(&self) -> &'t State {
[INFO] [stdout]     |                  ^^^^^         ^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 201 |     pub fn state(&self) -> &'t State<'_> {
[INFO] [stdout]     |                                     ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr1/table.rs:169:22
[INFO] [stdout]     |
[INFO] [stdout] 169 |     pub fn conflicts(&self) -> Vec<Conflict> {
[INFO] [stdout]     |                      ^^^^^         ^^^^^^^^
[INFO] [stdout]     |                      |             |
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      |             the same lifetime is hidden here
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 169 |     pub fn conflicts(&self) -> Vec<Conflict<'_>> {
[INFO] [stdout]     |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/lr1/table.rs:224:18
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn state(&self) -> &'t State {
[INFO] [stdout]     |                  ^^^^^         ^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn state(&self) -> &'t State<'_> {
[INFO] [stdout]     |                                     ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:212:20
[INFO] [stdout]     |
[INFO] [stdout] 212 |     pub fn symbols(&self) -> Vec<Symbol> {
[INFO] [stdout]     |                    ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 212 |     pub fn symbols(&self) -> Vec<Symbol<'_>> {
[INFO] [stdout]     |                                        ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:224:22
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn terminals(&self) -> Vec<Symbol> {
[INFO] [stdout]     |                      ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 224 |     pub fn terminals(&self) -> Vec<Symbol<'_>> {
[INFO] [stdout]     |                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:235:25
[INFO] [stdout]     |
[INFO] [stdout] 235 |     pub fn nonterminals(&self) -> Vec<Symbol> {
[INFO] [stdout]     |                         ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 235 |     pub fn nonterminals(&self) -> Vec<Symbol<'_>> {
[INFO] [stdout]     |                                             ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:246:18
[INFO] [stdout]     |
[INFO] [stdout] 246 |     pub fn rules(&self) -> Vec<Rule> {
[INFO] [stdout]     |                  ^^^^^         ^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 246 |     pub fn rules(&self) -> Vec<Rule<'_>> {
[INFO] [stdout]     |                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/grammar.rs:258:34
[INFO] [stdout]     |
[INFO] [stdout] 258 |     pub fn symbol<S: AsRef<str>>(&self, name: S) -> Option<Symbol> {
[INFO] [stdout]     |                                  ^^^^^                     ^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                  |
[INFO] [stdout]     |                                  the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 258 |     pub fn symbol<S: AsRef<str>>(&self, name: S) -> Option<Symbol<'_>> {
[INFO] [stdout]     |                                                                  ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 2.14s
[INFO] running `Command { std: "docker" "inspect" "ff3fb63b2fdbfd5206755e067973532283a9d3c11ca85795f9f1770c09951876", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ff3fb63b2fdbfd5206755e067973532283a9d3c11ca85795f9f1770c09951876", kill_on_drop: false }`
[INFO] [stdout] ff3fb63b2fdbfd5206755e067973532283a9d3c11ca85795f9f1770c09951876
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c90bcb9571b7aab0d8beaa2ce8a998ffaf079d38" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] c6b7bd4942ae82a9466e947784eb6ddf0599a8e1b0f90a6f1aa652e6272432ce
[INFO] running `Command { std: "docker" "start" "-a" "c6b7bd4942ae82a9466e947784eb6ddf0599a8e1b0f90a6f1aa652e6272432ce", kill_on_drop: false }`
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/lr0/table.rs:146:22
[INFO] [stderr]     |
[INFO] [stderr] 146 |     pub fn conflicts(&self) -> Vec<Conflict> {
[INFO] [stderr]     |                      ^^^^^         ^^^^^^^^
[INFO] [stderr]     |                      |             |
[INFO] [stderr]     |                      |             the same lifetime is hidden here
[INFO] [stderr]     |                      |             the same lifetime is hidden here
[INFO] [stderr]     |                      the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 146 |     pub fn conflicts(&self) -> Vec<Conflict<'_>> {
[INFO] [stderr]     |                                            ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/lr0/table.rs:201:18
[INFO] [stdout] 
[INFO] [stderr]     |
[INFO] [stdout] running 27 tests
[INFO] [stderr] 201 |     pub fn state(&self) -> &'t State {
[INFO] [stdout] test tests::grammar::test_can_end_with ... ok
[INFO] [stderr]     |                  ^^^^^         ^^^^^ the same lifetime is hidden here
[INFO] [stdout] test tests::grammar::test_first ... ok
[INFO] [stderr]     |                  |
[INFO] [stdout] test tests::grammar::test_first_mutual_recursion ... ok
[INFO] [stderr]     |                  the lifetime is elided here
[INFO] [stdout] test tests::grammar::test_first_nullable ... ok
[INFO] [stderr]     |
[INFO] [stdout] test tests::grammar::test_first_with_empty ... ok
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] test tests::grammar::test_follow_nullable ... ok
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stdout] test tests::grammar::test_follow_simple ... ok
[INFO] [stderr]     |
[INFO] [stdout] test tests::grammar::test_grammar ... ok
[INFO] [stderr] 201 |     pub fn state(&self) -> &'t State<'_> {
[INFO] [stdout] test tests::grammar::test_is_nullable_seq ... ok
[INFO] [stderr]     |                                     ++++
[INFO] [stdout] test tests::grammar::test_is_terminal ... ok
[INFO] [stderr] 
[INFO] [stdout] test tests::grammar::test_follow_nullable3 ... ok
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout] test tests::grammar::test_nullables ... ok
[INFO] [stderr]    --> src/lr1/table.rs:169:22
[INFO] [stdout] test tests::grammar::ll1_example1 ... ok
[INFO] [stderr]     |
[INFO] [stdout] test tests::lr0::step_item ... ok
[INFO] [stderr] 169 |     pub fn conflicts(&self) -> Vec<Conflict> {
[INFO] [stdout] test tests::grammar::test_nullables_with_empty ... ok
[INFO] [stderr]     |                      ^^^^^         ^^^^^^^^
[INFO] [stdout] test tests::grammar::test_follow_nullable2 ... ok
[INFO] [stderr]     |                      |             |
[INFO] [stdout] test tests::grammar::test_first2 ... ok
[INFO] [stderr]     |                      |             the same lifetime is hidden here
[INFO] [stdout] test tests::lr0::debug_for_items ... ok
[INFO] [stderr]     |                      |             the same lifetime is hidden here
[INFO] [stdout] test tests::grammar::test_empty ... ok
[INFO] [stderr]     |                      the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 169 |     pub fn conflicts(&self) -> Vec<Conflict<'_>> {
[INFO] [stderr]     |                                            ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/lr1/table.rs:224:18
[INFO] [stderr]     |
[INFO] [stderr] 224 |     pub fn state(&self) -> &'t State {
[INFO] [stderr]     |                  ^^^^^         ^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                  |
[INFO] [stderr]     |                  the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 224 |     pub fn state(&self) -> &'t State<'_> {
[INFO] [stderr]     |                                     ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/grammar.rs:212:20
[INFO] [stderr]     |
[INFO] [stderr] 212 |     pub fn symbols(&self) -> Vec<Symbol> {
[INFO] [stderr]     |                    ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                    |
[INFO] [stderr]     |                    the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 212 |     pub fn symbols(&self) -> Vec<Symbol<'_>> {
[INFO] [stderr]     |                                        ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/grammar.rs:224:22
[INFO] [stderr]     |
[INFO] [stderr] 224 |     pub fn terminals(&self) -> Vec<Symbol> {
[INFO] [stderr]     |                      ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                      |
[INFO] [stderr]     |                      the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 224 |     pub fn terminals(&self) -> Vec<Symbol<'_>> {
[INFO] [stderr]     |                                          ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/grammar.rs:235:25
[INFO] [stderr]     |
[INFO] [stderr] 235 |     pub fn nonterminals(&self) -> Vec<Symbol> {
[INFO] [stderr]     |                         ^^^^^         ^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                         |
[INFO] [stderr]     |                         the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 235 |     pub fn nonterminals(&self) -> Vec<Symbol<'_>> {
[INFO] [stderr]     |                                             ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/grammar.rs:246:18
[INFO] [stderr]     |
[INFO] [stderr] 246 |     pub fn rules(&self) -> Vec<Rule> {
[INFO] [stderr]     |                  ^^^^^         ^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                  |
[INFO] [stderr]     |                  the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 246 |     pub fn rules(&self) -> Vec<Rule<'_>> {
[INFO] [stderr]     |                                    ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> src/grammar.rs:258:34
[INFO] [stderr]     |
[INFO] [stderr] 258 |     pub fn symbol<S: AsRef<str>>(&self, name: S) -> Option<Symbol> {
[INFO] [stderr]     |                                  ^^^^^                     ^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                                  |
[INFO] [stderr]     |                                  the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 258 |     pub fn symbol<S: AsRef<str>>(&self, name: S) -> Option<Symbol<'_>> {
[INFO] [stderr]     |                                                                  ++++
[INFO] [stderr] 
[INFO] [stderr] warning: `grammar-utils` (lib) generated 9 warnings (run `cargo fix --lib -p grammar-utils` to apply 9 suggestions)
[INFO] [stderr] warning: `grammar-utils` (lib test) generated 9 warnings (9 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.04s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/grammar_utils-2469440cfd5f4f66)
[INFO] [stdout] test tests::grammar::test_first_left_recursion ... ok
[INFO] [stdout] test tests::macros::test_macro ... ok
[INFO] [stdout] test tests::lr0::test_conflicts ... ok
[INFO] [stdout] test tests::lr1::test_conflicts2 ... ok
[INFO] [stdout] test tests::lr0::test_machine ... ok
[INFO] [stdout] test tests::lr1::test_machine ... ok
[INFO] [stdout] test tests::grammar::test_first_seq ... ok
[INFO] [stdout] test tests::lr1::test_conflicts ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 27 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests grammar_utils
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "c6b7bd4942ae82a9466e947784eb6ddf0599a8e1b0f90a6f1aa652e6272432ce", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c6b7bd4942ae82a9466e947784eb6ddf0599a8e1b0f90a6f1aa652e6272432ce", kill_on_drop: false }`
[INFO] [stdout] c6b7bd4942ae82a9466e947784eb6ddf0599a8e1b0f90a6f1aa652e6272432ce
