[INFO] fetching crate hc 0.1.2... [INFO] checking hc-0.1.2 against master#385fa9d845dd326c6bbfd58c22244215e431948a for absurd-question-mark-desugar [INFO] extracting crate hc 0.1.2 into /workspace/builds/worker-3-tc1/source [INFO] validating manifest of crates.io crate hc 0.1.2 on toolchain 385fa9d845dd326c6bbfd58c22244215e431948a [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+385fa9d845dd326c6bbfd58c22244215e431948a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking crates.io crate hc 0.1.2 [INFO] finished tweaking crates.io crate hc 0.1.2 [INFO] tweaked toml for crates.io crate hc 0.1.2 written to /workspace/builds/worker-3-tc1/source/Cargo.toml [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+385fa9d845dd326c6bbfd58c22244215e431948a" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Locking 13 packages [INFO] [stderr] Adding bitflags v0.4.0 (latest: v2.5.0) [INFO] [stderr] Adding encode_unicode v0.1.3 (latest: v1.0.0) [INFO] [stderr] Adding itertools v0.5.10 (latest: v0.12.1) [INFO] [stderr] Adding nix v0.5.1 (latest: v0.28.0) [INFO] [stderr] Adding rustyline v1.0.0 (latest: v14.0.0) [INFO] [stderr] Adding winapi v0.2.8 (latest: v0.3.9) [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+385fa9d845dd326c6bbfd58c22244215e431948a" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded rustyline v1.0.0 [INFO] [stderr] Downloaded bitflags v0.4.0 [INFO] [stderr] Downloaded nix v0.5.1 [INFO] [stderr] Downloaded itertools v0.5.10 [INFO] [stderr] Downloaded encode_unicode v0.1.3 [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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+385fa9d845dd326c6bbfd58c22244215e431948a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] e2a232a0cd1ecb6f0a103e0dad9e271761dd8a49e87e6a846cc23b8da3b225db [INFO] running `Command { std: "docker" "start" "-a" "e2a232a0cd1ecb6f0a103e0dad9e271761dd8a49e87e6a846cc23b8da3b225db", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "e2a232a0cd1ecb6f0a103e0dad9e271761dd8a49e87e6a846cc23b8da3b225db", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e2a232a0cd1ecb6f0a103e0dad9e271761dd8a49e87e6a846cc23b8da3b225db", kill_on_drop: false }` [INFO] [stdout] e2a232a0cd1ecb6f0a103e0dad9e271761dd8a49e87e6a846cc23b8da3b225db [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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+385fa9d845dd326c6bbfd58c22244215e431948a" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 6920c0f0843d97ca0a91290c48b0d6d5019cfa0ef30373114bd9a561c3a97887 [INFO] running `Command { std: "docker" "start" "-a" "6920c0f0843d97ca0a91290c48b0d6d5019cfa0ef30373114bd9a561c3a97887", kill_on_drop: false }` [INFO] [stderr] Checking bitflags v0.4.0 [INFO] [stderr] Checking encode_unicode v0.1.3 [INFO] [stderr] Checking getopts v0.2.21 [INFO] [stderr] Checking itertools v0.5.10 [INFO] [stderr] Checking nix v0.5.1 [INFO] [stderr] Checking rustyline v1.0.0 [INFO] [stderr] Checking hc v0.1.2 (/opt/rustwide/workdir) [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:115:17 [INFO] [stdout] | [INFO] [stdout] 115 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:116:17 [INFO] [stdout] | [INFO] [stdout] 116 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:125:17 [INFO] [stdout] | [INFO] [stdout] 125 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:126:17 [INFO] [stdout] | [INFO] [stdout] 126 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:135:17 [INFO] [stdout] | [INFO] [stdout] 135 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:136:17 [INFO] [stdout] | [INFO] [stdout] 136 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:145:17 [INFO] [stdout] | [INFO] [stdout] 145 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:146:17 [INFO] [stdout] | [INFO] [stdout] 146 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:159:17 [INFO] [stdout] | [INFO] [stdout] 159 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:160:17 [INFO] [stdout] | [INFO] [stdout] 160 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:169:17 [INFO] [stdout] | [INFO] [stdout] 169 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:170:17 [INFO] [stdout] | [INFO] [stdout] 170 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:179:17 [INFO] [stdout] | [INFO] [stdout] 179 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:180:17 [INFO] [stdout] | [INFO] [stdout] 180 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:189:17 [INFO] [stdout] | [INFO] [stdout] 189 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:190:17 [INFO] [stdout] | [INFO] [stdout] 190 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:199:17 [INFO] [stdout] | [INFO] [stdout] 199 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:200:17 [INFO] [stdout] | [INFO] [stdout] 200 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:209:17 [INFO] [stdout] | [INFO] [stdout] 209 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:210:17 [INFO] [stdout] | [INFO] [stdout] 210 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:219:17 [INFO] [stdout] | [INFO] [stdout] 219 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:220:17 [INFO] [stdout] | [INFO] [stdout] 220 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:229:17 [INFO] [stdout] | [INFO] [stdout] 229 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:115:17 [INFO] [stdout] | [INFO] [stdout] 115 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:116:17 [INFO] [stdout] | [INFO] [stdout] 116 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:125:17 [INFO] [stdout] | [INFO] [stdout] 125 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:126:17 [INFO] [stdout] | [INFO] [stdout] 126 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:135:17 [INFO] [stdout] | [INFO] [stdout] 135 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:136:17 [INFO] [stdout] | [INFO] [stdout] 136 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:145:17 [INFO] [stdout] | [INFO] [stdout] 145 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:146:17 [INFO] [stdout] | [INFO] [stdout] 146 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:159:17 [INFO] [stdout] | [INFO] [stdout] 159 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:160:17 [INFO] [stdout] | [INFO] [stdout] 160 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:169:17 [INFO] [stdout] | [INFO] [stdout] 169 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:170:17 [INFO] [stdout] | [INFO] [stdout] 170 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:179:17 [INFO] [stdout] | [INFO] [stdout] 179 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:180:17 [INFO] [stdout] | [INFO] [stdout] 180 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:189:17 [INFO] [stdout] | [INFO] [stdout] 189 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:190:17 [INFO] [stdout] | [INFO] [stdout] 190 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:199:17 [INFO] [stdout] | [INFO] [stdout] 199 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:200:17 [INFO] [stdout] | [INFO] [stdout] 200 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:209:17 [INFO] [stdout] | [INFO] [stdout] 209 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:210:17 [INFO] [stdout] | [INFO] [stdout] 210 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:219:17 [INFO] [stdout] | [INFO] [stdout] 219 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:220:17 [INFO] [stdout] | [INFO] [stdout] 220 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:229:17 [INFO] [stdout] | [INFO] [stdout] 229 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: panic message is not a string literal [INFO] [stdout] --> src/main.rs:40:24 [INFO] [stdout] | [INFO] [stdout] 40 | Err(f) => { panic!(f.to_string()) } [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021 [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(non_fmt_panics)]` on by default [INFO] [stdout] help: add a "{}" format string to `Display` the message [INFO] [stdout] | [INFO] [stdout] 40 | Err(f) => { panic!("{}", f.to_string()) } [INFO] [stdout] | +++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 24 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: panic message is not a string literal [INFO] [stdout] --> src/main.rs:40:24 [INFO] [stdout] | [INFO] [stdout] 40 | Err(f) => { panic!(f.to_string()) } [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021 [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(non_fmt_panics)]` on by default [INFO] [stdout] help: add a "{}" format string to `Display` the message [INFO] [stdout] | [INFO] [stdout] 40 | Err(f) => { panic!("{}", f.to_string()) } [INFO] [stdout] | +++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 24 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 2.07s [INFO] running `Command { std: "docker" "inspect" "6920c0f0843d97ca0a91290c48b0d6d5019cfa0ef30373114bd9a561c3a97887", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6920c0f0843d97ca0a91290c48b0d6d5019cfa0ef30373114bd9a561c3a97887", kill_on_drop: false }` [INFO] [stdout] 6920c0f0843d97ca0a91290c48b0d6d5019cfa0ef30373114bd9a561c3a97887 [INFO] checking hc-0.1.2 against try#645bb72776a6a56a1a8f52631a44bd082b2ba509 for absurd-question-mark-desugar [INFO] extracting crate hc 0.1.2 into /workspace/builds/worker-3-tc2/source [INFO] validating manifest of crates.io crate hc 0.1.2 on toolchain 645bb72776a6a56a1a8f52631a44bd082b2ba509 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+645bb72776a6a56a1a8f52631a44bd082b2ba509" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking crates.io crate hc 0.1.2 [INFO] finished tweaking crates.io crate hc 0.1.2 [INFO] tweaked toml for crates.io crate hc 0.1.2 written to /workspace/builds/worker-3-tc2/source/Cargo.toml [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+645bb72776a6a56a1a8f52631a44bd082b2ba509" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Updating crates.io index [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+645bb72776a6a56a1a8f52631a44bd082b2ba509" "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-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+645bb72776a6a56a1a8f52631a44bd082b2ba509" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 4ec1e03a86a0d4463ccea2db59ac9b83916476759af6e766c9d11cb399484784 [INFO] running `Command { std: "docker" "start" "-a" "4ec1e03a86a0d4463ccea2db59ac9b83916476759af6e766c9d11cb399484784", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "4ec1e03a86a0d4463ccea2db59ac9b83916476759af6e766c9d11cb399484784", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "4ec1e03a86a0d4463ccea2db59ac9b83916476759af6e766c9d11cb399484784", kill_on_drop: false }` [INFO] [stdout] 4ec1e03a86a0d4463ccea2db59ac9b83916476759af6e766c9d11cb399484784 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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:2788e3201cd34a07e3172128adcd8b3090168a8e3bcc40d7c032b9dda1df7d1c" "/opt/rustwide/cargo-home/bin/cargo" "+645bb72776a6a56a1a8f52631a44bd082b2ba509" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 8172d0ee10ab2847af3d4abf9bb94d07d0e2a921c410f69c03b5c2a6ebd81d0f [INFO] running `Command { std: "docker" "start" "-a" "8172d0ee10ab2847af3d4abf9bb94d07d0e2a921c410f69c03b5c2a6ebd81d0f", kill_on_drop: false }` [INFO] [stderr] Checking bitflags v0.4.0 [INFO] [stderr] Checking encode_unicode v0.1.3 [INFO] [stderr] Checking itertools v0.5.10 [INFO] [stderr] Checking getopts v0.2.21 [INFO] [stderr] Checking nix v0.5.1 [INFO] [stderr] Checking rustyline v1.0.0 [INFO] [stderr] Checking hc v0.1.2 (/opt/rustwide/workdir) [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:115:17 [INFO] [stdout] | [INFO] [stdout] 115 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:116:17 [INFO] [stdout] | [INFO] [stdout] 116 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:125:17 [INFO] [stdout] | [INFO] [stdout] 125 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:126:17 [INFO] [stdout] | [INFO] [stdout] 126 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:135:17 [INFO] [stdout] | [INFO] [stdout] 135 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:136:17 [INFO] [stdout] | [INFO] [stdout] 136 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:145:17 [INFO] [stdout] | [INFO] [stdout] 145 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:146:17 [INFO] [stdout] | [INFO] [stdout] 146 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:159:17 [INFO] [stdout] | [INFO] [stdout] 159 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:160:17 [INFO] [stdout] | [INFO] [stdout] 160 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:169:17 [INFO] [stdout] | [INFO] [stdout] 169 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:170:17 [INFO] [stdout] | [INFO] [stdout] 170 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:179:17 [INFO] [stdout] | [INFO] [stdout] 179 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:180:17 [INFO] [stdout] | [INFO] [stdout] 180 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:189:17 [INFO] [stdout] | [INFO] [stdout] 189 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:190:17 [INFO] [stdout] | [INFO] [stdout] 190 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:199:17 [INFO] [stdout] | [INFO] [stdout] 199 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:200:17 [INFO] [stdout] | [INFO] [stdout] 200 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:209:17 [INFO] [stdout] | [INFO] [stdout] 209 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:210:17 [INFO] [stdout] | [INFO] [stdout] 210 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:219:17 [INFO] [stdout] | [INFO] [stdout] 219 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:220:17 [INFO] [stdout] | [INFO] [stdout] 220 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:229:17 [INFO] [stdout] | [INFO] [stdout] 229 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:115:17 [INFO] [stdout] | [INFO] [stdout] 115 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:116:17 [INFO] [stdout] | [INFO] [stdout] 116 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:125:17 [INFO] [stdout] | [INFO] [stdout] 125 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:126:17 [INFO] [stdout] | [INFO] [stdout] 126 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:135:17 [INFO] [stdout] | [INFO] [stdout] 135 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:136:17 [INFO] [stdout] | [INFO] [stdout] 136 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:145:17 [INFO] [stdout] | [INFO] [stdout] 145 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:146:17 [INFO] [stdout] | [INFO] [stdout] 146 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:159:17 [INFO] [stdout] | [INFO] [stdout] 159 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:160:17 [INFO] [stdout] | [INFO] [stdout] 160 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:169:17 [INFO] [stdout] | [INFO] [stdout] 169 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:170:17 [INFO] [stdout] | [INFO] [stdout] 170 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:179:17 [INFO] [stdout] | [INFO] [stdout] 179 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:180:17 [INFO] [stdout] | [INFO] [stdout] 180 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:189:17 [INFO] [stdout] | [INFO] [stdout] 189 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:190:17 [INFO] [stdout] | [INFO] [stdout] 190 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:199:17 [INFO] [stdout] | [INFO] [stdout] 199 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:200:17 [INFO] [stdout] | [INFO] [stdout] 200 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:209:17 [INFO] [stdout] | [INFO] [stdout] 209 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:210:17 [INFO] [stdout] | [INFO] [stdout] 210 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:219:17 [INFO] [stdout] | [INFO] [stdout] 219 | let lhs = try!(execute(ctx, &*l)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:220:17 [INFO] [stdout] | [INFO] [stdout] 220 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/executor.rs:229:17 [INFO] [stdout] | [INFO] [stdout] 229 | let rhs = try!(execute(ctx, &*r)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: panic message is not a string literal [INFO] [stdout] --> src/main.rs:40:24 [INFO] [stdout] | [INFO] [stdout] 40 | Err(f) => { panic!(f.to_string()) } [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021 [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(non_fmt_panics)]` on by default [INFO] [stdout] help: add a "{}" format string to `Display` the message [INFO] [stdout] | [INFO] [stdout] 40 | Err(f) => { panic!("{}", f.to_string()) } [INFO] [stdout] | +++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 24 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: panic message is not a string literal [INFO] [stdout] --> src/main.rs:40:24 [INFO] [stdout] | [INFO] [stdout] 40 | Err(f) => { panic!(f.to_string()) } [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: this usage of `panic!()` is deprecated; it will be a hard error in Rust 2021 [INFO] [stdout] = note: for more information, see [INFO] [stdout] = note: `#[warn(non_fmt_panics)]` on by default [INFO] [stdout] help: add a "{}" format string to `Display` the message [INFO] [stdout] | [INFO] [stdout] 40 | Err(f) => { panic!("{}", f.to_string()) } [INFO] [stdout] | +++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 24 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1.90s [INFO] running `Command { std: "docker" "inspect" "8172d0ee10ab2847af3d4abf9bb94d07d0e2a921c410f69c03b5c2a6ebd81d0f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8172d0ee10ab2847af3d4abf9bb94d07d0e2a921c410f69c03b5c2a6ebd81d0f", kill_on_drop: false }` [INFO] [stdout] 8172d0ee10ab2847af3d4abf9bb94d07d0e2a921c410f69c03b5c2a6ebd81d0f