[INFO] cloning repository https://github.com/Michael0x2a/impo
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Michael0x2a/impo" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMichael0x2a%2Fimpo", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMichael0x2a%2Fimpo'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 1c6af75c5ae3b86c798596d2c419a2bcef615d38
[INFO] checking Michael0x2a/impo against master#bca37a20bd376ce3fd138e7cdee7fe704e0f8814 for pr-139493-3
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMichael0x2a%2Fimpo" "/workspace/builds/worker-4-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-4-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Michael0x2a/impo
[INFO] finished tweaking git repo https://github.com/Michael0x2a/impo
[INFO] tweaked toml for git repo https://github.com/Michael0x2a/impo written to /workspace/builds/worker-4-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Michael0x2a/impo on toolchain bca37a20bd376ce3fd138e7cdee7fe704e0f8814
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Michael0x2a/impo 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" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded strum_macros v0.22.0
[INFO] [stderr]   Downloaded ctor v0.1.21
[INFO] [stderr]   Downloaded struple-impl v0.1.0
[INFO] [stderr]   Downloaded strum v0.22.0
[INFO] [stderr]   Downloaded struple v0.1.1
[INFO] [stderr]   Downloaded output_vt100 v0.1.2
[INFO] [stderr]   Downloaded pretty_assertions v1.0.0
[INFO] [stderr]   Downloaded libc v0.2.106
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 47b56fc653341a68ad952e988fc7459171b261c4cec69496ae645546a0d6a21b
[INFO] running `Command { std: "docker" "start" "-a" "47b56fc653341a68ad952e988fc7459171b261c4cec69496ae645546a0d6a21b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "47b56fc653341a68ad952e988fc7459171b261c4cec69496ae645546a0d6a21b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "47b56fc653341a68ad952e988fc7459171b261c4cec69496ae645546a0d6a21b", kill_on_drop: false }`
[INFO] [stdout] 47b56fc653341a68ad952e988fc7459171b261c4cec69496ae645546a0d6a21b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7947a4f8a4e5b38444cbf8ccf54a0ff29503195c2918ab5361efe4c38c60d7e7
[INFO] running `Command { std: "docker" "start" "-a" "7947a4f8a4e5b38444cbf8ccf54a0ff29503195c2918ab5361efe4c38c60d7e7", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.30
[INFO] [stderr]    Compiling syn v1.0.80
[INFO] [stderr]    Compiling libc v0.2.106
[INFO] [stderr]    Compiling memchr v2.4.1
[INFO] [stderr]    Compiling nom v7.1.0
[INFO] [stderr]    Compiling serde v1.0.130
[INFO] [stderr]     Checking siphasher v0.3.7
[INFO] [stderr]    Compiling anyhow v1.0.44
[INFO] [stderr]     Checking new_debug_unreachable v1.0.4
[INFO] [stderr]     Checking precomputed-hash v0.1.1
[INFO] [stderr]     Checking phf_shared v0.8.0
[INFO] [stderr]     Checking itertools v0.10.1
[INFO] [stderr]     Checking strum v0.22.0
[INFO] [stderr]     Checking diff v0.1.12
[INFO] [stderr]     Checking pretty_assertions v1.0.0
[INFO] [stderr]     Checking parking_lot_core v0.8.5
[INFO] [stderr]     Checking parking_lot v0.11.2
[INFO] [stderr]    Compiling quote v1.0.10
[INFO] [stderr]     Checking string_cache v0.8.2
[INFO] [stderr]    Compiling thiserror-impl v1.0.30
[INFO] [stderr]    Compiling struple-impl v0.1.0
[INFO] [stderr]    Compiling derive_more v0.99.17
[INFO] [stderr]    Compiling strum_macros v0.22.0
[INFO] [stderr]     Checking struple v0.1.1
[INFO] [stderr]     Checking thiserror v1.0.30
[INFO] [stderr]     Checking impo v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Position` and `TokenKind`
[INFO] [stdout]  --> src/parser/combinators.rs:2:25
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub use crate::tokens::{Position, Token, TokenKind};
[INFO] [stdout]   |                         ^^^^^^^^         ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Position` and `TokenKind`
[INFO] [stdout]  --> src/parser/combinators.rs:2:25
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub use crate::tokens::{Position, Token, TokenKind};
[INFO] [stdout]   |                         ^^^^^^^^         ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/ast/primitives.rs:12:31
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct AbsoluteIdentifier(Identifier);
[INFO] [stdout]    |            ------------------ ^^^^^^^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/ast/primitives.rs:17:31
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct RelativeIdentifier(Identifier);
[INFO] [stdout]    |            ------------------ ^^^^^^^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/prettyprint/lisplike.rs:50:25
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn comment(comment: &Comment) -> Writer {
[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]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn comment(comment: &Comment) -> Writer<'_> {
[INFO] [stdout]    |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/prettyprint/lisplike.rs:89:27
[INFO] [stdout]    |
[INFO] [stdout] 89 |     fn write_block(block: &[StmtNode]) -> Writer {
[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] 89 |     fn write_block(block: &[StmtNode]) -> Writer<'_> {
[INFO] [stdout]    |                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/prettyprint/lisplike.rs:110:25
[INFO] [stdout]     |
[INFO] [stdout] 110 |     fn write_stmt(stmt: &StmtNode) -> Writer {
[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] 110 |     fn write_stmt(stmt: &StmtNode) -> Writer<'_> {
[INFO] [stdout]     |                                             ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/core.rs:99:13
[INFO] [stdout]     |
[INFO] [stdout]  99 |     tokens: &[Token],
[INFO] [stdout]     |             ^^^^^^^^ the lifetime is elided here
[INFO] [stdout] 100 |     target: impl AsRef<str>,
[INFO] [stdout] 101 | ) -> ParseResult<&Token> {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |      |           |
[INFO] [stdout]     |      |           the same lifetime is elided here
[INFO] [stdout]     |      the same lifetime is hidden 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] 101 | ) -> ParseResult<'_, &Token> {
[INFO] [stdout]     |                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:23:26
[INFO] [stdout]    |
[INFO] [stdout] 23 | fn match_program(tokens: &[Token]) -> ParseResult<Program> {
[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] 23 | fn match_program(tokens: &[Token]) -> ParseResult<'_, Program> {
[INFO] [stdout]    |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:30:24
[INFO] [stdout]    |
[INFO] [stdout] 30 | fn match_block(tokens: &[Token]) -> ParseResult<Block> {
[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] 30 | fn match_block(tokens: &[Token]) -> ParseResult<'_, Block> {
[INFO] [stdout]    |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:34:33
[INFO] [stdout]    |
[INFO] [stdout] 34 | fn match_indented_block(tokens: &[Token]) -> ParseResult<Block> {
[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] 34 | fn match_indented_block(tokens: &[Token]) -> ParseResult<'_, Block> {
[INFO] [stdout]    |                                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:42:23
[INFO] [stdout]    |
[INFO] [stdout] 42 | fn match_stmt(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 42 | fn match_stmt(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]    |                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:57:37
[INFO] [stdout]    |
[INFO] [stdout] 57 | fn match_func_signature_def(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 57 | fn match_func_signature_def(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]    |                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:64:42
[INFO] [stdout]    |
[INFO] [stdout] 64 | fn match_func_implementation_def(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 64 | fn match_func_implementation_def(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]    |                                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:74:30
[INFO] [stdout]    |
[INFO] [stdout] 74 | fn match_func_header(tokens: &[Token]) -> ParseResult<FuncSignatureDefStmt> {
[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] 74 | fn match_func_header(tokens: &[Token]) -> ParseResult<'_, FuncSignatureDefStmt> {
[INFO] [stdout]    |                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:122:24
[INFO] [stdout]     |
[INFO] [stdout] 122 | fn match_while(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 122 | fn match_while(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:136:26
[INFO] [stdout]     |
[INFO] [stdout] 136 | fn match_foreach(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 136 | fn match_foreach(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:154:21
[INFO] [stdout]     |
[INFO] [stdout] 154 | fn match_if(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 154 | fn match_if(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:185:29
[INFO] [stdout]     |
[INFO] [stdout] 185 | fn match_assignment(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 185 | fn match_assignment(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:202:25
[INFO] [stdout]     |
[INFO] [stdout] 202 | fn match_return(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 202 | fn match_return(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:212:24
[INFO] [stdout]     |
[INFO] [stdout] 212 | fn match_panic(tokens: &[Token]) -> ParseResult<StmtNode> {
[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 | fn match_panic(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:222:23
[INFO] [stdout]     |
[INFO] [stdout] 222 | fn match_line(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 222 | fn match_line(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:232:28
[INFO] [stdout]     |
[INFO] [stdout] 232 | fn match_empty_line(token: &[Token]) -> ParseResult<StmtNode> {
[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] 232 | fn match_empty_line(token: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:236:26
[INFO] [stdout]     |
[INFO] [stdout] 236 | fn match_comment(tokens: &[Token]) -> ParseResult<Comment> {
[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] 236 | fn match_comment(tokens: &[Token]) -> ParseResult<'_, Comment> {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:237:37
[INFO] [stdout]     |
[INFO] [stdout] 237 |     fn match_single_comment(tokens: &[Token]) -> ParseResult<String> {
[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] 237 |     fn match_single_comment(tokens: &[Token]) -> ParseResult<'_, String> {
[INFO] [stdout]     |                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_type.rs:13:27
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub fn match_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 13 | pub fn match_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]    |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_type.rs:29:31
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn match_primary_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 29 | fn match_primary_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]    |                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_type.rs:38:33
[INFO] [stdout]    |
[INFO] [stdout] 38 | fn match_reference_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 38 | fn match_reference_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]    |                                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_type.rs:59:28
[INFO] [stdout]    |
[INFO] [stdout] 59 | fn match_func_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 59 | fn match_func_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]    |                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_type.rs:89:29
[INFO] [stdout]    |
[INFO] [stdout] 89 | fn match_tuple_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 89 | fn match_tuple_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]    |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_type.rs:107:29
[INFO] [stdout]     |
[INFO] [stdout] 107 | fn match_empty_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 107 | fn match_empty_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]     |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_expr.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn match_expr(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 14 | pub fn match_expr(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]    |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_expr.rs:21:24
[INFO] [stdout]    |
[INFO] [stdout] 21 | fn match_group(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 21 | fn match_group(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]    |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_expr.rs:35:24
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn match_tuple(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 35 | fn match_tuple(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]    |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_expr.rs:52:29
[INFO] [stdout]    |
[INFO] [stdout] 52 | fn match_operations(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 52 | fn match_operations(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]    |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_expr.rs:83:22
[INFO] [stdout]    |
[INFO] [stdout] 83 |     fn build(tokens: &[Token], min_bp: u8) -> ParseResult<ExprNode> {
[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] 83 |     fn build(tokens: &[Token], min_bp: u8) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]    |                                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:135:27
[INFO] [stdout]     |
[INFO] [stdout] 135 | fn match_infix_op(tokens: &[Token]) -> ParseResult<InfixOp> {
[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] 135 | fn match_infix_op(tokens: &[Token]) -> ParseResult<'_, InfixOp> {
[INFO] [stdout]     |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:172:28
[INFO] [stdout]     |
[INFO] [stdout] 172 | fn match_prefix_op(tokens: &[Token]) -> ParseResult<PrefixOp> {
[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] 172 | fn match_prefix_op(tokens: &[Token]) -> ParseResult<'_, PrefixOp> {
[INFO] [stdout]     |                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:186:26
[INFO] [stdout]     |
[INFO] [stdout] 186 | fn match_operand(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 186 | fn match_operand(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:193:28
[INFO] [stdout]     |
[INFO] [stdout] 193 | fn match_call_like(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 193 | fn match_call_like(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:239:23
[INFO] [stdout]     |
[INFO] [stdout] 239 | fn match_unit(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 239 | fn match_unit(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:246:31
[INFO] [stdout]     |
[INFO] [stdout] 246 | fn match_field_lookup(tokens: &[Token]) -> ParseResult<ExprNode> {
[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 | fn match_field_lookup(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:263:23
[INFO] [stdout]     |
[INFO] [stdout] 263 | fn match_atom(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 263 | fn match_atom(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:270:27
[INFO] [stdout]     |
[INFO] [stdout] 270 | fn match_variable(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 270 | fn match_variable(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:274:27
[INFO] [stdout]     |
[INFO] [stdout] 274 | pub fn match_name(tokens: &[Token]) -> ParseResult<Name> {
[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] 274 | pub fn match_name(tokens: &[Token]) -> ParseResult<'_, Name> {
[INFO] [stdout]     |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:286:26
[INFO] [stdout]     |
[INFO] [stdout] 286 | fn match_literal(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 286 | fn match_literal(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/ast/primitives.rs:12:31
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct AbsoluteIdentifier(Identifier);
[INFO] [stdout]    |            ------------------ ^^^^^^^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/ast/primitives.rs:17:31
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct RelativeIdentifier(Identifier);
[INFO] [stdout]    |            ------------------ ^^^^^^^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/prettyprint/lisplike.rs:50:25
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn comment(comment: &Comment) -> Writer {
[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]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 50 |     fn comment(comment: &Comment) -> Writer<'_> {
[INFO] [stdout]    |                                            ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/prettyprint/lisplike.rs:89:27
[INFO] [stdout]    |
[INFO] [stdout] 89 |     fn write_block(block: &[StmtNode]) -> Writer {
[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] 89 |     fn write_block(block: &[StmtNode]) -> Writer<'_> {
[INFO] [stdout]    |                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/prettyprint/lisplike.rs:110:25
[INFO] [stdout]     |
[INFO] [stdout] 110 |     fn write_stmt(stmt: &StmtNode) -> Writer {
[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] 110 |     fn write_stmt(stmt: &StmtNode) -> Writer<'_> {
[INFO] [stdout]     |                                             ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/core.rs:99:13
[INFO] [stdout]     |
[INFO] [stdout]  99 |     tokens: &[Token],
[INFO] [stdout]     |             ^^^^^^^^ the lifetime is elided here
[INFO] [stdout] 100 |     target: impl AsRef<str>,
[INFO] [stdout] 101 | ) -> ParseResult<&Token> {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |      |           |
[INFO] [stdout]     |      |           the same lifetime is elided here
[INFO] [stdout]     |      the same lifetime is hidden 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] 101 | ) -> ParseResult<'_, &Token> {
[INFO] [stdout]     |                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:23:26
[INFO] [stdout]    |
[INFO] [stdout] 23 | fn match_program(tokens: &[Token]) -> ParseResult<Program> {
[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] 23 | fn match_program(tokens: &[Token]) -> ParseResult<'_, Program> {
[INFO] [stdout]    |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:30:24
[INFO] [stdout]    |
[INFO] [stdout] 30 | fn match_block(tokens: &[Token]) -> ParseResult<Block> {
[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] 30 | fn match_block(tokens: &[Token]) -> ParseResult<'_, Block> {
[INFO] [stdout]    |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:34:33
[INFO] [stdout]    |
[INFO] [stdout] 34 | fn match_indented_block(tokens: &[Token]) -> ParseResult<Block> {
[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] 34 | fn match_indented_block(tokens: &[Token]) -> ParseResult<'_, Block> {
[INFO] [stdout]    |                                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:42:23
[INFO] [stdout]    |
[INFO] [stdout] 42 | fn match_stmt(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 42 | fn match_stmt(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]    |                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:57:37
[INFO] [stdout]    |
[INFO] [stdout] 57 | fn match_func_signature_def(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 57 | fn match_func_signature_def(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]    |                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:64:42
[INFO] [stdout]    |
[INFO] [stdout] 64 | fn match_func_implementation_def(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 64 | fn match_func_implementation_def(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]    |                                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_stmt.rs:74:30
[INFO] [stdout]    |
[INFO] [stdout] 74 | fn match_func_header(tokens: &[Token]) -> ParseResult<FuncSignatureDefStmt> {
[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] 74 | fn match_func_header(tokens: &[Token]) -> ParseResult<'_, FuncSignatureDefStmt> {
[INFO] [stdout]    |                                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:122:24
[INFO] [stdout]     |
[INFO] [stdout] 122 | fn match_while(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 122 | fn match_while(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:136:26
[INFO] [stdout]     |
[INFO] [stdout] 136 | fn match_foreach(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 136 | fn match_foreach(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:154:21
[INFO] [stdout]     |
[INFO] [stdout] 154 | fn match_if(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 154 | fn match_if(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:185:29
[INFO] [stdout]     |
[INFO] [stdout] 185 | fn match_assignment(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 185 | fn match_assignment(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:202:25
[INFO] [stdout]     |
[INFO] [stdout] 202 | fn match_return(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 202 | fn match_return(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:212:24
[INFO] [stdout]     |
[INFO] [stdout] 212 | fn match_panic(tokens: &[Token]) -> ParseResult<StmtNode> {
[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 | fn match_panic(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:222:23
[INFO] [stdout]     |
[INFO] [stdout] 222 | fn match_line(tokens: &[Token]) -> ParseResult<StmtNode> {
[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] 222 | fn match_line(tokens: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:232:28
[INFO] [stdout]     |
[INFO] [stdout] 232 | fn match_empty_line(token: &[Token]) -> ParseResult<StmtNode> {
[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] 232 | fn match_empty_line(token: &[Token]) -> ParseResult<'_, StmtNode> {
[INFO] [stdout]     |                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:236:26
[INFO] [stdout]     |
[INFO] [stdout] 236 | fn match_comment(tokens: &[Token]) -> ParseResult<Comment> {
[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] 236 | fn match_comment(tokens: &[Token]) -> ParseResult<'_, Comment> {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_stmt.rs:237:37
[INFO] [stdout]     |
[INFO] [stdout] 237 |     fn match_single_comment(tokens: &[Token]) -> ParseResult<String> {
[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] 237 |     fn match_single_comment(tokens: &[Token]) -> ParseResult<'_, String> {
[INFO] [stdout]     |                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_type.rs:13:27
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub fn match_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 13 | pub fn match_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]    |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_type.rs:29:31
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn match_primary_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 29 | fn match_primary_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]    |                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_type.rs:38:33
[INFO] [stdout]    |
[INFO] [stdout] 38 | fn match_reference_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 38 | fn match_reference_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]    |                                                          +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_type.rs:59:28
[INFO] [stdout]    |
[INFO] [stdout] 59 | fn match_func_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 59 | fn match_func_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]    |                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_type.rs:89:29
[INFO] [stdout]    |
[INFO] [stdout] 89 | fn match_tuple_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 89 | fn match_tuple_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]    |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_type.rs:107:29
[INFO] [stdout]     |
[INFO] [stdout] 107 | fn match_empty_type(tokens: &[Token]) -> ParseResult<TypeNode> {
[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] 107 | fn match_empty_type(tokens: &[Token]) -> ParseResult<'_, TypeNode> {
[INFO] [stdout]     |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_expr.rs:14:27
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn match_expr(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 14 | pub fn match_expr(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]    |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_expr.rs:21:24
[INFO] [stdout]    |
[INFO] [stdout] 21 | fn match_group(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 21 | fn match_group(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]    |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_expr.rs:35:24
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn match_tuple(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 35 | fn match_tuple(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]    |                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_expr.rs:52:29
[INFO] [stdout]    |
[INFO] [stdout] 52 | fn match_operations(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 52 | fn match_operations(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]    |                                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/parser/parse_expr.rs:83:22
[INFO] [stdout]    |
[INFO] [stdout] 83 |     fn build(tokens: &[Token], min_bp: u8) -> ParseResult<ExprNode> {
[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] 83 |     fn build(tokens: &[Token], min_bp: u8) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]    |                                                           +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:135:27
[INFO] [stdout]     |
[INFO] [stdout] 135 | fn match_infix_op(tokens: &[Token]) -> ParseResult<InfixOp> {
[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] 135 | fn match_infix_op(tokens: &[Token]) -> ParseResult<'_, InfixOp> {
[INFO] [stdout]     |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:172:28
[INFO] [stdout]     |
[INFO] [stdout] 172 | fn match_prefix_op(tokens: &[Token]) -> ParseResult<PrefixOp> {
[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] 172 | fn match_prefix_op(tokens: &[Token]) -> ParseResult<'_, PrefixOp> {
[INFO] [stdout]     |                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:186:26
[INFO] [stdout]     |
[INFO] [stdout] 186 | fn match_operand(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 186 | fn match_operand(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:193:28
[INFO] [stdout]     |
[INFO] [stdout] 193 | fn match_call_like(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 193 | fn match_call_like(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:239:23
[INFO] [stdout]     |
[INFO] [stdout] 239 | fn match_unit(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 239 | fn match_unit(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:246:31
[INFO] [stdout]     |
[INFO] [stdout] 246 | fn match_field_lookup(tokens: &[Token]) -> ParseResult<ExprNode> {
[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 | fn match_field_lookup(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:263:23
[INFO] [stdout]     |
[INFO] [stdout] 263 | fn match_atom(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 263 | fn match_atom(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:270:27
[INFO] [stdout]     |
[INFO] [stdout] 270 | fn match_variable(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 270 | fn match_variable(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:274:27
[INFO] [stdout]     |
[INFO] [stdout] 274 | pub fn match_name(tokens: &[Token]) -> ParseResult<Name> {
[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] 274 | pub fn match_name(tokens: &[Token]) -> ParseResult<'_, Name> {
[INFO] [stdout]     |                                                    +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/parser/parse_expr.rs:286:26
[INFO] [stdout]     |
[INFO] [stdout] 286 | fn match_literal(tokens: &[Token]) -> ParseResult<ExprNode> {
[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] 286 | fn match_literal(tokens: &[Token]) -> ParseResult<'_, ExprNode> {
[INFO] [stdout]     |                                                   +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 17.51s
[INFO] running `Command { std: "docker" "inspect" "7947a4f8a4e5b38444cbf8ccf54a0ff29503195c2918ab5361efe4c38c60d7e7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7947a4f8a4e5b38444cbf8ccf54a0ff29503195c2918ab5361efe4c38c60d7e7", kill_on_drop: false }`
[INFO] [stdout] 7947a4f8a4e5b38444cbf8ccf54a0ff29503195c2918ab5361efe4c38c60d7e7
