[INFO] fetching crate chalk-engine 0.46.0... [INFO] checking chalk-engine-0.46.0 against master#a609fb45efad59dfd459c76e50899be9f0583b5a for pr-80579 [INFO] extracting crate chalk-engine 0.46.0 into /workspace/builds/worker-5/source [INFO] validating manifest of crates.io crate chalk-engine 0.46.0 on toolchain a609fb45efad59dfd459c76e50899be9f0583b5a [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+a609fb45efad59dfd459c76e50899be9f0583b5a" "read-manifest" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] started tweaking crates.io crate chalk-engine 0.46.0 [INFO] finished tweaking crates.io crate chalk-engine 0.46.0 [INFO] tweaked toml for crates.io crate chalk-engine 0.46.0 written to /workspace/builds/worker-5/source/Cargo.toml [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+a609fb45efad59dfd459c76e50899be9f0583b5a" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }` [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+a609fb45efad59dfd459c76e50899be9f0583b5a" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5/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" "rustops/crates-build-env@sha256:c8ac004eab7d63a0ad09a2dde3d3353ba464f767bee4de425dc8f74c46a1905e" "/opt/rustwide/cargo-home/bin/cargo" "+a609fb45efad59dfd459c76e50899be9f0583b5a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] f804bf2cad2ba881b5ae8571ce07e23fe148557cd04c7f78aa5241aaea63727d [INFO] running `Command { std: "docker" "start" "-a" "f804bf2cad2ba881b5ae8571ce07e23fe148557cd04c7f78aa5241aaea63727d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "f804bf2cad2ba881b5ae8571ce07e23fe148557cd04c7f78aa5241aaea63727d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f804bf2cad2ba881b5ae8571ce07e23fe148557cd04c7f78aa5241aaea63727d", kill_on_drop: false }` [INFO] [stdout] f804bf2cad2ba881b5ae8571ce07e23fe148557cd04c7f78aa5241aaea63727d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5/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" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "rustops/crates-build-env@sha256:c8ac004eab7d63a0ad09a2dde3d3353ba464f767bee4de425dc8f74c46a1905e" "/opt/rustwide/cargo-home/bin/cargo" "+a609fb45efad59dfd459c76e50899be9f0583b5a" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 253649578e0846185f5c77e2bbfd0c6a7205bfbeda5a0ade593b7027e4d38574 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "253649578e0846185f5c77e2bbfd0c6a7205bfbeda5a0ade593b7027e4d38574", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.24 [INFO] [stderr] Compiling unicode-xid v0.2.1 [INFO] [stderr] Compiling syn v1.0.56 [INFO] [stderr] Compiling autocfg v1.0.1 [INFO] [stderr] Compiling serde_derive v1.0.118 [INFO] [stderr] Compiling libc v0.2.81 [INFO] [stderr] Compiling byteorder v1.3.4 [INFO] [stderr] Compiling log v0.4.11 [INFO] [stderr] Compiling serde v1.0.118 [INFO] [stderr] Checking cfg-if v0.1.10 [INFO] [stderr] Checking regex-syntax v0.6.21 [INFO] [stderr] Compiling ryu v1.0.5 [INFO] [stderr] Compiling serde_json v1.0.61 [INFO] [stderr] Compiling bitflags v1.2.1 [INFO] [stderr] Checking itoa v0.4.7 [INFO] [stderr] Checking pin-project-lite v0.2.0 [INFO] [stderr] Checking cfg-if v1.0.0 [INFO] [stderr] Checking fixedbitset v0.2.0 [INFO] [stderr] Checking termcolor v1.1.2 [INFO] [stderr] Checking either v1.6.1 [INFO] [stderr] Checking tracing-core v0.1.17 [INFO] [stderr] Checking thread_local v1.0.1 [INFO] [stderr] Checking sharded-slab v0.1.0 [INFO] [stderr] Checking itertools v0.9.0 [INFO] [stderr] Compiling num-traits v0.2.14 [INFO] [stderr] Compiling num-integer v0.1.44 [INFO] [stderr] Compiling indexmap v1.6.1 [INFO] [stderr] Checking ena v0.14.0 [INFO] [stderr] Checking tracing-log v0.1.1 [INFO] [stderr] Compiling quote v1.0.8 [INFO] [stderr] Checking time v0.1.44 [INFO] [stderr] Checking atty v0.2.14 [INFO] [stderr] Checking petgraph v0.5.1 [INFO] [stderr] Checking chrono v0.4.19 [INFO] [stderr] Checking regex-automata v0.1.9 [INFO] [stderr] Checking regex v1.4.2 [INFO] [stderr] Checking matchers v0.0.1 [INFO] [stderr] Compiling synstructure v0.12.4 [INFO] [stderr] Compiling tracing-attributes v0.1.11 [INFO] [stderr] Compiling chalk-derive v0.46.0 [INFO] [stderr] Checking chalk-ir v0.46.0 [INFO] [stderr] Checking tracing v0.1.22 [INFO] [stderr] Checking tracing-serde v0.1.2 [INFO] [stderr] Checking tracing-subscriber v0.2.15 [INFO] [stderr] Checking tracing-tree v0.1.6 [INFO] [stderr] Checking chalk-solve v0.46.0 [INFO] [stderr] Checking chalk-engine v0.46.0 (/opt/rustwide/workdir) [INFO] [stdout] error[E0433]: failed to resolve: use of undeclared crate or module `chalk_integration` [INFO] [stdout] --> src/normalize_deep.rs:112:9 [INFO] [stdout] | [INFO] [stdout] 112 | use chalk_integration::interner::ChalkIr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ use of undeclared crate or module `chalk_integration` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0432]: unresolved import `chalk_integration` [INFO] [stdout] --> src/normalize_deep.rs:113:9 [INFO] [stdout] | [INFO] [stdout] 113 | use chalk_integration::{arg, ty}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ use of undeclared crate or module `chalk_integration` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0433]: failed to resolve: use of undeclared crate or module `chalk_integration` [INFO] [stdout] --> src/slg/aggregate.rs:585:13 [INFO] [stdout] | [INFO] [stdout] 585 | use chalk_integration::interner::ChalkIr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ use of undeclared crate or module `chalk_integration` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0433]: failed to resolve: use of undeclared crate or module `chalk_integration` [INFO] [stdout] --> src/slg/aggregate.rs:603:13 [INFO] [stdout] | [INFO] [stdout] 603 | use chalk_integration::interner::ChalkIr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ use of undeclared crate or module `chalk_integration` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0433]: failed to resolve: use of undeclared crate or module `chalk_integration` [INFO] [stdout] --> src/slg/aggregate.rs:622:13 [INFO] [stdout] | [INFO] [stdout] 622 | use chalk_integration::interner::ChalkIr; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ use of undeclared crate or module `chalk_integration` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0432]: unresolved import `chalk_integration` [INFO] [stdout] --> src/slg/aggregate.rs:578:9 [INFO] [stdout] | [INFO] [stdout] 578 | use chalk_integration::{arg, ty}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ use of undeclared crate or module `chalk_integration` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/normalize_deep.rs:145:18 [INFO] [stdout] | [INFO] [stdout] 145 | &ty!(apply (item 0) (expr b)), [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/normalize_deep.rs:156:13 [INFO] [stdout] | [INFO] [stdout] 156 | ty!(apply (item 0) (expr DeepNormalizer::normalize_deep(&mut table, interner, b.clone()))), [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/normalize_deep.rs:165:18 [INFO] [stdout] | [INFO] [stdout] 165 | &ty!(apply (item 1)), [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/normalize_deep.rs:170:13 [INFO] [stdout] | [INFO] [stdout] 170 | ty!(apply (item 0) (apply (item 1))) [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/slg/aggregate.rs:594:14 [INFO] [stdout] | [INFO] [stdout] 594 | &ty!(apply (item 0) (apply (item 1))), [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/slg/aggregate.rs:595:14 [INFO] [stdout] | [INFO] [stdout] 595 | &ty!(apply (item 0) (apply (item 2))), [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/slg/aggregate.rs:597:20 [INFO] [stdout] | [INFO] [stdout] 597 | assert_eq!(ty!(apply (item 0) (infer 0)), ty); [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/slg/aggregate.rs:613:14 [INFO] [stdout] | [INFO] [stdout] 613 | &ty!(apply (item 0) (apply (item 1))), [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/slg/aggregate.rs:614:14 [INFO] [stdout] | [INFO] [stdout] 614 | &ty!(apply (item 0) (apply (item 1))), [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/slg/aggregate.rs:616:20 [INFO] [stdout] | [INFO] [stdout] 616 | assert_eq!(ty!(apply (item 0) (apply (item 1))), ty); [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/slg/aggregate.rs:635:14 [INFO] [stdout] | [INFO] [stdout] 635 | &ty!(apply (item 0) (infer 0)), [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/slg/aggregate.rs:636:14 [INFO] [stdout] | [INFO] [stdout] 636 | &ty!(apply (item 0) (infer 1)), [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: cannot determine resolution for the macro `ty` [INFO] [stdout] --> src/slg/aggregate.rs:640:20 [INFO] [stdout] | [INFO] [stdout] 640 | assert_eq!(ty!(apply (item 0) (infer 0)), ty); [INFO] [stdout] | ^^ [INFO] [stdout] | [INFO] [stdout] = note: import resolution is stuck, try simplifying macro imports [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0412]: cannot find type `ChalkIr` in this scope [INFO] [stdout] --> src/normalize_deep.rs:121:30 [INFO] [stdout] | [INFO] [stdout] 121 | impl UnificationDatabase for TestDatabase { [INFO] [stdout] | - ^^^^^^^ not found in this scope [INFO] [stdout] | | [INFO] [stdout] | help: you might be missing a type parameter: `` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0412]: cannot find type `ChalkIr` in this scope [INFO] [stdout] --> src/normalize_deep.rs:122:55 [INFO] [stdout] | [INFO] [stdout] 121 | impl UnificationDatabase for TestDatabase { [INFO] [stdout] | - help: you might be missing a type parameter: `` [INFO] [stdout] 122 | fn fn_def_variance(&self, _fn_def_id: FnDefId) -> Variances { [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0412]: cannot find type `ChalkIr` in this scope [INFO] [stdout] --> src/normalize_deep.rs:122:78 [INFO] [stdout] | [INFO] [stdout] 121 | impl UnificationDatabase for TestDatabase { [INFO] [stdout] | - help: you might be missing a type parameter: `` [INFO] [stdout] 122 | fn fn_def_variance(&self, _fn_def_id: FnDefId) -> Variances { [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0425]: cannot find value `ChalkIr` in this scope [INFO] [stdout] --> src/normalize_deep.rs:123:30 [INFO] [stdout] | [INFO] [stdout] 123 | Variances::from(&ChalkIr, [Variance::Invariant; 20].iter().copied()) [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0412]: cannot find type `ChalkIr` in this scope [INFO] [stdout] --> src/normalize_deep.rs:126:47 [INFO] [stdout] | [INFO] [stdout] 121 | impl UnificationDatabase for TestDatabase { [INFO] [stdout] | - help: you might be missing a type parameter: `` [INFO] [stdout] ... [INFO] [stdout] 126 | fn adt_variance(&self, _adt_id: AdtId) -> Variances { [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0412]: cannot find type `ChalkIr` in this scope [INFO] [stdout] --> src/normalize_deep.rs:126:70 [INFO] [stdout] | [INFO] [stdout] 121 | impl UnificationDatabase for TestDatabase { [INFO] [stdout] | - help: you might be missing a type parameter: `` [INFO] [stdout] ... [INFO] [stdout] 126 | fn adt_variance(&self, _adt_id: AdtId) -> Variances { [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0425]: cannot find value `ChalkIr` in this scope [INFO] [stdout] --> src/normalize_deep.rs:127:30 [INFO] [stdout] | [INFO] [stdout] 127 | Variances::from(&ChalkIr, [Variance::Invariant; 20].iter().copied()) [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0425]: cannot find value `ChalkIr` in this scope [INFO] [stdout] --> src/normalize_deep.rs:133:25 [INFO] [stdout] | [INFO] [stdout] 133 | let interner = &ChalkIr; [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0412]: cannot find type `ChalkIr` in this scope [INFO] [stdout] --> src/normalize_deep.rs:134:39 [INFO] [stdout] | [INFO] [stdout] 132 | fn infer() { [INFO] [stdout] | - help: you might be missing a type parameter: `` [INFO] [stdout] 133 | let interner = &ChalkIr; [INFO] [stdout] 134 | let mut table: InferenceTable = InferenceTable::new(); [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0412]: cannot find type `ChalkIr` in this scope [INFO] [stdout] --> src/slg/aggregate.rs:586:39 [INFO] [stdout] | [INFO] [stdout] 584 | fn vec_i32_vs_vec_u32() { [INFO] [stdout] | - help: you might be missing a type parameter: `` [INFO] [stdout] 585 | use chalk_integration::interner::ChalkIr; [INFO] [stdout] 586 | let mut infer: InferenceTable = InferenceTable::new(); [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0425]: cannot find value `ChalkIr` in this scope [INFO] [stdout] --> src/slg/aggregate.rs:590:24 [INFO] [stdout] | [INFO] [stdout] 590 | interner: &ChalkIr, [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0425]: cannot find value `ChalkIr` in this scope [INFO] [stdout] --> src/slg/aggregate.rs:604:25 [INFO] [stdout] | [INFO] [stdout] 604 | let interner = &ChalkIr; [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0412]: cannot find type `ChalkIr` in this scope [INFO] [stdout] --> src/slg/aggregate.rs:605:39 [INFO] [stdout] | [INFO] [stdout] 602 | fn vec_i32_vs_vec_i32() { [INFO] [stdout] | - help: you might be missing a type parameter: `` [INFO] [stdout] ... [INFO] [stdout] 605 | let mut infer: InferenceTable = InferenceTable::new(); [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0425]: cannot find value `ChalkIr` in this scope [INFO] [stdout] --> src/slg/aggregate.rs:623:25 [INFO] [stdout] | [INFO] [stdout] 623 | let interner = &ChalkIr; [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0412]: cannot find type `ChalkIr` in this scope [INFO] [stdout] --> src/slg/aggregate.rs:624:39 [INFO] [stdout] | [INFO] [stdout] 621 | fn vec_x_vs_vec_y() { [INFO] [stdout] | - help: you might be missing a type parameter: `` [INFO] [stdout] ... [INFO] [stdout] 624 | let mut infer: InferenceTable = InferenceTable::new(); [INFO] [stdout] | ^^^^^^^ not found in this scope [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: aborting due to 34 previous errors [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] Some errors have detailed explanations: E0412, E0425, E0432, E0433. [INFO] [stdout] [INFO] [stdout] For more information about an error, try `rustc --explain E0412`. [INFO] [stdout] [INFO] [stderr] error: could not compile `chalk-engine` [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] error: build failed [INFO] running `Command { std: "docker" "inspect" "253649578e0846185f5c77e2bbfd0c6a7205bfbeda5a0ade593b7027e4d38574", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "253649578e0846185f5c77e2bbfd0c6a7205bfbeda5a0ade593b7027e4d38574", kill_on_drop: false }` [INFO] [stdout] 253649578e0846185f5c77e2bbfd0c6a7205bfbeda5a0ade593b7027e4d38574