[INFO] fetching crate peace_params 0.0.15... [INFO] checking peace_params-0.0.15 against try#b6bca0d7327839b5e3f7a7779947cb9113d08917+rustflags=-Zstrict-projection-item-bounds for 150662-leaf-spurious [INFO] extracting crate peace_params 0.0.15 into /workspace/builds/worker-3-tc2/source [INFO] started tweaking crates.io crate peace_params 0.0.15 [INFO] finished tweaking crates.io crate peace_params 0.0.15 [INFO] tweaked toml for crates.io crate peace_params 0.0.15 written to /workspace/builds/worker-3-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate peace_params 0.0.15 on toolchain b6bca0d7327839b5e3f7a7779947cb9113d08917 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b6bca0d7327839b5e3f7a7779947cb9113d08917" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate peace_params 0.0.15 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" "+b6bca0d7327839b5e3f7a7779947cb9113d08917" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b6bca0d7327839b5e3f7a7779947cb9113d08917" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 095c4e6373e8c7a65541573c43c33b9283146152452301da774ab9adf0170ce4 [INFO] running `Command { std: "docker" "start" "-a" "095c4e6373e8c7a65541573c43c33b9283146152452301da774ab9adf0170ce4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "095c4e6373e8c7a65541573c43c33b9283146152452301da774ab9adf0170ce4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "095c4e6373e8c7a65541573c43c33b9283146152452301da774ab9adf0170ce4", kill_on_drop: false }` [INFO] [stdout] 095c4e6373e8c7a65541573c43c33b9283146152452301da774ab9adf0170ce4 [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 -Zstrict-projection-item-bounds" "-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+b6bca0d7327839b5e3f7a7779947cb9113d08917" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] c52c1825cd89b4d435e9aff761527c4f830224844da949b1726adce23e1d26e7 [INFO] running `Command { std: "docker" "start" "-a" "c52c1825cd89b4d435e9aff761527c4f830224844da949b1726adce23e1d26e7", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.95 [INFO] [stderr] Compiling unicode-ident v1.0.18 [INFO] [stderr] Compiling serde v1.0.219 [INFO] [stderr] Checking equivalent v1.0.2 [INFO] [stderr] Compiling autocfg v1.4.0 [INFO] [stderr] Checking memchr v2.7.4 [INFO] [stderr] Checking allocator-api2 v0.2.21 [INFO] [stderr] Checking foldhash v0.1.5 [INFO] [stderr] Checking futures-sink v0.3.31 [INFO] [stderr] Checking pin-project-lite v0.2.16 [INFO] [stderr] Checking futures-core v0.3.31 [INFO] [stderr] Checking id_newtype v0.1.0 [INFO] [stderr] Checking futures-io v0.3.31 [INFO] [stderr] Checking futures-task v0.3.31 [INFO] [stderr] Compiling typeid v1.0.3 [INFO] [stderr] Compiling resman v0.19.0 [INFO] [stderr] Checking rt_ref v0.3.0 [INFO] [stderr] Checking fixedbitset v0.5.7 [INFO] [stderr] Checking downcast-rs v2.0.1 [INFO] [stderr] Checking tokio v1.44.2 [INFO] [stderr] Checking own v0.1.3 [INFO] [stderr] Checking futures-channel v0.3.31 [INFO] [stderr] Checking smallvec v1.15.0 [INFO] [stderr] Compiling thiserror v2.0.12 [INFO] [stderr] Checking rt_map v0.6.0 [INFO] [stderr] Checking dyn-clone v1.0.19 [INFO] [stderr] Checking hashbrown v0.15.2 [INFO] [stderr] Compiling slab v0.4.9 [INFO] [stderr] Checking nom v8.0.0 [INFO] [stderr] Compiling quote v1.0.40 [INFO] [stderr] Compiling syn v2.0.100 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling async-trait v0.1.88 [INFO] [stderr] Compiling peace_static_check_macros v0.0.15 [INFO] [stderr] Compiling dot_ix_static_check_macros v0.10.0 [INFO] [stderr] Compiling peace_data_derive v0.0.15 [INFO] [stderr] Compiling thiserror-impl v2.0.12 [INFO] [stderr] Compiling peace_params_derive v0.0.15 [INFO] [stderr] Checking futures-util v0.3.31 [INFO] [stderr] Checking futures-executor v0.3.31 [INFO] [stderr] Checking futures v0.3.31 [INFO] [stderr] Checking interruptible v0.2.4 [INFO] [stderr] Checking indexmap v2.9.0 [INFO] [stderr] Checking peace_fmt v0.0.15 [INFO] [stderr] Checking tynm v0.2.0 [INFO] [stderr] Checking erased-serde v0.4.6 [INFO] [stderr] Checking peace_core v0.0.15 [INFO] [stderr] Checking petgraph v0.8.1 [INFO] [stderr] Checking dot_ix_model v0.10.0 [INFO] [stderr] Checking peace_item_model v0.0.15 [INFO] [stderr] Checking peace_profile_model v0.0.15 [INFO] [stderr] Checking serde_tagged v0.4.0 [INFO] [stderr] Checking type_reg v0.9.0 [INFO] [stderr] Checking dot_ix v0.10.0 [INFO] [stderr] Checking daggy v0.9.0 [INFO] [stderr] Checking fn_graph v0.18.0 [INFO] [stderr] Checking peace_data v0.0.15 [INFO] [stderr] Checking peace_flow_model v0.0.15 [INFO] [stderr] Checking peace_resource_rt v0.0.15 [INFO] [stderr] Checking peace_params v0.0.15 (/opt/rustwide/workdir) [INFO] [stdout] error[E0277]: the trait bound `T: Deserialize<'_>` is not satisfied [INFO] [stdout] --> src/params_spec_fieldless.rs:115:24 [INFO] [stdout] | [INFO] [stdout] 115 | T: ParamsFieldless> + Clone + Debug + Send + Sync + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `Deserialize<'_>` is not implemented for `T` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `T` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] note: required for `ParamsSpecFieldless` to implement `for<'de> Deserialize<'de>` [INFO] [stdout] --> src/params_spec_fieldless.rs:33:10 [INFO] [stdout] | [INFO] [stdout] 31 | #[derive(Clone, Serialize, Deserialize)] [INFO] [stdout] | ----------- type parameter would need to implement `for<'de> Deserialize<'de>` [INFO] [stdout] 32 | #[serde(from = "crate::ParamsSpecFieldlessDe")] [INFO] [stdout] 33 | pub enum ParamsSpecFieldless [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: consider manually implementing `for<'de> Deserialize<'de>` to avoid undesired bounds [INFO] [stdout] help: consider further restricting type parameter `T` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 115 | T: ParamsFieldless> + Clone + Debug + Send + Sync + 'static + any_spec_rt_boxed::_::_serde::Deserialize<'_>, [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `T: any_spec_rt_boxed::_::_serde::Serialize` is not satisfied [INFO] [stdout] --> src/params_spec_fieldless.rs:115:24 [INFO] [stdout] | [INFO] [stdout] 115 | T: ParamsFieldless> + Clone + Debug + Send + Sync + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `any_spec_rt_boxed::_::_serde::Serialize` is not implemented for `T` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `T` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] note: required for `ParamsSpecFieldless` to implement `any_spec_rt_boxed::_::_serde::Serialize` [INFO] [stdout] --> src/params_spec_fieldless.rs:33:10 [INFO] [stdout] | [INFO] [stdout] 31 | #[derive(Clone, Serialize, Deserialize)] [INFO] [stdout] | --------- type parameter would need to implement `any_spec_rt_boxed::_::_serde::Serialize` [INFO] [stdout] 32 | #[serde(from = "crate::ParamsSpecFieldlessDe")] [INFO] [stdout] 33 | pub enum ParamsSpecFieldless [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: consider manually implementing `any_spec_rt_boxed::_::_serde::Serialize` to avoid undesired bounds [INFO] [stdout] help: consider further restricting type parameter `T` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 115 | T: ParamsFieldless> + Clone + Debug + Send + Sync + 'static + any_spec_rt_boxed::_::_serde::Serialize, [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `T: Deserialize<'_>` is not satisfied [INFO] [stdout] --> src/params_spec_fieldless.rs:175:24 [INFO] [stdout] | [INFO] [stdout] 175 | T: ParamsFieldless> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `Deserialize<'_>` is not implemented for `T` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `T` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] note: required for `ParamsSpecFieldless` to implement `for<'de> Deserialize<'de>` [INFO] [stdout] --> src/params_spec_fieldless.rs:33:10 [INFO] [stdout] | [INFO] [stdout] 31 | #[derive(Clone, Serialize, Deserialize)] [INFO] [stdout] | ----------- type parameter would need to implement `for<'de> Deserialize<'de>` [INFO] [stdout] 32 | #[serde(from = "crate::ParamsSpecFieldlessDe")] [INFO] [stdout] 33 | pub enum ParamsSpecFieldless [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: consider manually implementing `for<'de> Deserialize<'de>` to avoid undesired bounds [INFO] [stdout] help: consider further restricting type parameter `T` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 181 | + 'static + any_spec_rt_boxed::_::_serde::Deserialize<'_>, [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `T: Deserialize<'_>` is not satisfied [INFO] [stdout] --> src/params_spec_fieldless.rs:218:24 [INFO] [stdout] | [INFO] [stdout] 218 | T: ParamsFieldless> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `Deserialize<'_>` is not implemented for `T` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `T` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] note: required for `ParamsSpecFieldless` to implement `for<'de> Deserialize<'de>` [INFO] [stdout] --> src/params_spec_fieldless.rs:33:10 [INFO] [stdout] | [INFO] [stdout] 31 | #[derive(Clone, Serialize, Deserialize)] [INFO] [stdout] | ----------- type parameter would need to implement `for<'de> Deserialize<'de>` [INFO] [stdout] 32 | #[serde(from = "crate::ParamsSpecFieldlessDe")] [INFO] [stdout] 33 | pub enum ParamsSpecFieldless [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: consider manually implementing `for<'de> Deserialize<'de>` to avoid undesired bounds [INFO] [stdout] help: consider further restricting type parameter `T` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 224 | + 'static + any_spec_rt_boxed::_::_serde::Deserialize<'_>, [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `T: Deserialize<'_>` is not satisfied [INFO] [stdout] --> src/params_spec_fieldless.rs:115:24 [INFO] [stdout] | [INFO] [stdout] 115 | T: ParamsFieldless> + Clone + Debug + Send + Sync + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `Deserialize<'_>` is not implemented for `T` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `T` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] note: required for `ParamsSpecFieldless` to implement `for<'de> Deserialize<'de>` [INFO] [stdout] --> src/params_spec_fieldless.rs:33:10 [INFO] [stdout] | [INFO] [stdout] 31 | #[derive(Clone, Serialize, Deserialize)] [INFO] [stdout] | ----------- type parameter would need to implement `for<'de> Deserialize<'de>` [INFO] [stdout] 32 | #[serde(from = "crate::ParamsSpecFieldlessDe")] [INFO] [stdout] 33 | pub enum ParamsSpecFieldless [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: consider manually implementing `for<'de> Deserialize<'de>` to avoid undesired bounds [INFO] [stdout] help: consider further restricting type parameter `T` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 115 | T: ParamsFieldless> + Clone + Debug + Send + Sync + 'static + any_spec_rt_boxed::_::_serde::Deserialize<'_>, [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `T: any_spec_rt_boxed::_::_serde::Serialize` is not satisfied [INFO] [stdout] --> src/params_spec_fieldless.rs:115:24 [INFO] [stdout] | [INFO] [stdout] 115 | T: ParamsFieldless> + Clone + Debug + Send + Sync + 'static, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `any_spec_rt_boxed::_::_serde::Serialize` is not implemented for `T` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Serialize)]` to your `T` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] note: required for `ParamsSpecFieldless` to implement `any_spec_rt_boxed::_::_serde::Serialize` [INFO] [stdout] --> src/params_spec_fieldless.rs:33:10 [INFO] [stdout] | [INFO] [stdout] 31 | #[derive(Clone, Serialize, Deserialize)] [INFO] [stdout] | --------- type parameter would need to implement `any_spec_rt_boxed::_::_serde::Serialize` [INFO] [stdout] 32 | #[serde(from = "crate::ParamsSpecFieldlessDe")] [INFO] [stdout] 33 | pub enum ParamsSpecFieldless [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: consider manually implementing `any_spec_rt_boxed::_::_serde::Serialize` to avoid undesired bounds [INFO] [stdout] help: consider further restricting type parameter `T` with trait `Serialize` [INFO] [stdout] | [INFO] [stdout] 115 | T: ParamsFieldless> + Clone + Debug + Send + Sync + 'static + any_spec_rt_boxed::_::_serde::Serialize, [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `T: Deserialize<'_>` is not satisfied [INFO] [stdout] --> src/params_spec_fieldless.rs:175:24 [INFO] [stdout] | [INFO] [stdout] 175 | T: ParamsFieldless> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `Deserialize<'_>` is not implemented for `T` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `T` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] note: required for `ParamsSpecFieldless` to implement `for<'de> Deserialize<'de>` [INFO] [stdout] --> src/params_spec_fieldless.rs:33:10 [INFO] [stdout] | [INFO] [stdout] 31 | #[derive(Clone, Serialize, Deserialize)] [INFO] [stdout] | ----------- type parameter would need to implement `for<'de> Deserialize<'de>` [INFO] [stdout] 32 | #[serde(from = "crate::ParamsSpecFieldlessDe")] [INFO] [stdout] 33 | pub enum ParamsSpecFieldless [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: consider manually implementing `for<'de> Deserialize<'de>` to avoid undesired bounds [INFO] [stdout] help: consider further restricting type parameter `T` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 181 | + 'static + any_spec_rt_boxed::_::_serde::Deserialize<'_>, [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `T: Deserialize<'_>` is not satisfied [INFO] [stdout] --> src/params_spec_fieldless.rs:218:24 [INFO] [stdout] | [INFO] [stdout] 218 | T: ParamsFieldless> [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the trait `Deserialize<'_>` is not implemented for `T` [INFO] [stdout] | [INFO] [stdout] = note: for local types consider adding `#[derive(serde::Deserialize)]` to your `T` type [INFO] [stdout] = note: for types from other crates check whether the crate offers a `serde` feature flag [INFO] [stdout] note: required for `ParamsSpecFieldless` to implement `for<'de> Deserialize<'de>` [INFO] [stdout] --> src/params_spec_fieldless.rs:33:10 [INFO] [stdout] | [INFO] [stdout] 31 | #[derive(Clone, Serialize, Deserialize)] [INFO] [stdout] | ----------- type parameter would need to implement `for<'de> Deserialize<'de>` [INFO] [stdout] 32 | #[serde(from = "crate::ParamsSpecFieldlessDe")] [INFO] [stdout] 33 | pub enum ParamsSpecFieldless [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: consider manually implementing `for<'de> Deserialize<'de>` to avoid undesired bounds [INFO] [stdout] help: consider further restricting type parameter `T` with trait `Deserialize` [INFO] [stdout] | [INFO] [stdout] 224 | + 'static + any_spec_rt_boxed::_::_serde::Deserialize<'_>, [INFO] [stdout] | +++++++++++++++++++++++++++++++++++++++++++++++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] For more information about this error, try `rustc --explain E0277`. [INFO] [stdout] [INFO] [stderr] error: could not compile `peace_params` (lib test) due to 4 previous errors [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stdout] For more information about this error, try `rustc --explain E0277`. [INFO] [stdout] [INFO] [stderr] error: could not compile `peace_params` (lib) due to 4 previous errors [INFO] running `Command { std: "docker" "inspect" "c52c1825cd89b4d435e9aff761527c4f830224844da949b1726adce23e1d26e7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c52c1825cd89b4d435e9aff761527c4f830224844da949b1726adce23e1d26e7", kill_on_drop: false }` [INFO] [stdout] c52c1825cd89b4d435e9aff761527c4f830224844da949b1726adce23e1d26e7