[INFO] cloning repository https://github.com/lmammino/codecrafters-redis [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/lmammino/codecrafters-redis" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Flmammino%2Fcodecrafters-redis", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Flmammino%2Fcodecrafters-redis'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 9d6e11336bae5d77a365ce0363aba7dc981e3533 [INFO] checking lmammino/codecrafters-redis against master#36b21637e93b038453924d3c66821089e71d8baa for pr-143164 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Flmammino%2Fcodecrafters-redis" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/lmammino/codecrafters-redis [INFO] finished tweaking git repo https://github.com/lmammino/codecrafters-redis [INFO] tweaked toml for git repo https://github.com/lmammino/codecrafters-redis written to /workspace/builds/worker-3-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/lmammino/codecrafters-redis on toolchain 36b21637e93b038453924d3c66821089e71d8baa [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/lmammino/codecrafters-redis 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" "+36b21637e93b038453924d3c66821089e71d8baa" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cf8efcab8866f2cf4285301c7418e2f4f2a9b088c91ba69c40d5b659f81557f7" "/opt/rustwide/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] d18c7bedc444b5406d35d22860f157d2e601b443e210d3a865ae49684bc06f19 [INFO] running `Command { std: "docker" "start" "-a" "d18c7bedc444b5406d35d22860f157d2e601b443e210d3a865ae49684bc06f19", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "d18c7bedc444b5406d35d22860f157d2e601b443e210d3a865ae49684bc06f19", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "d18c7bedc444b5406d35d22860f157d2e601b443e210d3a865ae49684bc06f19", kill_on_drop: false }` [INFO] [stdout] d18c7bedc444b5406d35d22860f157d2e601b443e210d3a865ae49684bc06f19 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:cf8efcab8866f2cf4285301c7418e2f4f2a9b088c91ba69c40d5b659f81557f7" "/opt/rustwide/cargo-home/bin/cargo" "+36b21637e93b038453924d3c66821089e71d8baa" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 8a271e32a7da86b6d51593d68b4fb1e634a62419c6bc7f503a8137d95f8559d7 [INFO] running `Command { std: "docker" "start" "-a" "8a271e32a7da86b6d51593d68b4fb1e634a62419c6bc7f503a8137d95f8559d7", kill_on_drop: false }` [INFO] [stderr] Compiling autocfg v1.1.0 [INFO] [stderr] Compiling proc-macro2 v1.0.78 [INFO] [stderr] Compiling unicode-ident v1.0.12 [INFO] [stderr] Compiling libc v0.2.138 [INFO] [stderr] Compiling semver v1.0.21 [INFO] [stderr] Compiling syn v1.0.67 [INFO] [stderr] Checking memchr v2.7.1 [INFO] [stderr] Compiling unicode-xid v0.2.1 [INFO] [stderr] Checking pin-project-lite v0.2.9 [INFO] [stderr] Checking futures-sink v0.3.30 [INFO] [stderr] Checking futures-core v0.3.30 [INFO] [stderr] Compiling log v0.4.11 [INFO] [stderr] Compiling parking_lot_core v0.9.5 [INFO] [stderr] Checking futures-channel v0.3.30 [INFO] [stderr] Compiling slab v0.4.9 [INFO] [stderr] Compiling lock_api v0.4.9 [INFO] [stderr] Compiling num-traits v0.2.17 [INFO] [stderr] Compiling aho-corasick v1.1.2 [INFO] [stderr] Compiling rustc_version v0.4.0 [INFO] [stderr] Compiling num-integer v0.1.45 [INFO] [stderr] Checking cfg-if v0.1.10 [INFO] [stderr] Checking pin-utils v0.1.0 [INFO] [stderr] Checking smallvec v1.10.0 [INFO] [stderr] Checking futures-task v0.3.30 [INFO] [stderr] Checking scopeguard v1.1.0 [INFO] [stderr] Checking futures-io v0.3.30 [INFO] [stderr] Checking cfg-if v1.0.0 [INFO] [stderr] Compiling regex-syntax v0.8.2 [INFO] [stderr] Compiling rstest_macros v0.18.2 [INFO] [stderr] Compiling quote v1.0.35 [INFO] [stderr] Compiling num-bigint v0.4.4 [INFO] [stderr] Compiling tokio v1.23.0 [INFO] [stderr] Compiling syn v2.0.48 [INFO] [stderr] Compiling anyhow v1.0.59 [INFO] [stderr] Checking parking_lot v0.12.1 [INFO] [stderr] Checking socket2 v0.4.7 [INFO] [stderr] Checking signal-hook-registry v1.2.2 [INFO] [stderr] Checking num_cpus v1.13.0 [INFO] [stderr] Checking mio v0.8.5 [INFO] [stderr] Checking minimal-lexical v0.2.1 [INFO] [stderr] Compiling glob v0.3.1 [INFO] [stderr] Checking bytes v1.3.0 [INFO] [stderr] Compiling relative-path v1.9.2 [INFO] [stderr] Checking nom v7.1.3 [INFO] [stderr] Compiling regex-automata v0.4.4 [INFO] [stderr] Checking futures-timer v3.0.2 [INFO] [stderr] Compiling thiserror-impl v1.0.32 [INFO] [stderr] Compiling tokio-macros v1.8.2 [INFO] [stderr] Checking thiserror v1.0.32 [INFO] [stderr] Compiling regex v1.10.3 [INFO] [stderr] Compiling futures-macro v0.3.30 [INFO] [stderr] Checking futures-util v0.3.30 [INFO] [stderr] Checking redis-starter-rust v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:118:21 [INFO] [stdout] | [INFO] [stdout] 118 | fn parse_big_number(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:122:21 [INFO] [stdout] | [INFO] [stdout] 122 | fn parse_bulk_error(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:126:26 [INFO] [stdout] | [INFO] [stdout] 126 | fn parse_verbatim_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:130:14 [INFO] [stdout] | [INFO] [stdout] 130 | fn parse_map(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:134:14 [INFO] [stdout] | [INFO] [stdout] 134 | fn parse_set(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:138:15 [INFO] [stdout] | [INFO] [stdout] 138 | fn parse_push(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `Value` is never used [INFO] [stdout] --> src/resp.rs:14:10 [INFO] [stdout] | [INFO] [stdout] 14 | pub enum Value<'a> { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_value` is never used [INFO] [stdout] --> src/resp.rs:31:8 [INFO] [stdout] | [INFO] [stdout] 31 | pub fn parse_value(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `clrf` is never used [INFO] [stdout] --> src/resp.rs:51:4 [INFO] [stdout] | [INFO] [stdout] 51 | fn clrf(input: &str) -> IResult<&str, &str> { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `u32_or_minus1` is never used [INFO] [stdout] --> src/resp.rs:55:4 [INFO] [stdout] | [INFO] [stdout] 55 | fn u32_or_minus1(input: &str) -> IResult<&str, i32> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_simple_string_raw` is never used [INFO] [stdout] --> src/resp.rs:60:4 [INFO] [stdout] | [INFO] [stdout] 60 | fn parse_simple_string_raw(input: &str) -> IResult<&str, &str> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_simple_string` is never used [INFO] [stdout] --> src/resp.rs:64:4 [INFO] [stdout] | [INFO] [stdout] 64 | fn parse_simple_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_simple_error` is never used [INFO] [stdout] --> src/resp.rs:69:4 [INFO] [stdout] | [INFO] [stdout] 69 | fn parse_simple_error(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_integer` is never used [INFO] [stdout] --> src/resp.rs:74:4 [INFO] [stdout] | [INFO] [stdout] 74 | fn parse_integer(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_bulk_string` is never used [INFO] [stdout] --> src/resp.rs:79:4 [INFO] [stdout] | [INFO] [stdout] 79 | fn parse_bulk_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_array` is never used [INFO] [stdout] --> src/resp.rs:89:4 [INFO] [stdout] | [INFO] [stdout] 89 | fn parse_array(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_null` is never used [INFO] [stdout] --> src/resp.rs:98:4 [INFO] [stdout] | [INFO] [stdout] 98 | fn parse_null(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_boolean` is never used [INFO] [stdout] --> src/resp.rs:103:4 [INFO] [stdout] | [INFO] [stdout] 103 | fn parse_boolean(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_double` is never used [INFO] [stdout] --> src/resp.rs:112:4 [INFO] [stdout] | [INFO] [stdout] 112 | fn parse_double(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_big_number` is never used [INFO] [stdout] --> src/resp.rs:118:4 [INFO] [stdout] | [INFO] [stdout] 118 | fn parse_big_number(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_bulk_error` is never used [INFO] [stdout] --> src/resp.rs:122:4 [INFO] [stdout] | [INFO] [stdout] 122 | fn parse_bulk_error(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_verbatim_string` is never used [INFO] [stdout] --> src/resp.rs:126:4 [INFO] [stdout] | [INFO] [stdout] 126 | fn parse_verbatim_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_map` is never used [INFO] [stdout] --> src/resp.rs:130:4 [INFO] [stdout] | [INFO] [stdout] 130 | fn parse_map(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_set` is never used [INFO] [stdout] --> src/resp.rs:134:4 [INFO] [stdout] | [INFO] [stdout] 134 | fn parse_set(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_push` is never used [INFO] [stdout] --> src/resp.rs:138:4 [INFO] [stdout] | [INFO] [stdout] 138 | fn parse_push(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:31:27 [INFO] [stdout] | [INFO] [stdout] 31 | pub fn parse_value(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 31 | pub fn parse_value(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:64:31 [INFO] [stdout] | [INFO] [stdout] 64 | fn parse_simple_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 64 | fn parse_simple_string(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:69:30 [INFO] [stdout] | [INFO] [stdout] 69 | fn parse_simple_error(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 69 | fn parse_simple_error(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:74:25 [INFO] [stdout] | [INFO] [stdout] 74 | fn parse_integer(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 74 | fn parse_integer(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:79:29 [INFO] [stdout] | [INFO] [stdout] 79 | fn parse_bulk_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 79 | fn parse_bulk_string(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:89:23 [INFO] [stdout] | [INFO] [stdout] 89 | fn parse_array(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 89 | fn parse_array(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:98:22 [INFO] [stdout] | [INFO] [stdout] 98 | fn parse_null(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 98 | fn parse_null(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:103:25 [INFO] [stdout] | [INFO] [stdout] 103 | fn parse_boolean(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 103 | fn parse_boolean(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:112:24 [INFO] [stdout] | [INFO] [stdout] 112 | fn parse_double(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 112 | fn parse_double(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:118:28 [INFO] [stdout] | [INFO] [stdout] 118 | fn parse_big_number(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 118 | fn parse_big_number(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:122:28 [INFO] [stdout] | [INFO] [stdout] 122 | fn parse_bulk_error(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 122 | fn parse_bulk_error(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:126:33 [INFO] [stdout] | [INFO] [stdout] 126 | fn parse_verbatim_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 126 | fn parse_verbatim_string(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:130:21 [INFO] [stdout] | [INFO] [stdout] 130 | fn parse_map(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 130 | fn parse_map(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:134:21 [INFO] [stdout] | [INFO] [stdout] 134 | fn parse_set(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 134 | fn parse_set(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:138:22 [INFO] [stdout] | [INFO] [stdout] 138 | fn parse_push(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 138 | fn parse_push(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking futures-executor v0.3.30 [INFO] [stderr] Checking futures v0.3.30 [INFO] [stderr] Checking rstest v0.18.2 [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:118:21 [INFO] [stdout] | [INFO] [stdout] 118 | fn parse_big_number(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:122:21 [INFO] [stdout] | [INFO] [stdout] 122 | fn parse_bulk_error(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:126:26 [INFO] [stdout] | [INFO] [stdout] 126 | fn parse_verbatim_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:130:14 [INFO] [stdout] | [INFO] [stdout] 130 | fn parse_map(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:134:14 [INFO] [stdout] | [INFO] [stdout] 134 | fn parse_set(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `input` [INFO] [stdout] --> src/resp.rs:138:15 [INFO] [stdout] | [INFO] [stdout] 138 | fn parse_push(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^ help: if this is intentional, prefix it with an underscore: `_input` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variants `BigNumber`, `BulkError`, `VerbatimString`, `Map`, `Set`, and `Push` are never constructed [INFO] [stdout] --> src/resp.rs:23:5 [INFO] [stdout] | [INFO] [stdout] 14 | pub enum Value<'a> { [INFO] [stdout] | ----- variants in this enum [INFO] [stdout] ... [INFO] [stdout] 23 | BigNumber(BigUint), // ( [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 24 | BulkError, // ! [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 25 | VerbatimString, // = [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] 26 | Map, // % [INFO] [stdout] | ^^^ [INFO] [stdout] 27 | Set, // ~ [INFO] [stdout] | ^^^ [INFO] [stdout] 28 | Push, // > [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Value` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_null` is never used [INFO] [stdout] --> src/resp.rs:98:4 [INFO] [stdout] | [INFO] [stdout] 98 | fn parse_null(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:31:27 [INFO] [stdout] | [INFO] [stdout] 31 | pub fn parse_value(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 31 | pub fn parse_value(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:64:31 [INFO] [stdout] | [INFO] [stdout] 64 | fn parse_simple_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 64 | fn parse_simple_string(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:69:30 [INFO] [stdout] | [INFO] [stdout] 69 | fn parse_simple_error(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 69 | fn parse_simple_error(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:74:25 [INFO] [stdout] | [INFO] [stdout] 74 | fn parse_integer(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 74 | fn parse_integer(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:79:29 [INFO] [stdout] | [INFO] [stdout] 79 | fn parse_bulk_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 79 | fn parse_bulk_string(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:89:23 [INFO] [stdout] | [INFO] [stdout] 89 | fn parse_array(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 89 | fn parse_array(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:98:22 [INFO] [stdout] | [INFO] [stdout] 98 | fn parse_null(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 98 | fn parse_null(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:103:25 [INFO] [stdout] | [INFO] [stdout] 103 | fn parse_boolean(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 103 | fn parse_boolean(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:112:24 [INFO] [stdout] | [INFO] [stdout] 112 | fn parse_double(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 112 | fn parse_double(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:118:28 [INFO] [stdout] | [INFO] [stdout] 118 | fn parse_big_number(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 118 | fn parse_big_number(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:122:28 [INFO] [stdout] | [INFO] [stdout] 122 | fn parse_bulk_error(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 122 | fn parse_bulk_error(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:126:33 [INFO] [stdout] | [INFO] [stdout] 126 | fn parse_verbatim_string(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 126 | fn parse_verbatim_string(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:130:21 [INFO] [stdout] | [INFO] [stdout] 130 | fn parse_map(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 130 | fn parse_map(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:134:21 [INFO] [stdout] | [INFO] [stdout] 134 | fn parse_set(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 134 | fn parse_set(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: lifetime flowing from input to output with different syntax can be confusing [INFO] [stdout] --> src/resp.rs:138:22 [INFO] [stdout] | [INFO] [stdout] 138 | fn parse_push(input: &str) -> IResult<&str, Value> { [INFO] [stdout] | ^^^^ ---- ----- the lifetimes get resolved as `'_` [INFO] [stdout] | | | [INFO] [stdout] | | the lifetimes get resolved as `'_` [INFO] [stdout] | this lifetime flows to the output [INFO] [stdout] | [INFO] [stdout] help: one option is to remove the lifetime for references and use the anonymous lifetime for paths [INFO] [stdout] | [INFO] [stdout] 138 | fn parse_push(input: &str) -> IResult<&str, Value<'_>> { [INFO] [stdout] | ++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 29.01s [INFO] running `Command { std: "docker" "inspect" "8a271e32a7da86b6d51593d68b4fb1e634a62419c6bc7f503a8137d95f8559d7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8a271e32a7da86b6d51593d68b4fb1e634a62419c6bc7f503a8137d95f8559d7", kill_on_drop: false }` [INFO] [stdout] 8a271e32a7da86b6d51593d68b4fb1e634a62419c6bc7f503a8137d95f8559d7