[INFO] cloning repository https://github.com/sgh370/rustvalidity [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/sgh370/rustvalidity" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsgh370%2Frustvalidity", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsgh370%2Frustvalidity'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] be186d8f12b5135ce27df0a31f33a7a4c0a54571 [INFO] checking sgh370/rustvalidity against try#a7b168ac4977e8e93a43448b44847adaa305d5a9 for pr-150557 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsgh370%2Frustvalidity" "/workspace/builds/worker-3-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/sgh370/rustvalidity [INFO] finished tweaking git repo https://github.com/sgh370/rustvalidity [INFO] tweaked toml for git repo https://github.com/sgh370/rustvalidity written to /workspace/builds/worker-3-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/sgh370/rustvalidity on toolchain a7b168ac4977e8e93a43448b44847adaa305d5a9 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+a7b168ac4977e8e93a43448b44847adaa305d5a9" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/sgh370/rustvalidity already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+a7b168ac4977e8e93a43448b44847adaa305d5a9" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+a7b168ac4977e8e93a43448b44847adaa305d5a9" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 1378f95220f5ccce15c88390e7f4b8b363f6ad53a7e6e234599385090346867c [INFO] running `Command { std: "docker" "start" "-a" "1378f95220f5ccce15c88390e7f4b8b363f6ad53a7e6e234599385090346867c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "1378f95220f5ccce15c88390e7f4b8b363f6ad53a7e6e234599385090346867c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1378f95220f5ccce15c88390e7f4b8b363f6ad53a7e6e234599385090346867c", kill_on_drop: false }` [INFO] [stdout] 1378f95220f5ccce15c88390e7f4b8b363f6ad53a7e6e234599385090346867c [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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+a7b168ac4977e8e93a43448b44847adaa305d5a9" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 296e461f2b7c2d9567554e67ae5c38c7ec60900a4fe01496e74edd81b993ca5c [INFO] running `Command { std: "docker" "start" "-a" "296e461f2b7c2d9567554e67ae5c38c7ec60900a4fe01496e74edd81b993ca5c", kill_on_drop: false }` [INFO] [stderr] Compiling getrandom v0.3.2 [INFO] [stderr] Checking percent-encoding v2.3.1 [INFO] [stderr] Checking unicode-ident v1.0.18 [INFO] [stderr] Checking regex v1.11.1 [INFO] [stderr] Compiling synstructure v0.13.1 [INFO] [stderr] Compiling zerovec-derive v0.10.3 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling icu_provider_macros v1.5.0 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Checking proc-macro2 v1.0.95 [INFO] [stderr] Checking form_urlencoded v1.2.1 [INFO] [stderr] Checking uuid v1.16.0 [INFO] [stderr] Checking quote v1.0.40 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.7.5 [INFO] [stderr] Checking syn v2.0.100 [INFO] [stderr] Checking thiserror v1.0.69 [INFO] [stderr] Checking zerofrom v0.1.6 [INFO] [stderr] Checking yoke v0.7.5 [INFO] [stderr] Checking zerovec v0.10.4 [INFO] [stderr] Checking serde v1.0.219 [INFO] [stderr] Checking tinystr v0.7.6 [INFO] [stderr] Checking icu_collections v1.5.0 [INFO] [stderr] Checking icu_locid v1.5.0 [INFO] [stderr] Checking icu_provider v1.5.0 [INFO] [stderr] Checking rustvalidity-derive v0.1.0 (/opt/rustwide/workdir/rustvalidity-derive) [INFO] [stdout] error[E0432]: unresolved import `syn::NestedMeta` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:3:68 [INFO] [stdout] | [INFO] [stdout] 3 | use syn::{parse_macro_input, DeriveInput, Data, Fields, Lit, Meta, NestedMeta, MetaNameValue}; [INFO] [stdout] | ^^^^^^^^^^ no `NestedMeta` in the root [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0432]: unresolved import `syn::NestedMeta` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:3:68 [INFO] [stdout] | [INFO] [stdout] 3 | use syn::{parse_macro_input, DeriveInput, Data, Fields, Lit, Meta, NestedMeta, MetaNameValue}; [INFO] [stdout] | ^^^^^^^^^^ no `NestedMeta` in the root [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `MetaNameValue` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:3:80 [INFO] [stdout] | [INFO] [stdout] 3 | use syn::{parse_macro_input, DeriveInput, Data, Fields, Lit, Meta, NestedMeta, MetaNameValue}; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `MetaNameValue` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:3:80 [INFO] [stdout] | [INFO] [stdout] 3 | use syn::{parse_macro_input, DeriveInput, Data, Fields, Lit, Meta, NestedMeta, MetaNameValue}; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0615]: attempted to take value of method `path` on type `&&Attribute` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:47:33 [INFO] [stdout] | [INFO] [stdout] 47 | .filter(|attr| attr.path.is_ident("validate")) [INFO] [stdout] | ^^^^ method, not a field [INFO] [stdout] | [INFO] [stdout] help: use parentheses to call the method [INFO] [stdout] | [INFO] [stdout] 47 | .filter(|attr| attr.path().is_ident("validate")) [INFO] [stdout] | ++ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking icu_locid_transform v1.5.0 [INFO] [stdout] error[E0599]: no method named `parse_meta` found for reference `&Attribute` in the current scope [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:49:28 [INFO] [stdout] | [INFO] [stdout] 49 | match attr.parse_meta() { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] help: there is a method `parse_nested_meta` with a similar name, but with different arguments [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/syn-2.0.100/src/attr.rs:391:5 [INFO] [stdout] | [INFO] [stdout] 391 | / pub fn parse_nested_meta( [INFO] [stdout] 392 | | &self, [INFO] [stdout] 393 | | logic: impl FnMut(ParseNestedMeta) -> Result<()>, [INFO] [stdout] 394 | | ) -> Result<()> { [INFO] [stdout] | |___________________^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `nested` on type `MetaList` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:50:60 [INFO] [stdout] | [INFO] [stdout] 50 | Ok(Meta::List(meta_list)) => meta_list.nested, [INFO] [stdout] | ^^^^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `delimiter`, `tokens` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0615]: attempted to take value of method `path` on type `&&Attribute` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:47:33 [INFO] [stdout] | [INFO] [stdout] 47 | .filter(|attr| attr.path.is_ident("validate")) [INFO] [stdout] | ^^^^ method, not a field [INFO] [stdout] | [INFO] [stdout] help: use parentheses to call the method [INFO] [stdout] | [INFO] [stdout] 47 | .filter(|attr| attr.path().is_ident("validate")) [INFO] [stdout] | ++ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0599]: no method named `parse_meta` found for reference `&Attribute` in the current scope [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:49:28 [INFO] [stdout] | [INFO] [stdout] 49 | match attr.parse_meta() { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] help: there is a method `parse_nested_meta` with a similar name, but with different arguments [INFO] [stdout] --> /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/syn-2.0.100/src/attr.rs:391:5 [INFO] [stdout] | [INFO] [stdout] 391 | / pub fn parse_nested_meta( [INFO] [stdout] 392 | | &self, [INFO] [stdout] 393 | | logic: impl FnMut(ParseNestedMeta) -> Result<()>, [INFO] [stdout] 394 | | ) -> Result<()> { [INFO] [stdout] | |___________________^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `nested` on type `MetaList` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:50:60 [INFO] [stdout] | [INFO] [stdout] 50 | Ok(Meta::List(meta_list)) => meta_list.nested, [INFO] [stdout] | ^^^^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `delimiter`, `tokens` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `nested` on type `MetaList` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:125:53 [INFO] [stdout] | [INFO] [stdout] 125 | ... for nested in meta_list.nested.iter() { [INFO] [stdout] | ^^^^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `delimiter`, `tokens` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `lit` on type `MetaNameValue` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:128:76 [INFO] [stdout] | [INFO] [stdout] 128 | ... if let Lit::Int(lit_int) = &name_value.lit { [INFO] [stdout] | ^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `eq_token`, `value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `nested` on type `MetaList` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:151:53 [INFO] [stdout] | [INFO] [stdout] 151 | ... for nested in meta_list.nested.iter() { [INFO] [stdout] | ^^^^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `delimiter`, `tokens` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: could not compile `rustvalidity-derive` (lib test) due to 13 previous errors; 1 warning emitted [INFO] [stdout] error[E0609]: no field `nested` on type `MetaList` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:169:53 [INFO] [stdout] | [INFO] [stdout] 169 | ... for nested in meta_list.nested.iter() { [INFO] [stdout] | ^^^^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `delimiter`, `tokens` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stdout] error[E0609]: no field `nested` on type `MetaList` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:125:53 [INFO] [stdout] | [INFO] [stdout] 125 | ... for nested in meta_list.nested.iter() { [INFO] [stdout] | ^^^^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `delimiter`, `tokens` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: could not compile `rustvalidity-derive` (lib) due to 13 previous errors; 1 warning emitted [INFO] [stdout] error[E0609]: no field `lit` on type `MetaNameValue` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:128:76 [INFO] [stdout] | [INFO] [stdout] 128 | ... if let Lit::Int(lit_int) = &name_value.lit { [INFO] [stdout] | ^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `eq_token`, `value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `nested` on type `MetaList` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:188:53 [INFO] [stdout] | [INFO] [stdout] 188 | ... for nested in meta_list.nested.iter() { [INFO] [stdout] | ^^^^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `delimiter`, `tokens` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `lit` on type `MetaNameValue` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:191:76 [INFO] [stdout] | [INFO] [stdout] 191 | ... if let Lit::Int(lit_int) = &name_value.lit { [INFO] [stdout] | ^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `eq_token`, `value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `nested` on type `MetaList` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:151:53 [INFO] [stdout] | [INFO] [stdout] 151 | ... for nested in meta_list.nested.iter() { [INFO] [stdout] | ^^^^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `delimiter`, `tokens` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `lit` on type `MetaNameValue` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:219:68 [INFO] [stdout] | [INFO] [stdout] 219 | ... if let Lit::Int(lit_int) = &name_value.lit { [INFO] [stdout] | ^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `eq_token`, `value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `nested` on type `MetaList` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:169:53 [INFO] [stdout] | [INFO] [stdout] 169 | ... for nested in meta_list.nested.iter() { [INFO] [stdout] | ^^^^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `delimiter`, `tokens` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `lit` on type `MetaNameValue` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:234:68 [INFO] [stdout] | [INFO] [stdout] 234 | ... if let Lit::Int(lit_int) = &name_value.lit { [INFO] [stdout] | ^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `eq_token`, `value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `nested` on type `MetaList` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:188:53 [INFO] [stdout] | [INFO] [stdout] 188 | ... for nested in meta_list.nested.iter() { [INFO] [stdout] | ^^^^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `delimiter`, `tokens` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `lit` on type `MetaNameValue` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:191:76 [INFO] [stdout] | [INFO] [stdout] 191 | ... if let Lit::Int(lit_int) = &name_value.lit { [INFO] [stdout] | ^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `eq_token`, `value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `lit` on type `MetaNameValue` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:219:68 [INFO] [stdout] | [INFO] [stdout] 219 | ... if let Lit::Int(lit_int) = &name_value.lit { [INFO] [stdout] | ^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `eq_token`, `value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0282]: type annotations needed [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:255:9 [INFO] [stdout] | [INFO] [stdout] 255 | / quote! { [INFO] [stdout] 256 | | #(#validation_code)* [INFO] [stdout] 257 | | } [INFO] [stdout] | |_________^ cannot infer type [INFO] [stdout] | [INFO] [stdout] = note: this error originates in the macro `$crate::quote_bind_next_or_break` which comes from the expansion of the macro `quote` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0609]: no field `lit` on type `MetaNameValue` [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:234:68 [INFO] [stdout] | [INFO] [stdout] 234 | ... if let Lit::Int(lit_int) = &name_value.lit { [INFO] [stdout] | ^^^ unknown field [INFO] [stdout] | [INFO] [stdout] = note: available fields are: `path`, `eq_token`, `value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0282]: type annotations needed [INFO] [stdout] --> rustvalidity-derive/src/lib.rs:255:9 [INFO] [stdout] | [INFO] [stdout] 255 | / quote! { [INFO] [stdout] 256 | | #(#validation_code)* [INFO] [stdout] 257 | | } [INFO] [stdout] | |_________^ cannot infer type [INFO] [stdout] | [INFO] [stdout] = note: this error originates in the macro `$crate::quote_bind_next_or_break` which comes from the expansion of the macro `quote` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] Some errors have detailed explanations: E0282, E0432, E0599, E0609, E0615. [INFO] [stdout] [INFO] [stdout] For more information about an error, try `rustc --explain E0282`. [INFO] [stdout] [INFO] [stdout] Some errors have detailed explanations: E0282, E0432, E0599, E0609, E0615. [INFO] [stdout] [INFO] [stdout] For more information about an error, try `rustc --explain E0282`. [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "296e461f2b7c2d9567554e67ae5c38c7ec60900a4fe01496e74edd81b993ca5c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "296e461f2b7c2d9567554e67ae5c38c7ec60900a4fe01496e74edd81b993ca5c", kill_on_drop: false }` [INFO] [stdout] 296e461f2b7c2d9567554e67ae5c38c7ec60900a4fe01496e74edd81b993ca5c