[INFO] cloning repository https://github.com/JulesGuesnon/tokyo-rust-meetup
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/JulesGuesnon/tokyo-rust-meetup" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FJulesGuesnon%2Ftokyo-rust-meetup", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FJulesGuesnon%2Ftokyo-rust-meetup'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] a2025d901a688d2a13ac943fcdefe602e7075b3c
[INFO] checking JulesGuesnon/tokyo-rust-meetup against try#a7b168ac4977e8e93a43448b44847adaa305d5a9 for pr-150557
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FJulesGuesnon%2Ftokyo-rust-meetup" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/JulesGuesnon/tokyo-rust-meetup
[INFO] finished tweaking git repo https://github.com/JulesGuesnon/tokyo-rust-meetup
[INFO] tweaked toml for git repo https://github.com/JulesGuesnon/tokyo-rust-meetup written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/JulesGuesnon/tokyo-rust-meetup on toolchain a7b168ac4977e8e93a43448b44847adaa305d5a9
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+a7b168ac4977e8e93a43448b44847adaa305d5a9" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/JulesGuesnon/tokyo-rust-meetup 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" "+a7b168ac4977e8e93a43448b44847adaa305d5a9" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+a7b168ac4977e8e93a43448b44847adaa305d5a9" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 319c4bfd569b886d624d2e93bdcf2d53a84fc0968881fe5fcfa5e75355c9fcc1
[INFO] running `Command { std: "docker" "start" "-a" "319c4bfd569b886d624d2e93bdcf2d53a84fc0968881fe5fcfa5e75355c9fcc1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "319c4bfd569b886d624d2e93bdcf2d53a84fc0968881fe5fcfa5e75355c9fcc1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "319c4bfd569b886d624d2e93bdcf2d53a84fc0968881fe5fcfa5e75355c9fcc1", kill_on_drop: false }`
[INFO] [stdout] 319c4bfd569b886d624d2e93bdcf2d53a84fc0968881fe5fcfa5e75355c9fcc1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+a7b168ac4977e8e93a43448b44847adaa305d5a9" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 170f3fb40e4a393bafa8415a6ef609ffdf8db888dea96ff76f8097d8723bae4f
[INFO] running `Command { std: "docker" "start" "-a" "170f3fb40e4a393bafa8415a6ef609ffdf8db888dea96ff76f8097d8723bae4f", kill_on_drop: false }`
[INFO] [stderr]     Checking memchr v2.7.2
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking step_1 v0.1.0 (/opt/rustwide/workdir/packages/step-1)
[INFO] [stderr]     Checking step_0 v0.1.0 (/opt/rustwide/workdir/packages/step-0)
[INFO] [stderr]     Checking step_4 v0.1.0 (/opt/rustwide/workdir/packages/step-4)
[INFO] [stderr]     Checking step_2 v0.1.0 (/opt/rustwide/workdir/packages/step-2)
[INFO] [stderr]     Checking step_3 v0.1.0 (/opt/rustwide/workdir/packages/step-3)
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:21:53
[INFO] [stdout]    |
[INFO] [stdout] 21 | fn hello<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<String, E> {
[INFO] [stdout]    |                                          --         ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                          |
[INFO] [stdout]    |                                          the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 21 | fn hello<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, String, E> {
[INFO] [stdout]    |                                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:27:53
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn world<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<String, E> {
[INFO] [stdout]    |                                          --         ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                          |
[INFO] [stdout]    |                                          the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn world<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, String, E> {
[INFO] [stdout]    |                                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:33:56
[INFO] [stdout]    |
[INFO] [stdout] 33 | fn is_happy<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                             --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                             |
[INFO] [stdout]    |                                             the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 33 | fn is_happy<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:37:59
[INFO] [stdout]    |
[INFO] [stdout] 37 | fn whitespaces<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                                |          |       |
[INFO] [stdout]    |                                                |          |       the same lifetime is named here
[INFO] [stdout]    |                                                |          the same lifetime is hidden here
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 37 | fn whitespaces<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:41:59
[INFO] [stdout]    |
[INFO] [stdout] 41 | fn hello_world<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<(String, String, bool), E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                |
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 41 | fn hello_world<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, (String, String, bool), E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:49:53
[INFO] [stdout]    |
[INFO] [stdout] 49 | fn parse<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<HelloWorld, E> {
[INFO] [stdout]    |                                          --         ^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                          |
[INFO] [stdout]    |                                          the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 49 | fn parse<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, HelloWorld, E> {
[INFO] [stdout]    |                                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:21:53
[INFO] [stdout]    |
[INFO] [stdout] 21 | fn hello<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<String, E> {
[INFO] [stdout]    |                                          --         ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                          |
[INFO] [stdout]    |                                          the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 21 | fn hello<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, String, E> {
[INFO] [stdout]    |                                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:27:53
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn world<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<String, E> {
[INFO] [stdout]    |                                          --         ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                          |
[INFO] [stdout]    |                                          the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn world<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, String, E> {
[INFO] [stdout]    |                                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:33:56
[INFO] [stdout]    |
[INFO] [stdout] 33 | fn is_happy<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                             --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                             |
[INFO] [stdout]    |                                             the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 33 | fn is_happy<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:37:59
[INFO] [stdout]    |
[INFO] [stdout] 37 | fn whitespaces<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                                |          |       |
[INFO] [stdout]    |                                                |          |       the same lifetime is named here
[INFO] [stdout]    |                                                |          the same lifetime is hidden here
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 37 | fn whitespaces<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:41:59
[INFO] [stdout]    |
[INFO] [stdout] 41 | fn hello_world<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<(String, String, bool), E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                |
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 41 | fn hello_world<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, (String, String, bool), E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-0/src/main.rs:49:53
[INFO] [stdout]    |
[INFO] [stdout] 49 | fn parse<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<HelloWorld, E> {
[INFO] [stdout]    |                                          --         ^^^^^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                          |
[INFO] [stdout]    |                                          the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 49 | fn parse<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, HelloWorld, E> {
[INFO] [stdout]    |                                                            +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:31:57
[INFO] [stdout]    |
[INFO] [stdout] 31 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                              --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                              |          |       |
[INFO] [stdout]    |                                              |          |       the same lifetime is named here
[INFO] [stdout]    |                                              |          the same lifetime is hidden here
[INFO] [stdout]    |                                              the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 31 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:35:58
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                               --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                               |
[INFO] [stdout]    |                                               the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:39:59
[INFO] [stdout]    |
[INFO] [stdout] 39 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                |
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 39 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:43:56
[INFO] [stdout]    |
[INFO] [stdout] 43 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<(), E> {
[INFO] [stdout]    |                                             --         ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                             |
[INFO] [stdout]    |                                             the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 43 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<'a, (), E> {
[INFO] [stdout]    |                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:47:78
[INFO] [stdout]    |
[INFO] [stdout] 47 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                                                   --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                                                   |          |       |
[INFO] [stdout]    |                                                                   |          |       the same lifetime is named here
[INFO] [stdout]    |                                                                   |          the same lifetime is hidden here
[INFO] [stdout]    |                                                                   the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 47 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:56:6
[INFO] [stdout]    |
[INFO] [stdout] 55 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 56 | ) -> Result<Vec<JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 56 | ) -> Result<'a, Vec<JsonValue>, E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:71:6
[INFO] [stdout]    |
[INFO] [stdout] 70 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 71 | ) -> Result<(&'a str, JsonValue), E> {
[INFO] [stdout]    |      ^^^^^^^^^--^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |      |        |
[INFO] [stdout]    |      |        the same lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 71 | ) -> Result<'a, (&'a str, JsonValue), E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:82:6
[INFO] [stdout]    |
[INFO] [stdout] 81 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 82 | ) -> Result<HashMap<String, JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 82 | ) -> Result<'a, HashMap<String, JsonValue>, E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-2/src/main.rs:106:6
[INFO] [stdout]     |
[INFO] [stdout] 105 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 106 | ) -> Result<JsonValue, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 106 | ) -> Result<'a, JsonValue, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> packages/step-2/src/main.rs:125:13
[INFO] [stdout]     |
[INFO] [stdout] 125 | fn parse(i: &str) -> Result<JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |             ^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |        |                              |
[INFO] [stdout]     |             |        |                              the same lifetime is elided 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] 125 | fn parse(i: &str) -> Result<'_, JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:27:50
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn sp<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                       --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                       |          |       |
[INFO] [stdout]    |                                       |          |       the same lifetime is named here
[INFO] [stdout]    |                                       |          the same lifetime is hidden here
[INFO] [stdout]    |                                       the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn sp<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:35:57
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                              --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                              |          |       |
[INFO] [stdout]    |                                              |          |       the same lifetime is named here
[INFO] [stdout]    |                                              |          the same lifetime is hidden here
[INFO] [stdout]    |                                              the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:39:59
[INFO] [stdout]    |
[INFO] [stdout] 39 | fn boolean<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                |
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 39 | fn boolean<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:47:56
[INFO] [stdout]    |
[INFO] [stdout] 47 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<(), E> {
[INFO] [stdout]    |                                             --         ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                             |
[INFO] [stdout]    |                                             the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 47 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<'a, (), E> {
[INFO] [stdout]    |                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:63:6
[INFO] [stdout]    |
[INFO] [stdout] 62 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 63 | ) -> Result<Vec<JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 63 | ) -> Result<'a, Vec<JsonValue>, E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:79:6
[INFO] [stdout]    |
[INFO] [stdout] 78 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 79 | ) -> Result<(&'a str, JsonValue), E> {
[INFO] [stdout]    |      ^^^^^^^^^--^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |      |        |
[INFO] [stdout]    |      |        the same lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 79 | ) -> Result<'a, (&'a str, JsonValue), E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:90:6
[INFO] [stdout]    |
[INFO] [stdout] 89 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 90 | ) -> Result<HashMap<String, JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 90 | ) -> Result<'a, HashMap<String, JsonValue>, E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-1/src/main.rs:114:6
[INFO] [stdout]     |
[INFO] [stdout] 113 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 114 | ) -> Result<JsonValue, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 114 | ) -> Result<'a, JsonValue, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:31:57
[INFO] [stdout]    |
[INFO] [stdout] 31 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                              --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                              |          |       |
[INFO] [stdout]    |                                              |          |       the same lifetime is named here
[INFO] [stdout]    |                                              |          the same lifetime is hidden here
[INFO] [stdout]    |                                              the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 31 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> packages/step-1/src/main.rs:129:13
[INFO] [stdout]     |
[INFO] [stdout] 129 | fn parse(i: &str) -> Result<JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |             ^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |        |                              |
[INFO] [stdout]     |             |        |                              the same lifetime is elided 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] 129 | fn parse(i: &str) -> Result<'_, JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:35:58
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                               --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                               |
[INFO] [stdout]    |                                               the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:39:59
[INFO] [stdout]    |
[INFO] [stdout] 39 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                |
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 39 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:43:56
[INFO] [stdout]    |
[INFO] [stdout] 43 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<(), E> {
[INFO] [stdout]    |                                             --         ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                             |
[INFO] [stdout]    |                                             the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 43 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<'a, (), E> {
[INFO] [stdout]    |                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:47:78
[INFO] [stdout]    |
[INFO] [stdout] 47 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                                                   --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                                                   |          |       |
[INFO] [stdout]    |                                                                   |          |       the same lifetime is named here
[INFO] [stdout]    |                                                                   |          the same lifetime is hidden here
[INFO] [stdout]    |                                                                   the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 47 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:56:6
[INFO] [stdout]    |
[INFO] [stdout] 55 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 56 | ) -> Result<Vec<JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 56 | ) -> Result<'a, Vec<JsonValue>, E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:71:6
[INFO] [stdout]    |
[INFO] [stdout] 70 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 71 | ) -> Result<(&'a str, JsonValue), E> {
[INFO] [stdout]    |      ^^^^^^^^^--^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |      |        |
[INFO] [stdout]    |      |        the same lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 71 | ) -> Result<'a, (&'a str, JsonValue), E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-2/src/main.rs:82:6
[INFO] [stdout]    |
[INFO] [stdout] 81 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 82 | ) -> Result<HashMap<String, JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 82 | ) -> Result<'a, HashMap<String, JsonValue>, E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-2/src/main.rs:106:6
[INFO] [stdout]     |
[INFO] [stdout] 105 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 106 | ) -> Result<JsonValue, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 106 | ) -> Result<'a, JsonValue, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> packages/step-2/src/main.rs:125:13
[INFO] [stdout]     |
[INFO] [stdout] 125 | fn parse(i: &str) -> Result<JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |             ^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |        |                              |
[INFO] [stdout]     |             |        |                              the same lifetime is elided 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] 125 | fn parse(i: &str) -> Result<'_, JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:32:57
[INFO] [stdout]    |
[INFO] [stdout] 32 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                              --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                              |          |       |
[INFO] [stdout]    |                                              |          |       the same lifetime is named here
[INFO] [stdout]    |                                              |          the same lifetime is hidden here
[INFO] [stdout]    |                                              the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 32 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:36:58
[INFO] [stdout]    |
[INFO] [stdout] 36 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                               --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                               |
[INFO] [stdout]    |                                               the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 36 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:40:59
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                |
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:44:56
[INFO] [stdout]    |
[INFO] [stdout] 44 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<(), E> {
[INFO] [stdout]    |                                             --         ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                             |
[INFO] [stdout]    |                                             the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 44 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<'a, (), E> {
[INFO] [stdout]    |                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:48:55
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn u16_hex<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<u16, E> {
[INFO] [stdout]    |                                            --         ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                            |
[INFO] [stdout]    |                                            the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn u16_hex<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, u16, E> {
[INFO] [stdout]    |                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:54:62
[INFO] [stdout]    |
[INFO] [stdout] 54 | fn unicode_escape<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<char, E> {
[INFO] [stdout]    |                                                   --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                   |
[INFO] [stdout]    |                                                   the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 54 | fn unicode_escape<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, char, E> {
[INFO] [stdout]    |                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:79:58
[INFO] [stdout]    |
[INFO] [stdout] 79 | fn parse_char<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<char, E> {
[INFO] [stdout]    |                                               --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                               |
[INFO] [stdout]    |                                               the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 79 | fn parse_char<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, char, E> {
[INFO] [stdout]    |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:27:50
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn sp<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                       --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                       |          |       |
[INFO] [stdout]    |                                       |          |       the same lifetime is named here
[INFO] [stdout]    |                                       |          the same lifetime is hidden here
[INFO] [stdout]    |                                       the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn sp<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:103:78
[INFO] [stdout]     |
[INFO] [stdout] 103 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<String, E> {
[INFO] [stdout]     |                                                                   --         ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                                                   |
[INFO] [stdout]     |                                                                   the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 103 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<'a, String, E> {
[INFO] [stdout]     |                                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:121:6
[INFO] [stdout]     |
[INFO] [stdout] 120 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 121 | ) -> Result<Vec<JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 121 | ) -> Result<'a, Vec<JsonValue>, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:35:57
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                              --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                              |          |       |
[INFO] [stdout]    |                                              |          |       the same lifetime is named here
[INFO] [stdout]    |                                              |          the same lifetime is hidden here
[INFO] [stdout]    |                                              the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:137:6
[INFO] [stdout]     |
[INFO] [stdout] 136 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 137 | ) -> Result<(String, JsonValue), E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 137 | ) -> Result<'a, (String, JsonValue), E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:148:6
[INFO] [stdout]     |
[INFO] [stdout] 147 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 148 | ) -> Result<HashMap<String, JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 148 | ) -> Result<'a, HashMap<String, JsonValue>, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:39:59
[INFO] [stdout]    |
[INFO] [stdout] 39 | fn boolean<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                |
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 39 | fn boolean<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:168:6
[INFO] [stdout]     |
[INFO] [stdout] 167 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 168 | ) -> Result<JsonValue, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 168 | ) -> Result<'a, JsonValue, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:47:56
[INFO] [stdout]    |
[INFO] [stdout] 47 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<(), E> {
[INFO] [stdout]    |                                             --         ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                             |
[INFO] [stdout]    |                                             the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 47 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<'a, (), E> {
[INFO] [stdout]    |                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:187:13
[INFO] [stdout]     |
[INFO] [stdout] 187 | fn parse(i: &str) -> Result<JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |             ^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |        |                              |
[INFO] [stdout]     |             |        |                              the same lifetime is elided 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] 187 | fn parse(i: &str) -> Result<'_, JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:63:6
[INFO] [stdout]    |
[INFO] [stdout] 62 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 63 | ) -> Result<Vec<JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 63 | ) -> Result<'a, Vec<JsonValue>, E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:79:6
[INFO] [stdout]    |
[INFO] [stdout] 78 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 79 | ) -> Result<(&'a str, JsonValue), E> {
[INFO] [stdout]    |      ^^^^^^^^^--^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |      |        |
[INFO] [stdout]    |      |        the same lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 79 | ) -> Result<'a, (&'a str, JsonValue), E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-1/src/main.rs:90:6
[INFO] [stdout]    |
[INFO] [stdout] 89 |     i: &'a str,
[INFO] [stdout]    |         -- the lifetime is named here
[INFO] [stdout] 90 | ) -> Result<HashMap<String, JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 90 | ) -> Result<'a, HashMap<String, JsonValue>, E> {
[INFO] [stdout]    |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-1/src/main.rs:114:6
[INFO] [stdout]     |
[INFO] [stdout] 113 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 114 | ) -> Result<JsonValue, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 114 | ) -> Result<'a, JsonValue, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> packages/step-1/src/main.rs:129:13
[INFO] [stdout]     |
[INFO] [stdout] 129 | fn parse(i: &str) -> Result<JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |             ^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |        |                              |
[INFO] [stdout]     |             |        |                              the same lifetime is elided 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] 129 | fn parse(i: &str) -> Result<'_, JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:74:57
[INFO] [stdout]    |
[INFO] [stdout] 74 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                              --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                              |          |       |
[INFO] [stdout]    |                                              |          |       the same lifetime is named here
[INFO] [stdout]    |                                              |          the same lifetime is hidden here
[INFO] [stdout]    |                                              the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 74 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:78:58
[INFO] [stdout]    |
[INFO] [stdout] 78 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                               --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                               |
[INFO] [stdout]    |                                               the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 78 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:82:59
[INFO] [stdout]    |
[INFO] [stdout] 82 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                |
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 82 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:86:56
[INFO] [stdout]    |
[INFO] [stdout] 86 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<(), E> {
[INFO] [stdout]    |                                             --         ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                             |
[INFO] [stdout]    |                                             the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 86 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<'a, (), E> {
[INFO] [stdout]    |                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:90:55
[INFO] [stdout]    |
[INFO] [stdout] 90 | fn u16_hex<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<u16, E> {
[INFO] [stdout]    |                                            --         ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                            |
[INFO] [stdout]    |                                            the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 90 | fn u16_hex<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, u16, E> {
[INFO] [stdout]    |                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:96:62
[INFO] [stdout]    |
[INFO] [stdout] 96 | fn unicode_escape<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<char, E> {
[INFO] [stdout]    |                                                   --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                   |
[INFO] [stdout]    |                                                   the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 96 | fn unicode_escape<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, char, E> {
[INFO] [stdout]    |                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:121:58
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn parse_char<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<char, E> {
[INFO] [stdout]     |                                               --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                               |
[INFO] [stdout]     |                                               the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn parse_char<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, char, E> {
[INFO] [stdout]     |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:147:78
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<String, E> {
[INFO] [stdout]     |                                                                   --         ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                                                   |
[INFO] [stdout]     |                                                                   the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<'a, String, E> {
[INFO] [stdout]     |                                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:165:6
[INFO] [stdout]     |
[INFO] [stdout] 164 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 165 | ) -> Result<Vec<JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 165 | ) -> Result<'a, Vec<JsonValue>, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:186:6
[INFO] [stdout]     |
[INFO] [stdout] 185 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 186 | ) -> Result<(String, JsonValue), E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 186 | ) -> Result<'a, (String, JsonValue), E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:200:6
[INFO] [stdout]     |
[INFO] [stdout] 199 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 200 | ) -> Result<HashMap<String, JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 200 | ) -> Result<'a, HashMap<String, JsonValue>, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:219:6
[INFO] [stdout]     |
[INFO] [stdout] 218 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 219 | ) -> Result<JsonValue, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 219 | ) -> Result<'a, JsonValue, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:236:13
[INFO] [stdout]     |
[INFO] [stdout] 236 | fn parse(i: &str) -> Result<JsonValue, Error<&str>> {
[INFO] [stdout]     |             ^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |        |                       |
[INFO] [stdout]     |             |        |                       the same lifetime is elided 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] 236 | fn parse(i: &str) -> Result<'_, JsonValue, Error<&str>> {
[INFO] [stdout]     |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:74:57
[INFO] [stdout]    |
[INFO] [stdout] 74 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                              --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                              |          |       |
[INFO] [stdout]    |                                              |          |       the same lifetime is named here
[INFO] [stdout]    |                                              |          the same lifetime is hidden here
[INFO] [stdout]    |                                              the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 74 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:78:58
[INFO] [stdout]    |
[INFO] [stdout] 78 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                               --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                               |
[INFO] [stdout]    |                                               the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 78 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:82:59
[INFO] [stdout]    |
[INFO] [stdout] 82 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                |
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 82 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:86:56
[INFO] [stdout]    |
[INFO] [stdout] 86 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<(), E> {
[INFO] [stdout]    |                                             --         ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                             |
[INFO] [stdout]    |                                             the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 86 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<'a, (), E> {
[INFO] [stdout]    |                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:90:55
[INFO] [stdout]    |
[INFO] [stdout] 90 | fn u16_hex<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<u16, E> {
[INFO] [stdout]    |                                            --         ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                            |
[INFO] [stdout]    |                                            the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 90 | fn u16_hex<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, u16, E> {
[INFO] [stdout]    |                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-4/src/main.rs:96:62
[INFO] [stdout]    |
[INFO] [stdout] 96 | fn unicode_escape<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<char, E> {
[INFO] [stdout]    |                                                   --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                   |
[INFO] [stdout]    |                                                   the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 96 | fn unicode_escape<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, char, E> {
[INFO] [stdout]    |                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:121:58
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn parse_char<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<char, E> {
[INFO] [stdout]     |                                               --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                               |
[INFO] [stdout]     |                                               the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 121 | fn parse_char<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, char, E> {
[INFO] [stdout]     |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:147:78
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<String, E> {
[INFO] [stdout]     |                                                                   --         ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                                                   |
[INFO] [stdout]     |                                                                   the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<'a, String, E> {
[INFO] [stdout]     |                                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:165:6
[INFO] [stdout]     |
[INFO] [stdout] 164 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 165 | ) -> Result<Vec<JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 165 | ) -> Result<'a, Vec<JsonValue>, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:186:6
[INFO] [stdout]     |
[INFO] [stdout] 185 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 186 | ) -> Result<(String, JsonValue), E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 186 | ) -> Result<'a, (String, JsonValue), E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:200:6
[INFO] [stdout]     |
[INFO] [stdout] 199 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 200 | ) -> Result<HashMap<String, JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 200 | ) -> Result<'a, HashMap<String, JsonValue>, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:219:6
[INFO] [stdout]     |
[INFO] [stdout] 218 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 219 | ) -> Result<JsonValue, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 219 | ) -> Result<'a, JsonValue, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> packages/step-4/src/main.rs:236:13
[INFO] [stdout]     |
[INFO] [stdout] 236 | fn parse(i: &str) -> Result<JsonValue, Error<&str>> {
[INFO] [stdout]     |             ^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |        |                       |
[INFO] [stdout]     |             |        |                       the same lifetime is elided 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] 236 | fn parse(i: &str) -> Result<'_, JsonValue, Error<&str>> {
[INFO] [stdout]     |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:32:57
[INFO] [stdout]    |
[INFO] [stdout] 32 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<&'a str, E> {
[INFO] [stdout]    |                                              --         ^^^^^^^^--^^^^^^^^
[INFO] [stdout]    |                                              |          |       |
[INFO] [stdout]    |                                              |          |       the same lifetime is named here
[INFO] [stdout]    |                                              |          the same lifetime is hidden here
[INFO] [stdout]    |                                              the lifetime is named 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: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 32 | fn parse_str<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, &'a str, E> {
[INFO] [stdout]    |                                                                +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:36:58
[INFO] [stdout]    |
[INFO] [stdout] 36 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                               --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                               |
[INFO] [stdout]    |                                               the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 36 | fn parse_true<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:40:59
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<bool, E> {
[INFO] [stdout]    |                                                --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                |
[INFO] [stdout]    |                                                the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn parse_false<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, bool, E> {
[INFO] [stdout]    |                                                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:44:56
[INFO] [stdout]    |
[INFO] [stdout] 44 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<(), E> {
[INFO] [stdout]    |                                             --         ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                             |
[INFO] [stdout]    |                                             the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 44 | fn null<'a, E: ParseError<&'a str>>(input: &'a str) -> Result<'a, (), E> {
[INFO] [stdout]    |                                                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:48:55
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn u16_hex<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<u16, E> {
[INFO] [stdout]    |                                            --         ^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                            |
[INFO] [stdout]    |                                            the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn u16_hex<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, u16, E> {
[INFO] [stdout]    |                                                              +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:54:62
[INFO] [stdout]    |
[INFO] [stdout] 54 | fn unicode_escape<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<char, E> {
[INFO] [stdout]    |                                                   --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                                   |
[INFO] [stdout]    |                                                   the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 54 | fn unicode_escape<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, char, E> {
[INFO] [stdout]    |                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> packages/step-3/src/main.rs:79:58
[INFO] [stdout]    |
[INFO] [stdout] 79 | fn parse_char<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<char, E> {
[INFO] [stdout]    |                                               --         ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                                               |
[INFO] [stdout]    |                                               the lifetime is named here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 79 | fn parse_char<'a, E: ParseError<&'a str>>(i: &'a str) -> Result<'a, char, E> {
[INFO] [stdout]    |                                                                 +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:103:78
[INFO] [stdout]     |
[INFO] [stdout] 103 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<String, E> {
[INFO] [stdout]     |                                                                   --         ^^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                                                   |
[INFO] [stdout]     |                                                                   the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 103 | fn string<'a, E: ParseError<&'a str> + ContextError<&'a str>>(i: &'a str) -> Result<'a, String, E> {
[INFO] [stdout]     |                                                                                     +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:121:6
[INFO] [stdout]     |
[INFO] [stdout] 120 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 121 | ) -> Result<Vec<JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 121 | ) -> Result<'a, Vec<JsonValue>, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:137:6
[INFO] [stdout]     |
[INFO] [stdout] 136 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 137 | ) -> Result<(String, JsonValue), E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 137 | ) -> Result<'a, (String, JsonValue), E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:148:6
[INFO] [stdout]     |
[INFO] [stdout] 147 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 148 | ) -> Result<HashMap<String, JsonValue>, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 148 | ) -> Result<'a, HashMap<String, JsonValue>, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:168:6
[INFO] [stdout]     |
[INFO] [stdout] 167 |     i: &'a str,
[INFO] [stdout]     |         -- the lifetime is named here
[INFO] [stdout] 168 | ) -> Result<JsonValue, E> {
[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: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 168 | ) -> Result<'a, JsonValue, E> {
[INFO] [stdout]     |             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> packages/step-3/src/main.rs:187:13
[INFO] [stdout]     |
[INFO] [stdout] 187 | fn parse(i: &str) -> Result<JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |             ^^^^     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |        |                              |
[INFO] [stdout]     |             |        |                              the same lifetime is elided 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] 187 | fn parse(i: &str) -> Result<'_, JsonValue, VerboseError<&str>> {
[INFO] [stdout]     |                             +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1.40s
[INFO] running `Command { std: "docker" "inspect" "170f3fb40e4a393bafa8415a6ef609ffdf8db888dea96ff76f8097d8723bae4f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "170f3fb40e4a393bafa8415a6ef609ffdf8db888dea96ff76f8097d8723bae4f", kill_on_drop: false }`
[INFO] [stdout] 170f3fb40e4a393bafa8415a6ef609ffdf8db888dea96ff76f8097d8723bae4f
