[INFO] fetching crate rust-sitter-macro 0.4.5... [INFO] testing rust-sitter-macro-0.4.5 against try#c2e32f1c9652b13ed99608599c1e855462f421f3 for pr-146098-8 [INFO] extracting crate rust-sitter-macro 0.4.5 into /workspace/builds/worker-7-tc2/source [INFO] started tweaking crates.io crate rust-sitter-macro 0.4.5 [INFO] finished tweaking crates.io crate rust-sitter-macro 0.4.5 [INFO] tweaked toml for crates.io crate rust-sitter-macro 0.4.5 written to /workspace/builds/worker-7-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate rust-sitter-macro 0.4.5 on toolchain c2e32f1c9652b13ed99608599c1e855462f421f3 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate crates.io crate rust-sitter-macro 0.4.5 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" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 05bb84c6922afda39e77de8d5b070f2672fe8015da22c89f048a8108f9a82193 [INFO] running `Command { std: "docker" "start" "-a" "05bb84c6922afda39e77de8d5b070f2672fe8015da22c89f048a8108f9a82193", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "05bb84c6922afda39e77de8d5b070f2672fe8015da22c89f048a8108f9a82193", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "05bb84c6922afda39e77de8d5b070f2672fe8015da22c89f048a8108f9a82193", kill_on_drop: false }` [INFO] [stdout] 05bb84c6922afda39e77de8d5b070f2672fe8015da22c89f048a8108f9a82193 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] ddeabd47bbb92eeb48d1b8b80c0b87d5a3385ec7e68a575a502acb609109417b [INFO] running `Command { std: "docker" "start" "-a" "ddeabd47bbb92eeb48d1b8b80c0b87d5a3385ec7e68a575a502acb609109417b", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.93 [INFO] [stderr] Compiling unicode-ident v1.0.17 [INFO] [stderr] Compiling quote v1.0.38 [INFO] [stderr] Compiling syn v2.0.98 [INFO] [stderr] Compiling rust-sitter-common v0.4.5 [INFO] [stderr] Compiling rust-sitter-macro v0.4.5 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 6.65s [INFO] running `Command { std: "docker" "inspect" "ddeabd47bbb92eeb48d1b8b80c0b87d5a3385ec7e68a575a502acb609109417b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ddeabd47bbb92eeb48d1b8b80c0b87d5a3385ec7e68a575a502acb609109417b", kill_on_drop: false }` [INFO] [stdout] ddeabd47bbb92eeb48d1b8b80c0b87d5a3385ec7e68a575a502acb609109417b [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 6ef5e4c53b160e9ea55811101b5071c4b0af919991c18ba6ff6ea4d5ef281237 [INFO] running `Command { std: "docker" "start" "-a" "6ef5e4c53b160e9ea55811101b5071c4b0af919991c18ba6ff6ea4d5ef281237", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.169 [INFO] [stderr] Compiling once_cell v1.20.3 [INFO] [stderr] Compiling getrandom v0.3.1 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling bitflags v2.8.0 [INFO] [stderr] Compiling similar v2.7.0 [INFO] [stderr] Compiling linked-hash-map v0.5.6 [INFO] [stderr] Compiling fastrand v2.3.0 [INFO] [stderr] Compiling syn v2.0.98 [INFO] [stderr] Compiling console v0.15.10 [INFO] [stderr] Compiling tempfile v3.17.1 [INFO] [stderr] Compiling rust-sitter-common v0.4.5 [INFO] [stderr] Compiling pin-project-internal v1.1.9 [INFO] [stderr] Compiling rust-sitter-macro v0.4.5 (/opt/rustwide/workdir) [INFO] [stderr] Compiling pin-project v1.1.9 [INFO] [stderr] Compiling insta v1.42.1 [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 9.75s [INFO] running `Command { std: "docker" "inspect" "6ef5e4c53b160e9ea55811101b5071c4b0af919991c18ba6ff6ea4d5ef281237", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6ef5e4c53b160e9ea55811101b5071c4b0af919991c18ba6ff6ea4d5ef281237", kill_on_drop: false }` [INFO] [stdout] 6ef5e4c53b160e9ea55811101b5071c4b0af919991c18ba6ff6ea4d5ef281237 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 56cf935f79444dcd6a31a5a8a15c9e9e17a0bdda6fe738911f41834feb5c109a [INFO] running `Command { std: "docker" "start" "-a" "56cf935f79444dcd6a31a5a8a15c9e9e17a0bdda6fe738911f41834feb5c109a", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.08s [INFO] [stdout] [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/rust_sitter_macro-f994f512f19f167e) [INFO] [stdout] running 10 tests [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'c2e32f1c9652b13ed99608599c1e855462f421f3'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'c2e32f1c9652b13ed99608599c1e855462f421f3'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'c2e32f1c9652b13ed99608599c1e855462f421f3'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'c2e32f1c9652b13ed99608599c1e855462f421f3'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'c2e32f1c9652b13ed99608599c1e855462f421f3'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'c2e32f1c9652b13ed99608599c1e855462f421f3'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'c2e32f1c9652b13ed99608599c1e855462f421f3'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'c2e32f1c9652b13ed99608599c1e855462f421f3'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'c2e32f1c9652b13ed99608599c1e855462f421f3'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'c2e32f1c9652b13ed99608599c1e855462f421f3'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stdout] test tests::struct_optional ... FAILED [INFO] [stdout] test tests::enum_recursive ... FAILED [INFO] [stdout] test tests::enum_with_unamed_vector ... FAILED [INFO] [stdout] test tests::enum_transformed_fields ... FAILED [INFO] [stdout] test tests::enum_prec_left ... FAILED [INFO] [stdout] test tests::grammar_unboxed_field ... FAILED [INFO] [stdout] test tests::enum_with_named_field ... FAILED [INFO] [stdout] test tests::spanned_in_vec ... FAILED [INFO] [stdout] test tests::struct_repeat ... FAILED [INFO] [stdout] test tests::struct_extra ... FAILED [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- tests::struct_optional stdout ---- [INFO] [stdout] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Snapshot Summary ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ [INFO] [stdout] Snapshot file: src/snapshots/rust_sitter_macro__tests__struct_optional.snap [INFO] [stdout] Snapshot: struct_optional [INFO] [stdout] Source: src/lib.rs:424 [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] Expression: rustfmt_code(&expand_grammar(parse_quote! [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::grammar("test")] mod grammar [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::language] pub struct Language [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::leaf(pattern = r"\d+", transform = |v| [INFO] [stdout] v.parse().unwrap())] v: Option, t: Option, [INFO] [stdout] } pub struct Number [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::leaf(pattern = r"\d+", transform = |v| [INFO] [stdout] v.parse().unwrap())] v: i32 [INFO] [stdout] } [INFO] [stdout] } [INFO] [stdout] })? .to_token_stream().to_string()) [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] -old snapshot [INFO] [stdout] +new results [INFO] [stdout] ────────────┬─────────────────────────────────────────────────────────────────── [INFO] [stdout] 0 │-mod grammar { [INFO] [stdout] 1 │- pub struct Language { [INFO] [stdout] 2 │- v: Option, [INFO] [stdout] 3 │- t: Option, [INFO] [stdout] 4 │- } [INFO] [stdout] 5 │- impl ::rust_sitter::Extract for Language { [INFO] [stdout] 6 │- type LeafFn = (); [INFO] [stdout] 7 │- #[allow(non_snake_case)] [INFO] [stdout] 8 │- fn extract( [INFO] [stdout] 9 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 10 │- source: &[u8], [INFO] [stdout] 11 │- last_idx: usize, [INFO] [stdout] 12 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 13 │- ) -> Self { [INFO] [stdout] 14 │- let node = node.unwrap(); [INFO] [stdout] 15 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 16 │- Language { [INFO] [stdout] 17 │- v: { [INFO] [stdout] 18 │- ::rust_sitter::__private::extract_field::< [INFO] [stdout] 19 │- Option>, [INFO] [stdout] 20 │- _, [INFO] [stdout] 21 │- >( [INFO] [stdout] 22 │- cursor, source, last_idx, "v", Some(&|v| v.parse().unwrap()) [INFO] [stdout] 23 │- ) [INFO] [stdout] 24 │- }, [INFO] [stdout] 25 │- t: { [INFO] [stdout] 26 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 27 │- cursor, source, last_idx, "t", None, [INFO] [stdout] 28 │- ) [INFO] [stdout] 29 │- }, [INFO] [stdout] 30 │- } [INFO] [stdout] 31 │- }) [INFO] [stdout] 32 │- } [INFO] [stdout] 33 │- } [INFO] [stdout] 34 │- pub struct Number { [INFO] [stdout] 35 │- v: i32, [INFO] [stdout] 36 │- } [INFO] [stdout] 37 │- impl ::rust_sitter::Extract for Number { [INFO] [stdout] 38 │- type LeafFn = (); [INFO] [stdout] 39 │- #[allow(non_snake_case)] [INFO] [stdout] 40 │- fn extract( [INFO] [stdout] 41 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 42 │- source: &[u8], [INFO] [stdout] 43 │- last_idx: usize, [INFO] [stdout] 44 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 45 │- ) -> Self { [INFO] [stdout] 46 │- let node = node.unwrap(); [INFO] [stdout] 47 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 48 │- Number { [INFO] [stdout] 49 │- v: { [INFO] [stdout] 50 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 51 │- cursor, [INFO] [stdout] 52 │- source, [INFO] [stdout] 53 │- last_idx, [INFO] [stdout] 54 │- "v", [INFO] [stdout] 55 │- Some(&|v| v.parse().unwrap()), [INFO] [stdout] 56 │- ) [INFO] [stdout] 57 │- }, [INFO] [stdout] 58 │- } [INFO] [stdout] 59 │- }) [INFO] [stdout] 60 │- } [INFO] [stdout] 61 │- } [INFO] [stdout] 62 │- extern "C" { [INFO] [stdout] 63 │- fn tree_sitter_test() -> ::rust_sitter::tree_sitter::Language; [INFO] [stdout] 64 │- } [INFO] [stdout] 65 │- pub fn language() -> ::rust_sitter::tree_sitter::Language { [INFO] [stdout] 66 │- unsafe { tree_sitter_test() } [INFO] [stdout] 67 │- } [INFO] [stdout] 68 │- #[doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] [INFO] [stdout] 69 │- #[doc = "[`Language`]"] [INFO] [stdout] 70 │- #[doc = r" instance containing the parsed structured data."] [INFO] [stdout] 71 │- pub fn parse( [INFO] [stdout] 72 │- input: &str, [INFO] [stdout] 73 │- ) -> core::result::Result> { [INFO] [stdout] 74 │- ::rust_sitter::__private::parse::(input, language) [INFO] [stdout] 75 │- } [INFO] [stdout] 76 │-} [INFO] [stdout] 0 │+mod grammar { pub struct Language { v : Option < i32 > , t : Option < Number > , } impl :: rust_sitter :: Extract < Language > for Language { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Language { v : { :: rust_sitter :: __private :: extract_field :: < Option < rust_sitter :: WithLeaf < i32 > > , _ > (cursor , source , last_idx , "v" , Some (& | v | v . parse () . unwrap ())) } , t : { :: rust_sitter :: __private :: extract_field :: < Option < Number > , _ > (cursor , source , last_idx , "t" , None) } }) } } pub struct Number { v : i32 } impl :: rust_sitter :: Extract < Number > for Number { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Number { v : { :: rust_sitter :: __private :: extract_field :: < rust_sitter :: WithLeaf < i32 > , _ > (cursor , source , last_idx , "v" , Some (& | v | v . parse () . unwrap ())) } }) } } extern "C" { fn tree_sitter_test () -> :: rust_sitter :: tree_sitter :: Language ; } pub fn language () -> :: rust_sitter :: tree_sitter :: Language { unsafe { tree_sitter_test () } } # [doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] # [doc = "[`Language`]"] # [doc = r" instance containing the parsed structured data."] pub fn parse (input : & str) -> core :: result :: Result < Language , Vec < :: rust_sitter :: errors :: ParseError > > { :: rust_sitter :: __private :: parse :: < Language > (input , language) } } [INFO] [stdout] ────────────┴─────────────────────────────────────────────────────────────────── [INFO] [stdout] [INFO] [stdout] thread 'tests::struct_optional' (32) panicked at src/lib.rs:424:9: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileIo(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }, "/opt/rustwide/workdir/src/snapshots/rust_sitter_macro__tests__struct_optional.snap.new") [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::libunwind::trace::h9ea1e07ac77a25d7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h72b75eb83b53d15a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x713ee9e7b1c2 - std::sys::backtrace::_print_fmt::h255777b7ec902439 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x713ee9e7b1c2 - ::fmt::h8a1ac49fcd7ee8ce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x713ee9eab40f - core::fmt::rt::Argument::fmt::h635cbf3c6754cc90 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x713ee9eab40f - core::fmt::write::hbdcc0ec4f1bab1db [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x713ee9e2c943 - std::io::default_write_fmt::h2580ece0d4b58e51 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x713ee9e2c943 - std::io::Write::write_fmt::hac9e42858f273b87 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x713ee9e41e92 - std::sys::backtrace::BacktraceLock::print::h052febbd86f7bf07 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x713ee9e4a2ba - std::panicking::default_hook::{{closure}}::h66aeee20dd470abb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x713ee9e4a14c - std::panicking::default_hook::h9d66b9642014ce48 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6289ebb7161e - as core::ops::function::Fn>::call::h8c698701e444e564 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 12: 0x6289ebb7161e - test::test_main_with_exit_callback::{{closure}}::ha1c98e7b69c4defb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x713ee9e4a96f - as core::ops::function::Fn>::call::hc4f222a8a57c637a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 14: 0x713ee9e4a96f - std::panicking::panic_with_hook::h6d5921a1a1fa5a8e [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x713ee9e4a71a - std::panicking::panic_handler::{{closure}}::hafeef6f707d43542 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x713ee9e41fc9 - std::sys::backtrace::__rust_end_short_backtrace::h08cbc3319a3d0120 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x713ee9e1e4ad - __rustc[ce5c411ff86ab1b2]::rust_begin_unwind [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x713ee9ebb410 - core::panicking::panic_fmt::h774fb860369a0f7b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x713ee9eb9d56 - core::result::unwrap_failed::h72ee8fcbf1bf8ff9 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x6289eba366a1 - core::result::Result::unwrap::h85aa971974d63926 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x6289eba366a1 - rust_sitter_macro::tests::struct_optional::h160b333af82eb0cb [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:424:9 [INFO] [stdout] 22: 0x6289eba367fd - rust_sitter_macro::tests::struct_optional::{{closure}}::h4d7edf2b51aaaf6f [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:423:29 [INFO] [stdout] 23: 0x6289eba461a6 - core::ops::function::FnOnce::call_once::hb272b3004e60af98 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6289ebb7146b - core::ops::function::FnOnce::call_once::h4f6eabe90cccb47d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x6289ebb7146b - test::__rust_begin_short_backtrace::h94208530f2b4c8c7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x6289ebb8547d - test::run_test_in_process::{{closure}}::hbdc6a45a78c46404 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x6289ebb8547d - as core::ops::function::FnOnce<()>>::call_once::h7f9d8efc7eedd165 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x6289ebb8547d - std::panicking::catch_unwind::do_call::he5edbaf126c13b99 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x6289ebb8547d - std::panicking::catch_unwind::h3d6a8652eceeabce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x6289ebb8547d - std::panic::catch_unwind::hbef0c501dd7bb498 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x6289ebb8547d - test::run_test_in_process::h400008a46a5006a0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x6289ebb8547d - test::run_test::{{closure}}::h9a131655b31d9427 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x6289ebb5e9c4 - test::run_test::{{closure}}::he4a7177c216308c0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x6289ebb5e9c4 - std::sys::backtrace::__rust_begin_short_backtrace::hd3980e9c55d6c539 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h18552df67c7aa9b8 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 36: 0x6289ebb622fa - as core::ops::function::FnOnce<()>>::call_once::h3d7b285234641a08 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x6289ebb622fa - std::panicking::catch_unwind::do_call::h5a2b5cf36528a5b2 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x6289ebb622fa - std::panicking::catch_unwind::h7e8b531bbda77d20 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x6289ebb622fa - std::panic::catch_unwind::hf9bbb2040b4f1e6c [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::h600f92cf68549574 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 41: 0x6289ebb622fa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb6607307df8a1847 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x713ee9e3c8ef - as core::ops::function::FnOnce>::call_once::h6891ad53a5ed6f52 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2085:9 [INFO] [stdout] 43: 0x713ee9e3c8ef - std::sys::thread::unix::Thread::new::thread_start::h7f3e77fa86df70af [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/thread/unix.rs:124:17 [INFO] [stdout] 44: 0x713ee9bd6aa4 - [INFO] [stdout] 45: 0x713ee9c63a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- tests::enum_recursive stdout ---- [INFO] [stdout] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Snapshot Summary ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ [INFO] [stdout] Snapshot file: src/snapshots/rust_sitter_macro__tests__enum_recursive.snap [INFO] [stdout] Snapshot: enum_recursive [INFO] [stdout] Source: src/lib.rs:285 [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] Expression: rustfmt_code(&expand_grammar(parse_quote! [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::grammar("test")] mod grammar [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::language] pub enum Expression [INFO] [stdout] { [INFO] [stdout] Number(#[rust_sitter::leaf(pattern = r"\d+", transform = |v| [INFO] [stdout] v.parse().unwrap())] i32), [INFO] [stdout] Neg(#[rust_sitter::leaf(text = "-")] (), Box), [INFO] [stdout] } [INFO] [stdout] } [INFO] [stdout] })? .to_token_stream().to_string()) [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] -old snapshot [INFO] [stdout] +new results [INFO] [stdout] ────────────┬─────────────────────────────────────────────────────────────────── [INFO] [stdout] 0 │-mod grammar { [INFO] [stdout] 1 │- pub enum Expression { [INFO] [stdout] 2 │- Number(i32), [INFO] [stdout] 3 │- Neg((), Box), [INFO] [stdout] 4 │- } [INFO] [stdout] 5 │- impl ::rust_sitter::Extract for Expression { [INFO] [stdout] 6 │- type LeafFn = (); [INFO] [stdout] 7 │- #[allow(non_snake_case)] [INFO] [stdout] 8 │- fn extract( [INFO] [stdout] 9 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 10 │- source: &[u8], [INFO] [stdout] 11 │- _last_idx: usize, [INFO] [stdout] 12 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 13 │- ) -> Self { [INFO] [stdout] 14 │- let node = node.unwrap(); [INFO] [stdout] 15 │- let mut cursor = node.walk(); [INFO] [stdout] 16 │- assert!( [INFO] [stdout] 17 │- cursor.goto_first_child(), [INFO] [stdout] 18 │- "Could not find a child corresponding to any enum branch" [INFO] [stdout] 19 │- ); [INFO] [stdout] 20 │- loop { [INFO] [stdout] 21 │- let node = cursor.node(); [INFO] [stdout] 22 │- match node.kind() { [INFO] [stdout] 23 │- "Expression_Number" => { [INFO] [stdout] 24 │- return ::rust_sitter::__private::extract_struct_or_variant( [INFO] [stdout] 25 │- node, [INFO] [stdout] 26 │- move |cursor, last_idx| { [INFO] [stdout] 27 │- Expression::Number({ [INFO] [stdout] 28 │- ::rust_sitter::__private::extract_field::< [INFO] [stdout] 29 │- rust_sitter::WithLeaf, [INFO] [stdout] 30 │- _, [INFO] [stdout] 31 │- >( [INFO] [stdout] 32 │- cursor, source, last_idx, "0", Some(&|v| v.parse().unwrap()) [INFO] [stdout] 33 │- ) [INFO] [stdout] 34 │- }) [INFO] [stdout] 35 │- }, [INFO] [stdout] 36 │- ) [INFO] [stdout] 37 │- } [INFO] [stdout] 38 │- "Expression_Neg" => { [INFO] [stdout] 39 │- return ::rust_sitter::__private::extract_struct_or_variant( [INFO] [stdout] 40 │- node, [INFO] [stdout] 41 │- move |cursor, last_idx| { [INFO] [stdout] 42 │- Expression::Neg( [INFO] [stdout] 43 │- { [INFO] [stdout] 44 │- ::rust_sitter::__private::extract_field::<(), _>( [INFO] [stdout] 45 │- cursor, source, last_idx, "0", None, [INFO] [stdout] 46 │- ) [INFO] [stdout] 47 │- }, [INFO] [stdout] 48 │- { [INFO] [stdout] 49 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 50 │- cursor, source, last_idx, "1", None, [INFO] [stdout] 51 │- ) [INFO] [stdout] 52 │- }, [INFO] [stdout] 53 │- ) [INFO] [stdout] 54 │- }, [INFO] [stdout] 55 │- ) [INFO] [stdout] 56 │- } [INFO] [stdout] 57 │- _ => { [INFO] [stdout] 58 │- if !cursor.goto_next_sibling() { [INFO] [stdout] 59 │- panic!("Could not find a child corresponding to any enum branch") [INFO] [stdout] 60 │- } [INFO] [stdout] 61 │- } [INFO] [stdout] 62 │- } [INFO] [stdout] 63 │- } [INFO] [stdout] 64 │- } [INFO] [stdout] 65 │- } [INFO] [stdout] 66 │- extern "C" { [INFO] [stdout] 67 │- fn tree_sitter_test() -> ::rust_sitter::tree_sitter::Language; [INFO] [stdout] 68 │- } [INFO] [stdout] 69 │- pub fn language() -> ::rust_sitter::tree_sitter::Language { [INFO] [stdout] 70 │- unsafe { tree_sitter_test() } [INFO] [stdout] 71 │- } [INFO] [stdout] 72 │- #[doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] [INFO] [stdout] 73 │- #[doc = "[`Expression`]"] [INFO] [stdout] 74 │- #[doc = r" instance containing the parsed structured data."] [INFO] [stdout] 75 │- pub fn parse( [INFO] [stdout] 76 │- input: &str, [INFO] [stdout] 77 │- ) -> core::result::Result> { [INFO] [stdout] 78 │- ::rust_sitter::__private::parse::(input, language) [INFO] [stdout] 79 │- } [INFO] [stdout] 80 │-} [INFO] [stdout] 0 │+mod grammar { pub enum Expression { Number (i32) , Neg (() , Box < Expression >) , } impl :: rust_sitter :: Extract < Expression > for Expression { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , _last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; let mut cursor = node . walk () ; assert ! (cursor . goto_first_child () , "Could not find a child corresponding to any enum branch") ; loop { let node = cursor . node () ; match node . kind () { "Expression_Number" => return :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Expression :: Number ({ :: rust_sitter :: __private :: extract_field :: < rust_sitter :: WithLeaf < i32 > , _ > (cursor , source , last_idx , "0" , Some (& | v | v . parse () . unwrap ())) })) , "Expression_Neg" => return :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Expression :: Neg ({ :: rust_sitter :: __private :: extract_field :: < () , _ > (cursor , source , last_idx , "0" , None) } , { :: rust_sitter :: __private :: extract_field :: < Box < Expression > , _ > (cursor , source , last_idx , "1" , None) })) , _ => if ! cursor . goto_next_sibling () { panic ! ("Could not find a child corresponding to any enum branch") } } } } } extern "C" { fn tree_sitter_test () -> :: rust_sitter :: tree_sitter :: Language ; } pub fn language () -> :: rust_sitter :: tree_sitter :: Language { unsafe { tree_sitter_test () } } # [doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] # [doc = "[`Expression`]"] # [doc = r" instance containing the parsed structured data."] pub fn parse (input : & str) -> core :: result :: Result < Expression , Vec < :: rust_sitter :: errors :: ParseError > > { :: rust_sitter :: __private :: parse :: < Expression > (input , language) } } [INFO] [stdout] ────────────┴─────────────────────────────────────────────────────────────────── [INFO] [stdout] [INFO] [stdout] thread 'tests::enum_recursive' (25) panicked at src/lib.rs:285:9: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileIo(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }, "/opt/rustwide/workdir/src/snapshots/rust_sitter_macro__tests__enum_recursive.snap.new") [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::libunwind::trace::h9ea1e07ac77a25d7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h72b75eb83b53d15a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x713ee9e7b1c2 - std::sys::backtrace::_print_fmt::h255777b7ec902439 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x713ee9e7b1c2 - ::fmt::h8a1ac49fcd7ee8ce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x713ee9eab40f - core::fmt::rt::Argument::fmt::h635cbf3c6754cc90 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x713ee9eab40f - core::fmt::write::hbdcc0ec4f1bab1db [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x713ee9e2c943 - std::io::default_write_fmt::h2580ece0d4b58e51 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x713ee9e2c943 - std::io::Write::write_fmt::hac9e42858f273b87 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x713ee9e41e92 - std::sys::backtrace::BacktraceLock::print::h052febbd86f7bf07 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x713ee9e4a2ba - std::panicking::default_hook::{{closure}}::h66aeee20dd470abb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x713ee9e4a14c - std::panicking::default_hook::h9d66b9642014ce48 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6289ebb7161e - as core::ops::function::Fn>::call::h8c698701e444e564 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 12: 0x6289ebb7161e - test::test_main_with_exit_callback::{{closure}}::ha1c98e7b69c4defb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x713ee9e4a96f - as core::ops::function::Fn>::call::hc4f222a8a57c637a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 14: 0x713ee9e4a96f - std::panicking::panic_with_hook::h6d5921a1a1fa5a8e [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x713ee9e4a71a - std::panicking::panic_handler::{{closure}}::hafeef6f707d43542 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x713ee9e41fc9 - std::sys::backtrace::__rust_end_short_backtrace::h08cbc3319a3d0120 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x713ee9e1e4ad - __rustc[ce5c411ff86ab1b2]::rust_begin_unwind [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x713ee9ebb410 - core::panicking::panic_fmt::h774fb860369a0f7b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x713ee9eb9d56 - core::result::unwrap_failed::h72ee8fcbf1bf8ff9 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x6289eba33ad4 - core::result::Result::unwrap::h85aa971974d63926 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x6289eba33ad4 - rust_sitter_macro::tests::enum_recursive::hc79f00894f1f7200 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:285:9 [INFO] [stdout] 22: 0x6289eba33c2d - rust_sitter_macro::tests::enum_recursive::{{closure}}::h8ec57f7e3698559c [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:284:28 [INFO] [stdout] 23: 0x6289eba46256 - core::ops::function::FnOnce::call_once::hd79d3d39be40368b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6289ebb7146b - core::ops::function::FnOnce::call_once::h4f6eabe90cccb47d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x6289ebb7146b - test::__rust_begin_short_backtrace::h94208530f2b4c8c7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x6289ebb8547d - test::run_test_in_process::{{closure}}::hbdc6a45a78c46404 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x6289ebb8547d - as core::ops::function::FnOnce<()>>::call_once::h7f9d8efc7eedd165 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x6289ebb8547d - std::panicking::catch_unwind::do_call::he5edbaf126c13b99 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x6289ebb8547d - std::panicking::catch_unwind::h3d6a8652eceeabce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x6289ebb8547d - std::panic::catch_unwind::hbef0c501dd7bb498 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x6289ebb8547d - test::run_test_in_process::h400008a46a5006a0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x6289ebb8547d - test::run_test::{{closure}}::h9a131655b31d9427 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x6289ebb5e9c4 - test::run_test::{{closure}}::he4a7177c216308c0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x6289ebb5e9c4 - std::sys::backtrace::__rust_begin_short_backtrace::hd3980e9c55d6c539 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h18552df67c7aa9b8 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 36: 0x6289ebb622fa - as core::ops::function::FnOnce<()>>::call_once::h3d7b285234641a08 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x6289ebb622fa - std::panicking::catch_unwind::do_call::h5a2b5cf36528a5b2 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x6289ebb622fa - std::panicking::catch_unwind::h7e8b531bbda77d20 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x6289ebb622fa - std::panic::catch_unwind::hf9bbb2040b4f1e6c [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::h600f92cf68549574 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 41: 0x6289ebb622fa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb6607307df8a1847 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x713ee9e3c8ef - as core::ops::function::FnOnce>::call_once::h6891ad53a5ed6f52 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2085:9 [INFO] [stdout] 43: 0x713ee9e3c8ef - std::sys::thread::unix::Thread::new::thread_start::h7f3e77fa86df70af [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/thread/unix.rs:124:17 [INFO] [stdout] 44: 0x713ee9bd6aa4 - [INFO] [stdout] 45: 0x713ee9c63a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- tests::enum_with_unamed_vector stdout ---- [INFO] [stdout] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Snapshot Summary ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ [INFO] [stdout] Snapshot file: src/snapshots/rust_sitter_macro__tests__enum_with_unamed_vector.snap [INFO] [stdout] Snapshot: enum_with_unamed_vector [INFO] [stdout] Source: src/lib.rs:450 [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] Expression: rustfmt_code(&expand_grammar(parse_quote! [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::grammar("test")] mod grammar [INFO] [stdout] { [INFO] [stdout] pub struct Number [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::leaf(pattern = r"\d+", transform = |v| [INFO] [stdout] v.parse().unwrap())] value: u32 [INFO] [stdout] } #[rust_sitter::language] pub enum Expr [INFO] [stdout] { Numbers(#[rust_sitter::repeat(non_empty = true)] Vec) } [INFO] [stdout] } [INFO] [stdout] })? .to_token_stream().to_string()) [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] -old snapshot [INFO] [stdout] +new results [INFO] [stdout] ────────────┬─────────────────────────────────────────────────────────────────── [INFO] [stdout] 0 │-mod grammar { [INFO] [stdout] 1 │- pub struct Number { [INFO] [stdout] 2 │- value: u32, [INFO] [stdout] 3 │- } [INFO] [stdout] 4 │- impl ::rust_sitter::Extract for Number { [INFO] [stdout] 5 │- type LeafFn = (); [INFO] [stdout] 6 │- #[allow(non_snake_case)] [INFO] [stdout] 7 │- fn extract( [INFO] [stdout] 8 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 9 │- source: &[u8], [INFO] [stdout] 10 │- last_idx: usize, [INFO] [stdout] 11 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 12 │- ) -> Self { [INFO] [stdout] 13 │- let node = node.unwrap(); [INFO] [stdout] 14 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 15 │- Number { [INFO] [stdout] 16 │- value: { [INFO] [stdout] 17 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 18 │- cursor, [INFO] [stdout] 19 │- source, [INFO] [stdout] 20 │- last_idx, [INFO] [stdout] 21 │- "value", [INFO] [stdout] 22 │- Some(&|v| v.parse().unwrap()), [INFO] [stdout] 23 │- ) [INFO] [stdout] 24 │- }, [INFO] [stdout] 25 │- } [INFO] [stdout] 26 │- }) [INFO] [stdout] 27 │- } [INFO] [stdout] 28 │- } [INFO] [stdout] 29 │- pub enum Expr { [INFO] [stdout] 30 │- Numbers(Vec), [INFO] [stdout] 31 │- } [INFO] [stdout] 32 │- impl ::rust_sitter::Extract for Expr { [INFO] [stdout] 33 │- type LeafFn = (); [INFO] [stdout] 34 │- #[allow(non_snake_case)] [INFO] [stdout] 35 │- fn extract( [INFO] [stdout] 36 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 37 │- source: &[u8], [INFO] [stdout] 38 │- _last_idx: usize, [INFO] [stdout] 39 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 40 │- ) -> Self { [INFO] [stdout] 41 │- let node = node.unwrap(); [INFO] [stdout] 42 │- let mut cursor = node.walk(); [INFO] [stdout] 43 │- assert!( [INFO] [stdout] 44 │- cursor.goto_first_child(), [INFO] [stdout] 45 │- "Could not find a child corresponding to any enum branch" [INFO] [stdout] 46 │- ); [INFO] [stdout] 47 │- loop { [INFO] [stdout] 48 │- let node = cursor.node(); [INFO] [stdout] 49 │- match node.kind() { [INFO] [stdout] 50 │- "Expr_Numbers" => { [INFO] [stdout] 51 │- return ::rust_sitter::__private::extract_struct_or_variant( [INFO] [stdout] 52 │- node, [INFO] [stdout] 53 │- move |cursor, last_idx| { [INFO] [stdout] 54 │- Expr::Numbers({ [INFO] [stdout] 55 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 56 │- cursor, source, last_idx, "0", None, [INFO] [stdout] 57 │- ) [INFO] [stdout] 58 │- }) [INFO] [stdout] 59 │- }, [INFO] [stdout] 60 │- ) [INFO] [stdout] 61 │- } [INFO] [stdout] 62 │- _ => { [INFO] [stdout] 63 │- if !cursor.goto_next_sibling() { [INFO] [stdout] 64 │- panic!("Could not find a child corresponding to any enum branch") [INFO] [stdout] 65 │- } [INFO] [stdout] 66 │- } [INFO] [stdout] 67 │- } [INFO] [stdout] 68 │- } [INFO] [stdout] 69 │- } [INFO] [stdout] 70 │- } [INFO] [stdout] 71 │- extern "C" { [INFO] [stdout] 72 │- fn tree_sitter_test() -> ::rust_sitter::tree_sitter::Language; [INFO] [stdout] 73 │- } [INFO] [stdout] 74 │- pub fn language() -> ::rust_sitter::tree_sitter::Language { [INFO] [stdout] 75 │- unsafe { tree_sitter_test() } [INFO] [stdout] 76 │- } [INFO] [stdout] 77 │- #[doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] [INFO] [stdout] 78 │- #[doc = "[`Expr`]"] [INFO] [stdout] 79 │- #[doc = r" instance containing the parsed structured data."] [INFO] [stdout] 80 │- pub fn parse( [INFO] [stdout] 81 │- input: &str, [INFO] [stdout] 82 │- ) -> core::result::Result> { [INFO] [stdout] 83 │- ::rust_sitter::__private::parse::(input, language) [INFO] [stdout] 84 │- } [INFO] [stdout] 85 │-} [INFO] [stdout] 0 │+mod grammar { pub struct Number { value : u32 } impl :: rust_sitter :: Extract < Number > for Number { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Number { value : { :: rust_sitter :: __private :: extract_field :: < rust_sitter :: WithLeaf < u32 > , _ > (cursor , source , last_idx , "value" , Some (& | v | v . parse () . unwrap ())) } }) } } pub enum Expr { Numbers (Vec < Number >) } impl :: rust_sitter :: Extract < Expr > for Expr { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , _last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; let mut cursor = node . walk () ; assert ! (cursor . goto_first_child () , "Could not find a child corresponding to any enum branch") ; loop { let node = cursor . node () ; match node . kind () { "Expr_Numbers" => return :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Expr :: Numbers ({ :: rust_sitter :: __private :: extract_field :: < Vec < Number > , _ > (cursor , source , last_idx , "0" , None) })) , _ => if ! cursor . goto_next_sibling () { panic ! ("Could not find a child corresponding to any enum branch") } } } } } extern "C" { fn tree_sitter_test () -> :: rust_sitter :: tree_sitter :: Language ; } pub fn language () -> :: rust_sitter :: tree_sitter :: Language { unsafe { tree_sitter_test () } } # [doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] # [doc = "[`Expr`]"] # [doc = r" instance containing the parsed structured data."] pub fn parse (input : & str) -> core :: result :: Result < Expr , Vec < :: rust_sitter :: errors :: ParseError > > { :: rust_sitter :: __private :: parse :: < Expr > (input , language) } } [INFO] [stdout] ────────────┴─────────────────────────────────────────────────────────────────── [INFO] [stdout] [INFO] [stdout] thread 'tests::enum_with_unamed_vector' (28) panicked at src/lib.rs:450:9: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileIo(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }, "/opt/rustwide/workdir/src/snapshots/rust_sitter_macro__tests__enum_with_unamed_vector.snap.new") [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::libunwind::trace::h9ea1e07ac77a25d7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h72b75eb83b53d15a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x713ee9e7b1c2 - std::sys::backtrace::_print_fmt::h255777b7ec902439 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x713ee9e7b1c2 - ::fmt::h8a1ac49fcd7ee8ce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x713ee9eab40f - core::fmt::rt::Argument::fmt::h635cbf3c6754cc90 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x713ee9eab40f - core::fmt::write::hbdcc0ec4f1bab1db [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x713ee9e2c943 - std::io::default_write_fmt::h2580ece0d4b58e51 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x713ee9e2c943 - std::io::Write::write_fmt::hac9e42858f273b87 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x713ee9e41e92 - std::sys::backtrace::BacktraceLock::print::h052febbd86f7bf07 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x713ee9e4a2ba - std::panicking::default_hook::{{closure}}::h66aeee20dd470abb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x713ee9e4a14c - std::panicking::default_hook::h9d66b9642014ce48 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6289ebb7161e - as core::ops::function::Fn>::call::h8c698701e444e564 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 12: 0x6289ebb7161e - test::test_main_with_exit_callback::{{closure}}::ha1c98e7b69c4defb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x713ee9e4a96f - as core::ops::function::Fn>::call::hc4f222a8a57c637a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 14: 0x713ee9e4a96f - std::panicking::panic_with_hook::h6d5921a1a1fa5a8e [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x713ee9e4a71a - std::panicking::panic_handler::{{closure}}::hafeef6f707d43542 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x713ee9e41fc9 - std::sys::backtrace::__rust_end_short_backtrace::h08cbc3319a3d0120 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x713ee9e1e4ad - __rustc[ce5c411ff86ab1b2]::rust_begin_unwind [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x713ee9ebb410 - core::panicking::panic_fmt::h774fb860369a0f7b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x713ee9eb9d56 - core::result::unwrap_failed::h72ee8fcbf1bf8ff9 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x6289eba3b241 - core::result::Result::unwrap::h85aa971974d63926 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x6289eba3b241 - rust_sitter_macro::tests::enum_with_unamed_vector::h192667e5b68de5e9 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:450:9 [INFO] [stdout] 22: 0x6289eba3b44d - rust_sitter_macro::tests::enum_with_unamed_vector::{{closure}}::h740663f302f6f4fd [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:449:37 [INFO] [stdout] 23: 0x6289eba46096 - core::ops::function::FnOnce::call_once::h7991326dc885f290 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6289ebb7146b - core::ops::function::FnOnce::call_once::h4f6eabe90cccb47d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x6289ebb7146b - test::__rust_begin_short_backtrace::h94208530f2b4c8c7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x6289ebb8547d - test::run_test_in_process::{{closure}}::hbdc6a45a78c46404 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x6289ebb8547d - as core::ops::function::FnOnce<()>>::call_once::h7f9d8efc7eedd165 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x6289ebb8547d - std::panicking::catch_unwind::do_call::he5edbaf126c13b99 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x6289ebb8547d - std::panicking::catch_unwind::h3d6a8652eceeabce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x6289ebb8547d - std::panic::catch_unwind::hbef0c501dd7bb498 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x6289ebb8547d - test::run_test_in_process::h400008a46a5006a0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x6289ebb8547d - test::run_test::{{closure}}::h9a131655b31d9427 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x6289ebb5e9c4 - test::run_test::{{closure}}::he4a7177c216308c0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x6289ebb5e9c4 - std::sys::backtrace::__rust_begin_short_backtrace::hd3980e9c55d6c539 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h18552df67c7aa9b8 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 36: 0x6289ebb622fa - as core::ops::function::FnOnce<()>>::call_once::h3d7b285234641a08 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x6289ebb622fa - std::panicking::catch_unwind::do_call::h5a2b5cf36528a5b2 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x6289ebb622fa - std::panicking::catch_unwind::h7e8b531bbda77d20 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x6289ebb622fa - std::panic::catch_unwind::hf9bbb2040b4f1e6c [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::h600f92cf68549574 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 41: 0x6289ebb622fa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb6607307df8a1847 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x713ee9e3c8ef - as core::ops::function::FnOnce>::call_once::h6891ad53a5ed6f52 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2085:9 [INFO] [stdout] 43: 0x713ee9e3c8ef - std::sys::thread::unix::Thread::new::thread_start::h7f3e77fa86df70af [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/thread/unix.rs:124:17 [INFO] [stdout] 44: 0x713ee9bd6aa4 - [INFO] [stdout] 45: 0x713ee9c63a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- tests::enum_transformed_fields stdout ---- [INFO] [stdout] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Snapshot Summary ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ [INFO] [stdout] Snapshot file: src/snapshots/rust_sitter_macro__tests__enum_transformed_fields.snap [INFO] [stdout] Snapshot: enum_transformed_fields [INFO] [stdout] Source: src/lib.rs:263 [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] Expression: rustfmt_code(&expand_grammar(parse_quote! [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::grammar("test")] mod grammar [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::language] pub enum Expression [INFO] [stdout] { [INFO] [stdout] Number(#[rust_sitter::leaf(pattern = r"\d+", transform = |v| [INFO] [stdout] v.parse::().unwrap())] i32), [INFO] [stdout] } [INFO] [stdout] } [INFO] [stdout] })? .to_token_stream().to_string()) [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] -old snapshot [INFO] [stdout] +new results [INFO] [stdout] ────────────┬─────────────────────────────────────────────────────────────────── [INFO] [stdout] 0 │-mod grammar { [INFO] [stdout] 1 │- pub enum Expression { [INFO] [stdout] 2 │- Number(i32), [INFO] [stdout] 3 │- } [INFO] [stdout] 4 │- impl ::rust_sitter::Extract for Expression { [INFO] [stdout] 5 │- type LeafFn = (); [INFO] [stdout] 6 │- #[allow(non_snake_case)] [INFO] [stdout] 7 │- fn extract( [INFO] [stdout] 8 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 9 │- source: &[u8], [INFO] [stdout] 10 │- _last_idx: usize, [INFO] [stdout] 11 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 12 │- ) -> Self { [INFO] [stdout] 13 │- let node = node.unwrap(); [INFO] [stdout] 14 │- let mut cursor = node.walk(); [INFO] [stdout] 15 │- assert!( [INFO] [stdout] 16 │- cursor.goto_first_child(), [INFO] [stdout] 17 │- "Could not find a child corresponding to any enum branch" [INFO] [stdout] 18 │- ); [INFO] [stdout] 19 │- loop { [INFO] [stdout] 20 │- let node = cursor.node(); [INFO] [stdout] 21 │- match node.kind() { [INFO] [stdout] 22 │- "Expression_Number" => { [INFO] [stdout] 23 │- return ::rust_sitter::__private::extract_struct_or_variant( [INFO] [stdout] 24 │- node, [INFO] [stdout] 25 │- move |cursor, last_idx| { [INFO] [stdout] 26 │- Expression::Number({ [INFO] [stdout] 27 │- ::rust_sitter::__private::extract_field::< [INFO] [stdout] 28 │- rust_sitter::WithLeaf, [INFO] [stdout] 29 │- _, [INFO] [stdout] 30 │- >( [INFO] [stdout] 31 │- cursor, [INFO] [stdout] 32 │- source, [INFO] [stdout] 33 │- last_idx, [INFO] [stdout] 34 │- "0", [INFO] [stdout] 35 │- Some(&|v| v.parse::().unwrap()), [INFO] [stdout] 36 │- ) [INFO] [stdout] 37 │- }) [INFO] [stdout] 38 │- }, [INFO] [stdout] 39 │- ) [INFO] [stdout] 40 │- } [INFO] [stdout] 41 │- _ => { [INFO] [stdout] 42 │- if !cursor.goto_next_sibling() { [INFO] [stdout] 43 │- panic!("Could not find a child corresponding to any enum branch") [INFO] [stdout] 44 │- } [INFO] [stdout] 45 │- } [INFO] [stdout] 46 │- } [INFO] [stdout] 47 │- } [INFO] [stdout] 48 │- } [INFO] [stdout] 49 │- } [INFO] [stdout] 50 │- extern "C" { [INFO] [stdout] 51 │- fn tree_sitter_test() -> ::rust_sitter::tree_sitter::Language; [INFO] [stdout] 52 │- } [INFO] [stdout] 53 │- pub fn language() -> ::rust_sitter::tree_sitter::Language { [INFO] [stdout] 54 │- unsafe { tree_sitter_test() } [INFO] [stdout] 55 │- } [INFO] [stdout] 56 │- #[doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] [INFO] [stdout] 57 │- #[doc = "[`Expression`]"] [INFO] [stdout] 58 │- #[doc = r" instance containing the parsed structured data."] [INFO] [stdout] 59 │- pub fn parse( [INFO] [stdout] 60 │- input: &str, [INFO] [stdout] 61 │- ) -> core::result::Result> { [INFO] [stdout] 62 │- ::rust_sitter::__private::parse::(input, language) [INFO] [stdout] 63 │- } [INFO] [stdout] 64 │-} [INFO] [stdout] 0 │+mod grammar { pub enum Expression { Number (i32) , } impl :: rust_sitter :: Extract < Expression > for Expression { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , _last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; let mut cursor = node . walk () ; assert ! (cursor . goto_first_child () , "Could not find a child corresponding to any enum branch") ; loop { let node = cursor . node () ; match node . kind () { "Expression_Number" => return :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Expression :: Number ({ :: rust_sitter :: __private :: extract_field :: < rust_sitter :: WithLeaf < i32 > , _ > (cursor , source , last_idx , "0" , Some (& | v | v . parse :: < i32 > () . unwrap ())) })) , _ => if ! cursor . goto_next_sibling () { panic ! ("Could not find a child corresponding to any enum branch") } } } } } extern "C" { fn tree_sitter_test () -> :: rust_sitter :: tree_sitter :: Language ; } pub fn language () -> :: rust_sitter :: tree_sitter :: Language { unsafe { tree_sitter_test () } } # [doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] # [doc = "[`Expression`]"] # [doc = r" instance containing the parsed structured data."] pub fn parse (input : & str) -> core :: result :: Result < Expression , Vec < :: rust_sitter :: errors :: ParseError > > { :: rust_sitter :: __private :: parse :: < Expression > (input , language) } } [INFO] [stdout] ────────────┴─────────────────────────────────────────────────────────────────── [INFO] [stdout] [INFO] [stdout] thread 'tests::enum_transformed_fields' (26) panicked at src/lib.rs:263:9: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileIo(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }, "/opt/rustwide/workdir/src/snapshots/rust_sitter_macro__tests__enum_transformed_fields.snap.new") [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::libunwind::trace::h9ea1e07ac77a25d7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h72b75eb83b53d15a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x713ee9e7b1c2 - std::sys::backtrace::_print_fmt::h255777b7ec902439 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x713ee9e7b1c2 - ::fmt::h8a1ac49fcd7ee8ce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x713ee9eab40f - core::fmt::rt::Argument::fmt::h635cbf3c6754cc90 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x713ee9eab40f - core::fmt::write::hbdcc0ec4f1bab1db [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x713ee9e2c943 - std::io::default_write_fmt::h2580ece0d4b58e51 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x713ee9e2c943 - std::io::Write::write_fmt::hac9e42858f273b87 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x713ee9e41e92 - std::sys::backtrace::BacktraceLock::print::h052febbd86f7bf07 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x713ee9e4a2ba - std::panicking::default_hook::{{closure}}::h66aeee20dd470abb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x713ee9e4a14c - std::panicking::default_hook::h9d66b9642014ce48 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6289ebb7161e - as core::ops::function::Fn>::call::h8c698701e444e564 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 12: 0x6289ebb7161e - test::test_main_with_exit_callback::{{closure}}::ha1c98e7b69c4defb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x713ee9e4a96f - as core::ops::function::Fn>::call::hc4f222a8a57c637a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 14: 0x713ee9e4a96f - std::panicking::panic_with_hook::h6d5921a1a1fa5a8e [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x713ee9e4a71a - std::panicking::panic_handler::{{closure}}::hafeef6f707d43542 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x713ee9e41fc9 - std::sys::backtrace::__rust_end_short_backtrace::h08cbc3319a3d0120 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x713ee9e1e4ad - __rustc[ce5c411ff86ab1b2]::rust_begin_unwind [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x713ee9ebb410 - core::panicking::panic_fmt::h774fb860369a0f7b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x713ee9eb9d56 - core::result::unwrap_failed::h72ee8fcbf1bf8ff9 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x6289eba39e7a - core::result::Result::unwrap::h85aa971974d63926 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x6289eba39e7a - rust_sitter_macro::tests::enum_transformed_fields::he65f28decbb692f9 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:263:9 [INFO] [stdout] 22: 0x6289eba3a07d - rust_sitter_macro::tests::enum_transformed_fields::{{closure}}::hc9854cbfaceea8b0 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:262:37 [INFO] [stdout] 23: 0x6289eba45fb6 - core::ops::function::FnOnce::call_once::h591de59ab852eb8d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6289ebb7146b - core::ops::function::FnOnce::call_once::h4f6eabe90cccb47d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x6289ebb7146b - test::__rust_begin_short_backtrace::h94208530f2b4c8c7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x6289ebb8547d - test::run_test_in_process::{{closure}}::hbdc6a45a78c46404 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x6289ebb8547d - as core::ops::function::FnOnce<()>>::call_once::h7f9d8efc7eedd165 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x6289ebb8547d - std::panicking::catch_unwind::do_call::he5edbaf126c13b99 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x6289ebb8547d - std::panicking::catch_unwind::h3d6a8652eceeabce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x6289ebb8547d - std::panic::catch_unwind::hbef0c501dd7bb498 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x6289ebb8547d - test::run_test_in_process::h400008a46a5006a0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x6289ebb8547d - test::run_test::{{closure}}::h9a131655b31d9427 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x6289ebb5e9c4 - test::run_test::{{closure}}::he4a7177c216308c0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x6289ebb5e9c4 - std::sys::backtrace::__rust_begin_short_backtrace::hd3980e9c55d6c539 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h18552df67c7aa9b8 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 36: 0x6289ebb622fa - as core::ops::function::FnOnce<()>>::call_once::h3d7b285234641a08 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x6289ebb622fa - std::panicking::catch_unwind::do_call::h5a2b5cf36528a5b2 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x6289ebb622fa - std::panicking::catch_unwind::h7e8b531bbda77d20 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x6289ebb622fa - std::panic::catch_unwind::hf9bbb2040b4f1e6c [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::h600f92cf68549574 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 41: 0x6289ebb622fa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb6607307df8a1847 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x713ee9e3c8ef - as core::ops::function::FnOnce>::call_once::h6891ad53a5ed6f52 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2085:9 [INFO] [stdout] 43: 0x713ee9e3c8ef - std::sys::thread::unix::Thread::new::thread_start::h7f3e77fa86df70af [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/thread/unix.rs:124:17 [INFO] [stdout] 44: 0x713ee9bd6aa4 - [INFO] [stdout] 45: 0x713ee9c63a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- tests::enum_prec_left stdout ---- [INFO] [stdout] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Snapshot Summary ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ [INFO] [stdout] Snapshot file: src/snapshots/rust_sitter_macro__tests__enum_prec_left.snap [INFO] [stdout] Snapshot: enum_prec_left [INFO] [stdout] Source: src/lib.rs:312 [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] Expression: rustfmt_code(&expand_grammar(parse_quote! [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::grammar("test")] mod grammar [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::language] pub enum Expression [INFO] [stdout] { [INFO] [stdout] Number(#[rust_sitter::leaf(pattern = r"\d+", transform = |v| [INFO] [stdout] v.parse().unwrap())] i32), #[rust_sitter::prec_left(1)] [INFO] [stdout] Sub(Box, #[rust_sitter::leaf(text = "-")] (), [INFO] [stdout] Box), [INFO] [stdout] } [INFO] [stdout] } [INFO] [stdout] })? .to_token_stream().to_string()) [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] -old snapshot [INFO] [stdout] +new results [INFO] [stdout] ────────────┬─────────────────────────────────────────────────────────────────── [INFO] [stdout] 0 │-mod grammar { [INFO] [stdout] 1 │- pub enum Expression { [INFO] [stdout] 2 │- Number(i32), [INFO] [stdout] 3 │- Sub(Box, (), Box), [INFO] [stdout] 4 │- } [INFO] [stdout] 5 │- impl ::rust_sitter::Extract for Expression { [INFO] [stdout] 6 │- type LeafFn = (); [INFO] [stdout] 7 │- #[allow(non_snake_case)] [INFO] [stdout] 8 │- fn extract( [INFO] [stdout] 9 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 10 │- source: &[u8], [INFO] [stdout] 11 │- _last_idx: usize, [INFO] [stdout] 12 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 13 │- ) -> Self { [INFO] [stdout] 14 │- let node = node.unwrap(); [INFO] [stdout] 15 │- let mut cursor = node.walk(); [INFO] [stdout] 16 │- assert!( [INFO] [stdout] 17 │- cursor.goto_first_child(), [INFO] [stdout] 18 │- "Could not find a child corresponding to any enum branch" [INFO] [stdout] 19 │- ); [INFO] [stdout] 20 │- loop { [INFO] [stdout] 21 │- let node = cursor.node(); [INFO] [stdout] 22 │- match node.kind() { [INFO] [stdout] 23 │- "Expression_Number" => { [INFO] [stdout] 24 │- return ::rust_sitter::__private::extract_struct_or_variant( [INFO] [stdout] 25 │- node, [INFO] [stdout] 26 │- move |cursor, last_idx| { [INFO] [stdout] 27 │- Expression::Number({ [INFO] [stdout] 28 │- ::rust_sitter::__private::extract_field::< [INFO] [stdout] 29 │- rust_sitter::WithLeaf, [INFO] [stdout] 30 │- _, [INFO] [stdout] 31 │- >( [INFO] [stdout] 32 │- cursor, source, last_idx, "0", Some(&|v| v.parse().unwrap()) [INFO] [stdout] 33 │- ) [INFO] [stdout] 34 │- }) [INFO] [stdout] 35 │- }, [INFO] [stdout] 36 │- ) [INFO] [stdout] 37 │- } [INFO] [stdout] 38 │- "Expression_Sub" => { [INFO] [stdout] 39 │- return ::rust_sitter::__private::extract_struct_or_variant( [INFO] [stdout] 40 │- node, [INFO] [stdout] 41 │- move |cursor, last_idx| { [INFO] [stdout] 42 │- Expression::Sub( [INFO] [stdout] 43 │- { [INFO] [stdout] 44 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 45 │- cursor, source, last_idx, "0", None, [INFO] [stdout] 46 │- ) [INFO] [stdout] 47 │- }, [INFO] [stdout] 48 │- { [INFO] [stdout] 49 │- ::rust_sitter::__private::extract_field::<(), _>( [INFO] [stdout] 50 │- cursor, source, last_idx, "1", None, [INFO] [stdout] 51 │- ) [INFO] [stdout] 52 │- }, [INFO] [stdout] 53 │- { [INFO] [stdout] 54 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 55 │- cursor, source, last_idx, "2", None, [INFO] [stdout] 56 │- ) [INFO] [stdout] 57 │- }, [INFO] [stdout] 58 │- ) [INFO] [stdout] 59 │- }, [INFO] [stdout] 60 │- ) [INFO] [stdout] 61 │- } [INFO] [stdout] 62 │- _ => { [INFO] [stdout] 63 │- if !cursor.goto_next_sibling() { [INFO] [stdout] 64 │- panic!("Could not find a child corresponding to any enum branch") [INFO] [stdout] 65 │- } [INFO] [stdout] 66 │- } [INFO] [stdout] 67 │- } [INFO] [stdout] 68 │- } [INFO] [stdout] 69 │- } [INFO] [stdout] 70 │- } [INFO] [stdout] 71 │- extern "C" { [INFO] [stdout] 72 │- fn tree_sitter_test() -> ::rust_sitter::tree_sitter::Language; [INFO] [stdout] 73 │- } [INFO] [stdout] 74 │- pub fn language() -> ::rust_sitter::tree_sitter::Language { [INFO] [stdout] 75 │- unsafe { tree_sitter_test() } [INFO] [stdout] 76 │- } [INFO] [stdout] 77 │- #[doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] [INFO] [stdout] 78 │- #[doc = "[`Expression`]"] [INFO] [stdout] 79 │- #[doc = r" instance containing the parsed structured data."] [INFO] [stdout] 80 │- pub fn parse( [INFO] [stdout] 81 │- input: &str, [INFO] [stdout] 82 │- ) -> core::result::Result> { [INFO] [stdout] 83 │- ::rust_sitter::__private::parse::(input, language) [INFO] [stdout] 84 │- } [INFO] [stdout] 85 │-} [INFO] [stdout] 0 │+mod grammar { pub enum Expression { Number (i32) , Sub (Box < Expression > , () , Box < Expression >) , } impl :: rust_sitter :: Extract < Expression > for Expression { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , _last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; let mut cursor = node . walk () ; assert ! (cursor . goto_first_child () , "Could not find a child corresponding to any enum branch") ; loop { let node = cursor . node () ; match node . kind () { "Expression_Number" => return :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Expression :: Number ({ :: rust_sitter :: __private :: extract_field :: < rust_sitter :: WithLeaf < i32 > , _ > (cursor , source , last_idx , "0" , Some (& | v | v . parse () . unwrap ())) })) , "Expression_Sub" => return :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Expression :: Sub ({ :: rust_sitter :: __private :: extract_field :: < Box < Expression > , _ > (cursor , source , last_idx , "0" , None) } , { :: rust_sitter :: __private :: extract_field :: < () , _ > (cursor , source , last_idx , "1" , None) } , { :: rust_sitter :: __private :: extract_field :: < Box < Expression > , _ > (cursor , source , last_idx , "2" , None) })) , _ => if ! cursor . goto_next_sibling () { panic ! ("Could not find a child corresponding to any enum branch") } } } } } extern "C" { fn tree_sitter_test () -> :: rust_sitter :: tree_sitter :: Language ; } pub fn language () -> :: rust_sitter :: tree_sitter :: Language { unsafe { tree_sitter_test () } } # [doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] # [doc = "[`Expression`]"] # [doc = r" instance containing the parsed structured data."] pub fn parse (input : & str) -> core :: result :: Result < Expression , Vec < :: rust_sitter :: errors :: ParseError > > { :: rust_sitter :: __private :: parse :: < Expression > (input , language) } } [INFO] [stdout] ────────────┴─────────────────────────────────────────────────────────────────── [INFO] [stdout] [INFO] [stdout] thread 'tests::enum_prec_left' (24) panicked at src/lib.rs:312:9: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileIo(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }, "/opt/rustwide/workdir/src/snapshots/rust_sitter_macro__tests__enum_prec_left.snap.new") [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::libunwind::trace::h9ea1e07ac77a25d7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h72b75eb83b53d15a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x713ee9e7b1c2 - std::sys::backtrace::_print_fmt::h255777b7ec902439 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x713ee9e7b1c2 - ::fmt::h8a1ac49fcd7ee8ce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x713ee9eab40f - core::fmt::rt::Argument::fmt::h635cbf3c6754cc90 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x713ee9eab40f - core::fmt::write::hbdcc0ec4f1bab1db [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x713ee9e2c943 - std::io::default_write_fmt::h2580ece0d4b58e51 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x713ee9e2c943 - std::io::Write::write_fmt::hac9e42858f273b87 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x713ee9e41e92 - std::sys::backtrace::BacktraceLock::print::h052febbd86f7bf07 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x713ee9e4a2ba - std::panicking::default_hook::{{closure}}::h66aeee20dd470abb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x713ee9e4a14c - std::panicking::default_hook::h9d66b9642014ce48 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6289ebb7161e - as core::ops::function::Fn>::call::h8c698701e444e564 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 12: 0x6289ebb7161e - test::test_main_with_exit_callback::{{closure}}::ha1c98e7b69c4defb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x713ee9e4a96f - as core::ops::function::Fn>::call::hc4f222a8a57c637a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 14: 0x713ee9e4a96f - std::panicking::panic_with_hook::h6d5921a1a1fa5a8e [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x713ee9e4a71a - std::panicking::panic_handler::{{closure}}::hafeef6f707d43542 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x713ee9e41fc9 - std::sys::backtrace::__rust_end_short_backtrace::h08cbc3319a3d0120 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x713ee9e1e4ad - __rustc[ce5c411ff86ab1b2]::rust_begin_unwind [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x713ee9ebb410 - core::panicking::panic_fmt::h774fb860369a0f7b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x713ee9eb9d56 - core::result::unwrap_failed::h72ee8fcbf1bf8ff9 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x6289eba3271c - core::result::Result::unwrap::h85aa971974d63926 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x6289eba3271c - rust_sitter_macro::tests::enum_prec_left::h7030f64415e85a61 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:312:9 [INFO] [stdout] 22: 0x6289eba3291d - rust_sitter_macro::tests::enum_prec_left::{{closure}}::hd11d32ecee2b0700 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:311:28 [INFO] [stdout] 23: 0x6289eba460d6 - core::ops::function::FnOnce::call_once::h7ae0c2881fab4166 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6289ebb7146b - core::ops::function::FnOnce::call_once::h4f6eabe90cccb47d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x6289ebb7146b - test::__rust_begin_short_backtrace::h94208530f2b4c8c7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x6289ebb8547d - test::run_test_in_process::{{closure}}::hbdc6a45a78c46404 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x6289ebb8547d - as core::ops::function::FnOnce<()>>::call_once::h7f9d8efc7eedd165 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x6289ebb8547d - std::panicking::catch_unwind::do_call::he5edbaf126c13b99 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x6289ebb8547d - std::panicking::catch_unwind::h3d6a8652eceeabce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x6289ebb8547d - std::panic::catch_unwind::hbef0c501dd7bb498 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x6289ebb8547d - test::run_test_in_process::h400008a46a5006a0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x6289ebb8547d - test::run_test::{{closure}}::h9a131655b31d9427 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x6289ebb5e9c4 - test::run_test::{{closure}}::he4a7177c216308c0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x6289ebb5e9c4 - std::sys::backtrace::__rust_begin_short_backtrace::hd3980e9c55d6c539 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h18552df67c7aa9b8 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 36: 0x6289ebb622fa - as core::ops::function::FnOnce<()>>::call_once::h3d7b285234641a08 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x6289ebb622fa - std::panicking::catch_unwind::do_call::h5a2b5cf36528a5b2 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x6289ebb622fa - std::panicking::catch_unwind::h7e8b531bbda77d20 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x6289ebb622fa - std::panic::catch_unwind::hf9bbb2040b4f1e6c [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::h600f92cf68549574 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 41: 0x6289ebb622fa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb6607307df8a1847 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x713ee9e3c8ef - as core::ops::function::FnOnce>::call_once::h6891ad53a5ed6f52 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2085:9 [INFO] [stdout] 43: 0x713ee9e3c8ef - std::sys::thread::unix::Thread::new::thread_start::h7f3e77fa86df70af [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/thread/unix.rs:124:17 [INFO] [stdout] 44: 0x713ee9bd6aa4 - [INFO] [stdout] 45: 0x713ee9c63a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- tests::grammar_unboxed_field stdout ---- [INFO] [stdout] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Snapshot Summary ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ [INFO] [stdout] Snapshot file: src/snapshots/rust_sitter_macro__tests__grammar_unboxed_field.snap [INFO] [stdout] Snapshot: grammar_unboxed_field [INFO] [stdout] Source: src/lib.rs:368 [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] Expression: rustfmt_code(&expand_grammar(parse_quote! [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::grammar("test")] mod grammar [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::language] pub struct Language { e: Expression, } pub [INFO] [stdout] enum Expression [INFO] [stdout] { [INFO] [stdout] Number(#[rust_sitter::leaf(pattern = r"\d+", transform = |v: &str| [INFO] [stdout] v.parse::().unwrap())] i32), [INFO] [stdout] } [INFO] [stdout] } [INFO] [stdout] })? .to_token_stream().to_string()) [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] -old snapshot [INFO] [stdout] +new results [INFO] [stdout] ────────────┬─────────────────────────────────────────────────────────────────── [INFO] [stdout] 0 │-mod grammar { [INFO] [stdout] 1 │- pub struct Language { [INFO] [stdout] 2 │- e: Expression, [INFO] [stdout] 3 │- } [INFO] [stdout] 4 │- impl ::rust_sitter::Extract for Language { [INFO] [stdout] 5 │- type LeafFn = (); [INFO] [stdout] 6 │- #[allow(non_snake_case)] [INFO] [stdout] 7 │- fn extract( [INFO] [stdout] 8 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 9 │- source: &[u8], [INFO] [stdout] 10 │- last_idx: usize, [INFO] [stdout] 11 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 12 │- ) -> Self { [INFO] [stdout] 13 │- let node = node.unwrap(); [INFO] [stdout] 14 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 15 │- Language { [INFO] [stdout] 16 │- e: { [INFO] [stdout] 17 │- ::rust_sitter::__private::extract_field::( [INFO] [stdout] 18 │- cursor, source, last_idx, "e", None, [INFO] [stdout] 19 │- ) [INFO] [stdout] 20 │- }, [INFO] [stdout] 21 │- } [INFO] [stdout] 22 │- }) [INFO] [stdout] 23 │- } [INFO] [stdout] 24 │- } [INFO] [stdout] 25 │- pub enum Expression { [INFO] [stdout] 26 │- Number(i32), [INFO] [stdout] 27 │- } [INFO] [stdout] 28 │- impl ::rust_sitter::Extract for Expression { [INFO] [stdout] 29 │- type LeafFn = (); [INFO] [stdout] 30 │- #[allow(non_snake_case)] [INFO] [stdout] 31 │- fn extract( [INFO] [stdout] 32 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 33 │- source: &[u8], [INFO] [stdout] 34 │- _last_idx: usize, [INFO] [stdout] 35 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 36 │- ) -> Self { [INFO] [stdout] 37 │- let node = node.unwrap(); [INFO] [stdout] 38 │- let mut cursor = node.walk(); [INFO] [stdout] 39 │- assert!( [INFO] [stdout] 40 │- cursor.goto_first_child(), [INFO] [stdout] 41 │- "Could not find a child corresponding to any enum branch" [INFO] [stdout] 42 │- ); [INFO] [stdout] 43 │- loop { [INFO] [stdout] 44 │- let node = cursor.node(); [INFO] [stdout] 45 │- match node.kind() { [INFO] [stdout] 46 │- "Expression_Number" => { [INFO] [stdout] 47 │- return ::rust_sitter::__private::extract_struct_or_variant( [INFO] [stdout] 48 │- node, [INFO] [stdout] 49 │- move |cursor, last_idx| { [INFO] [stdout] 50 │- Expression::Number({ [INFO] [stdout] 51 │- ::rust_sitter::__private::extract_field::< [INFO] [stdout] 52 │- rust_sitter::WithLeaf, [INFO] [stdout] 53 │- _, [INFO] [stdout] 54 │- >( [INFO] [stdout] 55 │- cursor, [INFO] [stdout] 56 │- source, [INFO] [stdout] 57 │- last_idx, [INFO] [stdout] 58 │- "0", [INFO] [stdout] 59 │- Some(&|v: &str| v.parse::().unwrap()), [INFO] [stdout] 60 │- ) [INFO] [stdout] 61 │- }) [INFO] [stdout] 62 │- }, [INFO] [stdout] 63 │- ) [INFO] [stdout] 64 │- } [INFO] [stdout] 65 │- _ => { [INFO] [stdout] 66 │- if !cursor.goto_next_sibling() { [INFO] [stdout] 67 │- panic!("Could not find a child corresponding to any enum branch") [INFO] [stdout] 68 │- } [INFO] [stdout] 69 │- } [INFO] [stdout] 70 │- } [INFO] [stdout] 71 │- } [INFO] [stdout] 72 │- } [INFO] [stdout] 73 │- } [INFO] [stdout] 74 │- extern "C" { [INFO] [stdout] 75 │- fn tree_sitter_test() -> ::rust_sitter::tree_sitter::Language; [INFO] [stdout] 76 │- } [INFO] [stdout] 77 │- pub fn language() -> ::rust_sitter::tree_sitter::Language { [INFO] [stdout] 78 │- unsafe { tree_sitter_test() } [INFO] [stdout] 79 │- } [INFO] [stdout] 80 │- #[doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] [INFO] [stdout] 81 │- #[doc = "[`Language`]"] [INFO] [stdout] 82 │- #[doc = r" instance containing the parsed structured data."] [INFO] [stdout] 83 │- pub fn parse( [INFO] [stdout] 84 │- input: &str, [INFO] [stdout] 85 │- ) -> core::result::Result> { [INFO] [stdout] 86 │- ::rust_sitter::__private::parse::(input, language) [INFO] [stdout] 87 │- } [INFO] [stdout] 88 │-} [INFO] [stdout] 0 │+mod grammar { pub struct Language { e : Expression , } impl :: rust_sitter :: Extract < Language > for Language { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Language { e : { :: rust_sitter :: __private :: extract_field :: < Expression , _ > (cursor , source , last_idx , "e" , None) } }) } } pub enum Expression { Number (i32) , } impl :: rust_sitter :: Extract < Expression > for Expression { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , _last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; let mut cursor = node . walk () ; assert ! (cursor . goto_first_child () , "Could not find a child corresponding to any enum branch") ; loop { let node = cursor . node () ; match node . kind () { "Expression_Number" => return :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Expression :: Number ({ :: rust_sitter :: __private :: extract_field :: < rust_sitter :: WithLeaf < i32 > , _ > (cursor , source , last_idx , "0" , Some (& | v : & str | v . parse :: < i32 > () . unwrap ())) })) , _ => if ! cursor . goto_next_sibling () { panic ! ("Could not find a child corresponding to any enum branch") } } } } } extern "C" { fn tree_sitter_test () -> :: rust_sitter :: tree_sitter :: Language ; } pub fn language () -> :: rust_sitter :: tree_sitter :: Language { unsafe { tree_sitter_test () } } # [doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] # [doc = "[`Language`]"] # [doc = r" instance containing the parsed structured data."] pub fn parse (input : & str) -> core :: result :: Result < Language , Vec < :: rust_sitter :: errors :: ParseError > > { :: rust_sitter :: __private :: parse :: < Language > (input , language) } } [INFO] [stdout] ────────────┴─────────────────────────────────────────────────────────────────── [INFO] [stdout] [INFO] [stdout] thread 'tests::grammar_unboxed_field' (29) panicked at src/lib.rs:368:9: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileIo(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }, "/opt/rustwide/workdir/src/snapshots/rust_sitter_macro__tests__grammar_unboxed_field.snap.new") [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::libunwind::trace::h9ea1e07ac77a25d7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h72b75eb83b53d15a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x713ee9e7b1c2 - std::sys::backtrace::_print_fmt::h255777b7ec902439 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x713ee9e7b1c2 - ::fmt::h8a1ac49fcd7ee8ce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x713ee9eab40f - core::fmt::rt::Argument::fmt::h635cbf3c6754cc90 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x713ee9eab40f - core::fmt::write::hbdcc0ec4f1bab1db [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x713ee9e2c943 - std::io::default_write_fmt::h2580ece0d4b58e51 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x713ee9e2c943 - std::io::Write::write_fmt::hac9e42858f273b87 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x713ee9e41e92 - std::sys::backtrace::BacktraceLock::print::h052febbd86f7bf07 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x713ee9e4a2ba - std::panicking::default_hook::{{closure}}::h66aeee20dd470abb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x713ee9e4a14c - std::panicking::default_hook::h9d66b9642014ce48 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6289ebb7161e - as core::ops::function::Fn>::call::h8c698701e444e564 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 12: 0x6289ebb7161e - test::test_main_with_exit_callback::{{closure}}::ha1c98e7b69c4defb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x713ee9e4a96f - as core::ops::function::Fn>::call::hc4f222a8a57c637a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 14: 0x713ee9e4a96f - std::panicking::panic_with_hook::h6d5921a1a1fa5a8e [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x713ee9e4a71a - std::panicking::panic_handler::{{closure}}::hafeef6f707d43542 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x713ee9e41fc9 - std::sys::backtrace::__rust_end_short_backtrace::h08cbc3319a3d0120 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x713ee9e1e4ad - __rustc[ce5c411ff86ab1b2]::rust_begin_unwind [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x713ee9ebb410 - core::panicking::panic_fmt::h774fb860369a0f7b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x713ee9eb9d56 - core::result::unwrap_failed::h72ee8fcbf1bf8ff9 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x6289eba38d5f - core::result::Result::unwrap::h85aa971974d63926 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x6289eba38d5f - rust_sitter_macro::tests::grammar_unboxed_field::hbaf23bbaa4a5ee70 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:368:9 [INFO] [stdout] 22: 0x6289eba38f6d - rust_sitter_macro::tests::grammar_unboxed_field::{{closure}}::h670bc1b2cad3e4f5 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:367:35 [INFO] [stdout] 23: 0x6289eba46116 - core::ops::function::FnOnce::call_once::h944bc4a64dcd52fb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6289ebb7146b - core::ops::function::FnOnce::call_once::h4f6eabe90cccb47d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x6289ebb7146b - test::__rust_begin_short_backtrace::h94208530f2b4c8c7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x6289ebb8547d - test::run_test_in_process::{{closure}}::hbdc6a45a78c46404 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x6289ebb8547d - as core::ops::function::FnOnce<()>>::call_once::h7f9d8efc7eedd165 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x6289ebb8547d - std::panicking::catch_unwind::do_call::he5edbaf126c13b99 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x6289ebb8547d - std::panicking::catch_unwind::h3d6a8652eceeabce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x6289ebb8547d - std::panic::catch_unwind::hbef0c501dd7bb498 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x6289ebb8547d - test::run_test_in_process::h400008a46a5006a0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x6289ebb8547d - test::run_test::{{closure}}::h9a131655b31d9427 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x6289ebb5e9c4 - test::run_test::{{closure}}::he4a7177c216308c0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x6289ebb5e9c4 - std::sys::backtrace::__rust_begin_short_backtrace::hd3980e9c55d6c539 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h18552df67c7aa9b8 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 36: 0x6289ebb622fa - as core::ops::function::FnOnce<()>>::call_once::h3d7b285234641a08 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x6289ebb622fa - std::panicking::catch_unwind::do_call::h5a2b5cf36528a5b2 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x6289ebb622fa - std::panicking::catch_unwind::h7e8b531bbda77d20 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x6289ebb622fa - std::panic::catch_unwind::hf9bbb2040b4f1e6c [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::h600f92cf68549574 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 41: 0x6289ebb622fa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb6607307df8a1847 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x713ee9e3c8ef - as core::ops::function::FnOnce>::call_once::h6891ad53a5ed6f52 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2085:9 [INFO] [stdout] 43: 0x713ee9e3c8ef - std::sys::thread::unix::Thread::new::thread_start::h7f3e77fa86df70af [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/thread/unix.rs:124:17 [INFO] [stdout] 44: 0x713ee9bd6aa4 - [INFO] [stdout] 45: 0x713ee9c63a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- tests::enum_with_named_field stdout ---- [INFO] [stdout] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Snapshot Summary ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ [INFO] [stdout] Snapshot file: src/snapshots/rust_sitter_macro__tests__enum_with_named_field.snap [INFO] [stdout] Snapshot: enum_with_named_field [INFO] [stdout] Source: src/lib.rs:477 [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] Expression: rustfmt_code(&expand_grammar(parse_quote! [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::grammar("test")] mod grammar [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::language] pub enum Expr [INFO] [stdout] { [INFO] [stdout] Number(#[rust_sitter::leaf(pattern = r"\d+", transform = |v| [INFO] [stdout] v.parse().unwrap())] u32), Neg [INFO] [stdout] { #[rust_sitter::leaf(text = "!")] _bang: (), value: Box, } [INFO] [stdout] } [INFO] [stdout] } [INFO] [stdout] })? .to_token_stream().to_string()) [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] -old snapshot [INFO] [stdout] +new results [INFO] [stdout] ────────────┬─────────────────────────────────────────────────────────────────── [INFO] [stdout] 0 │-mod grammar { [INFO] [stdout] 1 │- pub enum Expr { [INFO] [stdout] 2 │- Number(u32), [INFO] [stdout] 3 │- Neg { _bang: (), value: Box }, [INFO] [stdout] 4 │- } [INFO] [stdout] 5 │- impl ::rust_sitter::Extract for Expr { [INFO] [stdout] 6 │- type LeafFn = (); [INFO] [stdout] 7 │- #[allow(non_snake_case)] [INFO] [stdout] 8 │- fn extract( [INFO] [stdout] 9 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 10 │- source: &[u8], [INFO] [stdout] 11 │- _last_idx: usize, [INFO] [stdout] 12 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 13 │- ) -> Self { [INFO] [stdout] 14 │- let node = node.unwrap(); [INFO] [stdout] 15 │- let mut cursor = node.walk(); [INFO] [stdout] 16 │- assert!( [INFO] [stdout] 17 │- cursor.goto_first_child(), [INFO] [stdout] 18 │- "Could not find a child corresponding to any enum branch" [INFO] [stdout] 19 │- ); [INFO] [stdout] 20 │- loop { [INFO] [stdout] 21 │- let node = cursor.node(); [INFO] [stdout] 22 │- match node.kind() { [INFO] [stdout] 23 │- "Expr_Number" => { [INFO] [stdout] 24 │- return ::rust_sitter::__private::extract_struct_or_variant( [INFO] [stdout] 25 │- node, [INFO] [stdout] 26 │- move |cursor, last_idx| { [INFO] [stdout] 27 │- Expr::Number({ [INFO] [stdout] 28 │- ::rust_sitter::__private::extract_field::< [INFO] [stdout] 29 │- rust_sitter::WithLeaf, [INFO] [stdout] 30 │- _, [INFO] [stdout] 31 │- >( [INFO] [stdout] 32 │- cursor, source, last_idx, "0", Some(&|v| v.parse().unwrap()) [INFO] [stdout] 33 │- ) [INFO] [stdout] 34 │- }) [INFO] [stdout] 35 │- }, [INFO] [stdout] 36 │- ) [INFO] [stdout] 37 │- } [INFO] [stdout] 38 │- "Expr_Neg" => { [INFO] [stdout] 39 │- return ::rust_sitter::__private::extract_struct_or_variant( [INFO] [stdout] 40 │- node, [INFO] [stdout] 41 │- move |cursor, last_idx| Expr::Neg { [INFO] [stdout] 42 │- _bang: { [INFO] [stdout] 43 │- ::rust_sitter::__private::extract_field::<(), _>( [INFO] [stdout] 44 │- cursor, source, last_idx, "_bang", None, [INFO] [stdout] 45 │- ) [INFO] [stdout] 46 │- }, [INFO] [stdout] 47 │- value: { [INFO] [stdout] 48 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 49 │- cursor, source, last_idx, "value", None, [INFO] [stdout] 50 │- ) [INFO] [stdout] 51 │- }, [INFO] [stdout] 52 │- }, [INFO] [stdout] 53 │- ) [INFO] [stdout] 54 │- } [INFO] [stdout] 55 │- _ => { [INFO] [stdout] 56 │- if !cursor.goto_next_sibling() { [INFO] [stdout] 57 │- panic!("Could not find a child corresponding to any enum branch") [INFO] [stdout] 58 │- } [INFO] [stdout] 59 │- } [INFO] [stdout] 60 │- } [INFO] [stdout] 61 │- } [INFO] [stdout] 62 │- } [INFO] [stdout] 63 │- } [INFO] [stdout] 64 │- extern "C" { [INFO] [stdout] 65 │- fn tree_sitter_test() -> ::rust_sitter::tree_sitter::Language; [INFO] [stdout] 66 │- } [INFO] [stdout] 67 │- pub fn language() -> ::rust_sitter::tree_sitter::Language { [INFO] [stdout] 68 │- unsafe { tree_sitter_test() } [INFO] [stdout] 69 │- } [INFO] [stdout] 70 │- #[doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] [INFO] [stdout] 71 │- #[doc = "[`Expr`]"] [INFO] [stdout] 72 │- #[doc = r" instance containing the parsed structured data."] [INFO] [stdout] 73 │- pub fn parse( [INFO] [stdout] 74 │- input: &str, [INFO] [stdout] 75 │- ) -> core::result::Result> { [INFO] [stdout] 76 │- ::rust_sitter::__private::parse::(input, language) [INFO] [stdout] 77 │- } [INFO] [stdout] 78 │-} [INFO] [stdout] 0 │+mod grammar { pub enum Expr { Number (u32) , Neg { _bang : () , value : Box < Expr > , } } impl :: rust_sitter :: Extract < Expr > for Expr { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , _last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; let mut cursor = node . walk () ; assert ! (cursor . goto_first_child () , "Could not find a child corresponding to any enum branch") ; loop { let node = cursor . node () ; match node . kind () { "Expr_Number" => return :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Expr :: Number ({ :: rust_sitter :: __private :: extract_field :: < rust_sitter :: WithLeaf < u32 > , _ > (cursor , source , last_idx , "0" , Some (& | v | v . parse () . unwrap ())) })) , "Expr_Neg" => return :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Expr :: Neg { _bang : { :: rust_sitter :: __private :: extract_field :: < () , _ > (cursor , source , last_idx , "_bang" , None) } , value : { :: rust_sitter :: __private :: extract_field :: < Box < Expr > , _ > (cursor , source , last_idx , "value" , None) } }) , _ => if ! cursor . goto_next_sibling () { panic ! ("Could not find a child corresponding to any enum branch") } } } } } extern "C" { fn tree_sitter_test () -> :: rust_sitter :: tree_sitter :: Language ; } pub fn language () -> :: rust_sitter :: tree_sitter :: Language { unsafe { tree_sitter_test () } } # [doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] # [doc = "[`Expr`]"] # [doc = r" instance containing the parsed structured data."] pub fn parse (input : & str) -> core :: result :: Result < Expr , Vec < :: rust_sitter :: errors :: ParseError > > { :: rust_sitter :: __private :: parse :: < Expr > (input , language) } } [INFO] [stdout] ────────────┴─────────────────────────────────────────────────────────────────── [INFO] [stdout] [INFO] [stdout] thread 'tests::enum_with_named_field' (27) panicked at src/lib.rs:477:9: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileIo(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }, "/opt/rustwide/workdir/src/snapshots/rust_sitter_macro__tests__enum_with_named_field.snap.new") [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::libunwind::trace::h9ea1e07ac77a25d7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h72b75eb83b53d15a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x713ee9e7b1c2 - std::sys::backtrace::_print_fmt::h255777b7ec902439 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x713ee9e7b1c2 - ::fmt::h8a1ac49fcd7ee8ce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x713ee9eab40f - core::fmt::rt::Argument::fmt::h635cbf3c6754cc90 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x713ee9eab40f - core::fmt::write::hbdcc0ec4f1bab1db [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x713ee9e2c943 - std::io::default_write_fmt::h2580ece0d4b58e51 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x713ee9e2c943 - std::io::Write::write_fmt::hac9e42858f273b87 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x713ee9e41e92 - std::sys::backtrace::BacktraceLock::print::h052febbd86f7bf07 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x713ee9e4a2ba - std::panicking::default_hook::{{closure}}::h66aeee20dd470abb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x713ee9e4a14c - std::panicking::default_hook::h9d66b9642014ce48 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6289ebb7161e - as core::ops::function::Fn>::call::h8c698701e444e564 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 12: 0x6289ebb7161e - test::test_main_with_exit_callback::{{closure}}::ha1c98e7b69c4defb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x713ee9e4a96f - as core::ops::function::Fn>::call::hc4f222a8a57c637a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 14: 0x713ee9e4a96f - std::panicking::panic_with_hook::h6d5921a1a1fa5a8e [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x713ee9e4a71a - std::panicking::panic_handler::{{closure}}::hafeef6f707d43542 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x713ee9e41fc9 - std::sys::backtrace::__rust_end_short_backtrace::h08cbc3319a3d0120 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x713ee9e1e4ad - __rustc[ce5c411ff86ab1b2]::rust_begin_unwind [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x713ee9ebb410 - core::panicking::panic_fmt::h774fb860369a0f7b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x713ee9eb9d56 - core::result::unwrap_failed::h72ee8fcbf1bf8ff9 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x6289eba37acb - core::result::Result::unwrap::h85aa971974d63926 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x6289eba37acb - rust_sitter_macro::tests::enum_with_named_field::h3c0d2ce957f7887f [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:477:9 [INFO] [stdout] 22: 0x6289eba37ccd - rust_sitter_macro::tests::enum_with_named_field::{{closure}}::hfcfcc225f173c469 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:476:35 [INFO] [stdout] 23: 0x6289eba461e6 - core::ops::function::FnOnce::call_once::hc265785f96bfcb17 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6289ebb7146b - core::ops::function::FnOnce::call_once::h4f6eabe90cccb47d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x6289ebb7146b - test::__rust_begin_short_backtrace::h94208530f2b4c8c7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x6289ebb8547d - test::run_test_in_process::{{closure}}::hbdc6a45a78c46404 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x6289ebb8547d - as core::ops::function::FnOnce<()>>::call_once::h7f9d8efc7eedd165 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x6289ebb8547d - std::panicking::catch_unwind::do_call::he5edbaf126c13b99 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x6289ebb8547d - std::panicking::catch_unwind::h3d6a8652eceeabce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x6289ebb8547d - std::panic::catch_unwind::hbef0c501dd7bb498 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x6289ebb8547d - test::run_test_in_process::h400008a46a5006a0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x6289ebb8547d - test::run_test::{{closure}}::h9a131655b31d9427 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x6289ebb5e9c4 - test::run_test::{{closure}}::he4a7177c216308c0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x6289ebb5e9c4 - std::sys::backtrace::__rust_begin_short_backtrace::hd3980e9c55d6c539 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h18552df67c7aa9b8 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 36: 0x6289ebb622fa - as core::ops::function::FnOnce<()>>::call_once::h3d7b285234641a08 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x6289ebb622fa - std::panicking::catch_unwind::do_call::h5a2b5cf36528a5b2 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x6289ebb622fa - std::panicking::catch_unwind::h7e8b531bbda77d20 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x6289ebb622fa - std::panic::catch_unwind::hf9bbb2040b4f1e6c [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::h600f92cf68549574 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 41: 0x6289ebb622fa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb6607307df8a1847 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x713ee9e3c8ef - as core::ops::function::FnOnce>::call_once::h6891ad53a5ed6f52 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2085:9 [INFO] [stdout] 43: 0x713ee9e3c8ef - std::sys::thread::unix::Thread::new::thread_start::h7f3e77fa86df70af [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/thread/unix.rs:124:17 [INFO] [stdout] 44: 0x713ee9bd6aa4 - [INFO] [stdout] 45: 0x713ee9c63a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- tests::spanned_in_vec stdout ---- [INFO] [stdout] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Snapshot Summary ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ [INFO] [stdout] Snapshot file: src/snapshots/rust_sitter_macro__tests__spanned_in_vec.snap [INFO] [stdout] Snapshot: spanned_in_vec [INFO] [stdout] Source: src/lib.rs:504 [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] Expression: rustfmt_code(&expand_grammar(parse_quote! [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::grammar("test")] mod grammar [INFO] [stdout] { [INFO] [stdout] use rust_sitter::Spanned; #[rust_sitter::language] pub struct [INFO] [stdout] NumberList { numbers: Vec>, } pub struct Number [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::leaf(pattern = r"\d+", transform = |v| [INFO] [stdout] v.parse().unwrap())] v: i32 [INFO] [stdout] } #[rust_sitter::extra] struct Whitespace [INFO] [stdout] { #[rust_sitter::leaf(pattern = r"\s")] _whitespace: (), } [INFO] [stdout] } [INFO] [stdout] })? .to_token_stream().to_string()) [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] -old snapshot [INFO] [stdout] +new results [INFO] [stdout] ────────────┬─────────────────────────────────────────────────────────────────── [INFO] [stdout] 0 │-mod grammar { [INFO] [stdout] 1 │- use rust_sitter::Spanned; [INFO] [stdout] 2 │- pub struct NumberList { [INFO] [stdout] 3 │- numbers: Vec>, [INFO] [stdout] 4 │- } [INFO] [stdout] 5 │- impl ::rust_sitter::Extract for NumberList { [INFO] [stdout] 6 │- type LeafFn = (); [INFO] [stdout] 7 │- #[allow(non_snake_case)] [INFO] [stdout] 8 │- fn extract( [INFO] [stdout] 9 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 10 │- source: &[u8], [INFO] [stdout] 11 │- last_idx: usize, [INFO] [stdout] 12 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 13 │- ) -> Self { [INFO] [stdout] 14 │- let node = node.unwrap(); [INFO] [stdout] 15 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 16 │- NumberList { [INFO] [stdout] 17 │- numbers: { [INFO] [stdout] 18 │- ::rust_sitter::__private::extract_field::>, _>( [INFO] [stdout] 19 │- cursor, source, last_idx, "numbers", None, [INFO] [stdout] 20 │- ) [INFO] [stdout] 21 │- }, [INFO] [stdout] 22 │- } [INFO] [stdout] 23 │- }) [INFO] [stdout] 24 │- } [INFO] [stdout] 25 │- } [INFO] [stdout] 26 │- pub struct Number { [INFO] [stdout] 27 │- v: i32, [INFO] [stdout] 28 │- } [INFO] [stdout] 29 │- impl ::rust_sitter::Extract for Number { [INFO] [stdout] 30 │- type LeafFn = (); [INFO] [stdout] 31 │- #[allow(non_snake_case)] [INFO] [stdout] 32 │- fn extract( [INFO] [stdout] 33 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 34 │- source: &[u8], [INFO] [stdout] 35 │- last_idx: usize, [INFO] [stdout] 36 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 37 │- ) -> Self { [INFO] [stdout] 38 │- let node = node.unwrap(); [INFO] [stdout] 39 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 40 │- Number { [INFO] [stdout] 41 │- v: { [INFO] [stdout] 42 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 43 │- cursor, [INFO] [stdout] 44 │- source, [INFO] [stdout] 45 │- last_idx, [INFO] [stdout] 46 │- "v", [INFO] [stdout] 47 │- Some(&|v| v.parse().unwrap()), [INFO] [stdout] 48 │- ) [INFO] [stdout] 49 │- }, [INFO] [stdout] 50 │- } [INFO] [stdout] 51 │- }) [INFO] [stdout] 52 │- } [INFO] [stdout] 53 │- } [INFO] [stdout] 54 │- struct Whitespace { [INFO] [stdout] 55 │- _whitespace: (), [INFO] [stdout] 56 │- } [INFO] [stdout] 57 │- impl ::rust_sitter::Extract for Whitespace { [INFO] [stdout] 58 │- type LeafFn = (); [INFO] [stdout] 59 │- #[allow(non_snake_case)] [INFO] [stdout] 60 │- fn extract( [INFO] [stdout] 61 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 62 │- source: &[u8], [INFO] [stdout] 63 │- last_idx: usize, [INFO] [stdout] 64 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 65 │- ) -> Self { [INFO] [stdout] 66 │- let node = node.unwrap(); [INFO] [stdout] 67 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 68 │- Whitespace { [INFO] [stdout] 69 │- _whitespace: { [INFO] [stdout] 70 │- ::rust_sitter::__private::extract_field::<(), _>( [INFO] [stdout] 71 │- cursor, [INFO] [stdout] 72 │- source, [INFO] [stdout] 73 │- last_idx, [INFO] [stdout] 74 │- "_whitespace", [INFO] [stdout] 75 │- None, [INFO] [stdout] 76 │- ) [INFO] [stdout] 77 │- }, [INFO] [stdout] 78 │- } [INFO] [stdout] 79 │- }) [INFO] [stdout] 80 │- } [INFO] [stdout] 81 │- } [INFO] [stdout] 82 │- extern "C" { [INFO] [stdout] 83 │- fn tree_sitter_test() -> ::rust_sitter::tree_sitter::Language; [INFO] [stdout] 84 │- } [INFO] [stdout] 85 │- pub fn language() -> ::rust_sitter::tree_sitter::Language { [INFO] [stdout] 86 │- unsafe { tree_sitter_test() } [INFO] [stdout] 87 │- } [INFO] [stdout] 88 │- #[doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] [INFO] [stdout] 89 │- #[doc = "[`NumberList`]"] [INFO] [stdout] 90 │- #[doc = r" instance containing the parsed structured data."] [INFO] [stdout] 91 │- pub fn parse( [INFO] [stdout] 92 │- input: &str, [INFO] [stdout] 93 │- ) -> core::result::Result> { [INFO] [stdout] 94 │- ::rust_sitter::__private::parse::(input, language) [INFO] [stdout] 95 │- } [INFO] [stdout] 96 │-} [INFO] [stdout] 0 │+mod grammar { use rust_sitter :: Spanned ; pub struct NumberList { numbers : Vec < Spanned < Number > > , } impl :: rust_sitter :: Extract < NumberList > for NumberList { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | NumberList { numbers : { :: rust_sitter :: __private :: extract_field :: < Vec < Spanned < Number > > , _ > (cursor , source , last_idx , "numbers" , None) } }) } } pub struct Number { v : i32 } impl :: rust_sitter :: Extract < Number > for Number { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Number { v : { :: rust_sitter :: __private :: extract_field :: < rust_sitter :: WithLeaf < i32 > , _ > (cursor , source , last_idx , "v" , Some (& | v | v . parse () . unwrap ())) } }) } } struct Whitespace { _whitespace : () , } impl :: rust_sitter :: Extract < Whitespace > for Whitespace { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Whitespace { _whitespace : { :: rust_sitter :: __private :: extract_field :: < () , _ > (cursor , source , last_idx , "_whitespace" , None) } }) } } extern "C" { fn tree_sitter_test () -> :: rust_sitter :: tree_sitter :: Language ; } pub fn language () -> :: rust_sitter :: tree_sitter :: Language { unsafe { tree_sitter_test () } } # [doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] # [doc = "[`NumberList`]"] # [doc = r" instance containing the parsed structured data."] pub fn parse (input : & str) -> core :: result :: Result < NumberList , Vec < :: rust_sitter :: errors :: ParseError > > { :: rust_sitter :: __private :: parse :: < NumberList > (input , language) } } [INFO] [stdout] ────────────┴─────────────────────────────────────────────────────────────────── [INFO] [stdout] [INFO] [stdout] thread 'tests::spanned_in_vec' (30) panicked at src/lib.rs:504:9: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileIo(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }, "/opt/rustwide/workdir/src/snapshots/rust_sitter_macro__tests__spanned_in_vec.snap.new") [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::libunwind::trace::h9ea1e07ac77a25d7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h72b75eb83b53d15a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x713ee9e7b1c2 - std::sys::backtrace::_print_fmt::h255777b7ec902439 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x713ee9e7b1c2 - ::fmt::h8a1ac49fcd7ee8ce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x713ee9eab40f - core::fmt::rt::Argument::fmt::h635cbf3c6754cc90 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x713ee9eab40f - core::fmt::write::hbdcc0ec4f1bab1db [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x713ee9e2c943 - std::io::default_write_fmt::h2580ece0d4b58e51 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x713ee9e2c943 - std::io::Write::write_fmt::hac9e42858f273b87 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x713ee9e41e92 - std::sys::backtrace::BacktraceLock::print::h052febbd86f7bf07 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x713ee9e4a2ba - std::panicking::default_hook::{{closure}}::h66aeee20dd470abb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x713ee9e4a14c - std::panicking::default_hook::h9d66b9642014ce48 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6289ebb7161e - as core::ops::function::Fn>::call::h8c698701e444e564 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 12: 0x6289ebb7161e - test::test_main_with_exit_callback::{{closure}}::ha1c98e7b69c4defb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x713ee9e4a96f - as core::ops::function::Fn>::call::hc4f222a8a57c637a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 14: 0x713ee9e4a96f - std::panicking::panic_with_hook::h6d5921a1a1fa5a8e [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x713ee9e4a71a - std::panicking::panic_handler::{{closure}}::hafeef6f707d43542 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x713ee9e41fc9 - std::sys::backtrace::__rust_end_short_backtrace::h08cbc3319a3d0120 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x713ee9e1e4ad - __rustc[ce5c411ff86ab1b2]::rust_begin_unwind [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x713ee9ebb410 - core::panicking::panic_fmt::h774fb860369a0f7b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x713ee9eb9d56 - core::result::unwrap_failed::h72ee8fcbf1bf8ff9 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x6289eba35118 - core::result::Result::unwrap::h85aa971974d63926 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x6289eba35118 - rust_sitter_macro::tests::spanned_in_vec::h7cb0d23af6e9767d [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:504:9 [INFO] [stdout] 22: 0x6289eba3531d - rust_sitter_macro::tests::spanned_in_vec::{{closure}}::hb27ad66b912e9e6c [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:503:28 [INFO] [stdout] 23: 0x6289eba45f76 - core::ops::function::FnOnce::call_once::h55eed91760506c70 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6289ebb7146b - core::ops::function::FnOnce::call_once::h4f6eabe90cccb47d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x6289ebb7146b - test::__rust_begin_short_backtrace::h94208530f2b4c8c7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x6289ebb8547d - test::run_test_in_process::{{closure}}::hbdc6a45a78c46404 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x6289ebb8547d - as core::ops::function::FnOnce<()>>::call_once::h7f9d8efc7eedd165 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x6289ebb8547d - std::panicking::catch_unwind::do_call::he5edbaf126c13b99 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x6289ebb8547d - std::panicking::catch_unwind::h3d6a8652eceeabce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x6289ebb8547d - std::panic::catch_unwind::hbef0c501dd7bb498 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x6289ebb8547d - test::run_test_in_process::h400008a46a5006a0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x6289ebb8547d - test::run_test::{{closure}}::h9a131655b31d9427 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x6289ebb5e9c4 - test::run_test::{{closure}}::he4a7177c216308c0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x6289ebb5e9c4 - std::sys::backtrace::__rust_begin_short_backtrace::hd3980e9c55d6c539 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h18552df67c7aa9b8 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 36: 0x6289ebb622fa - as core::ops::function::FnOnce<()>>::call_once::h3d7b285234641a08 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x6289ebb622fa - std::panicking::catch_unwind::do_call::h5a2b5cf36528a5b2 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x6289ebb622fa - std::panicking::catch_unwind::h7e8b531bbda77d20 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x6289ebb622fa - std::panic::catch_unwind::hf9bbb2040b4f1e6c [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::h600f92cf68549574 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 41: 0x6289ebb622fa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb6607307df8a1847 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x713ee9e3c8ef - as core::ops::function::FnOnce>::call_once::h6891ad53a5ed6f52 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2085:9 [INFO] [stdout] 43: 0x713ee9e3c8ef - std::sys::thread::unix::Thread::new::thread_start::h7f3e77fa86df70af [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/thread/unix.rs:124:17 [INFO] [stdout] 44: 0x713ee9bd6aa4 - [INFO] [stdout] 45: 0x713ee9c63a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- tests::struct_repeat stdout ---- [INFO] [stdout] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Snapshot Summary ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ [INFO] [stdout] Snapshot file: src/snapshots/rust_sitter_macro__tests__struct_repeat.snap [INFO] [stdout] Snapshot: struct_repeat [INFO] [stdout] Source: src/lib.rs:394 [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] Expression: rustfmt_code(&expand_grammar(parse_quote! [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::grammar("test")] mod grammar [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::language] pub struct NumberList [INFO] [stdout] { numbers: Vec, } pub struct Number [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::leaf(pattern = r"\d+", transform = |v| [INFO] [stdout] v.parse().unwrap())] v: i32 [INFO] [stdout] } #[rust_sitter::extra] struct Whitespace [INFO] [stdout] { #[rust_sitter::leaf(pattern = r"\s")] _whitespace: (), } [INFO] [stdout] } [INFO] [stdout] })? .to_token_stream().to_string()) [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] -old snapshot [INFO] [stdout] +new results [INFO] [stdout] ────────────┬─────────────────────────────────────────────────────────────────── [INFO] [stdout] 0 │-mod grammar { [INFO] [stdout] 1 │- pub struct NumberList { [INFO] [stdout] 2 │- numbers: Vec, [INFO] [stdout] 3 │- } [INFO] [stdout] 4 │- impl ::rust_sitter::Extract for NumberList { [INFO] [stdout] 5 │- type LeafFn = (); [INFO] [stdout] 6 │- #[allow(non_snake_case)] [INFO] [stdout] 7 │- fn extract( [INFO] [stdout] 8 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 9 │- source: &[u8], [INFO] [stdout] 10 │- last_idx: usize, [INFO] [stdout] 11 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 12 │- ) -> Self { [INFO] [stdout] 13 │- let node = node.unwrap(); [INFO] [stdout] 14 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 15 │- NumberList { [INFO] [stdout] 16 │- numbers: { [INFO] [stdout] 17 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 18 │- cursor, source, last_idx, "numbers", None, [INFO] [stdout] 19 │- ) [INFO] [stdout] 20 │- }, [INFO] [stdout] 21 │- } [INFO] [stdout] 22 │- }) [INFO] [stdout] 23 │- } [INFO] [stdout] 24 │- } [INFO] [stdout] 25 │- pub struct Number { [INFO] [stdout] 26 │- v: i32, [INFO] [stdout] 27 │- } [INFO] [stdout] 28 │- impl ::rust_sitter::Extract for Number { [INFO] [stdout] 29 │- type LeafFn = (); [INFO] [stdout] 30 │- #[allow(non_snake_case)] [INFO] [stdout] 31 │- fn extract( [INFO] [stdout] 32 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 33 │- source: &[u8], [INFO] [stdout] 34 │- last_idx: usize, [INFO] [stdout] 35 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 36 │- ) -> Self { [INFO] [stdout] 37 │- let node = node.unwrap(); [INFO] [stdout] 38 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 39 │- Number { [INFO] [stdout] 40 │- v: { [INFO] [stdout] 41 │- ::rust_sitter::__private::extract_field::, _>( [INFO] [stdout] 42 │- cursor, [INFO] [stdout] 43 │- source, [INFO] [stdout] 44 │- last_idx, [INFO] [stdout] 45 │- "v", [INFO] [stdout] 46 │- Some(&|v| v.parse().unwrap()), [INFO] [stdout] 47 │- ) [INFO] [stdout] 48 │- }, [INFO] [stdout] 49 │- } [INFO] [stdout] 50 │- }) [INFO] [stdout] 51 │- } [INFO] [stdout] 52 │- } [INFO] [stdout] 53 │- struct Whitespace { [INFO] [stdout] 54 │- _whitespace: (), [INFO] [stdout] 55 │- } [INFO] [stdout] 56 │- impl ::rust_sitter::Extract for Whitespace { [INFO] [stdout] 57 │- type LeafFn = (); [INFO] [stdout] 58 │- #[allow(non_snake_case)] [INFO] [stdout] 59 │- fn extract( [INFO] [stdout] 60 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 61 │- source: &[u8], [INFO] [stdout] 62 │- last_idx: usize, [INFO] [stdout] 63 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 64 │- ) -> Self { [INFO] [stdout] 65 │- let node = node.unwrap(); [INFO] [stdout] 66 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 67 │- Whitespace { [INFO] [stdout] 68 │- _whitespace: { [INFO] [stdout] 69 │- ::rust_sitter::__private::extract_field::<(), _>( [INFO] [stdout] 70 │- cursor, [INFO] [stdout] 71 │- source, [INFO] [stdout] 72 │- last_idx, [INFO] [stdout] 73 │- "_whitespace", [INFO] [stdout] 74 │- None, [INFO] [stdout] 75 │- ) [INFO] [stdout] 76 │- }, [INFO] [stdout] 77 │- } [INFO] [stdout] 78 │- }) [INFO] [stdout] 79 │- } [INFO] [stdout] 80 │- } [INFO] [stdout] 81 │- extern "C" { [INFO] [stdout] 82 │- fn tree_sitter_test() -> ::rust_sitter::tree_sitter::Language; [INFO] [stdout] 83 │- } [INFO] [stdout] 84 │- pub fn language() -> ::rust_sitter::tree_sitter::Language { [INFO] [stdout] 85 │- unsafe { tree_sitter_test() } [INFO] [stdout] 86 │- } [INFO] [stdout] 87 │- #[doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] [INFO] [stdout] 88 │- #[doc = "[`NumberList`]"] [INFO] [stdout] 89 │- #[doc = r" instance containing the parsed structured data."] [INFO] [stdout] 90 │- pub fn parse( [INFO] [stdout] 91 │- input: &str, [INFO] [stdout] 92 │- ) -> core::result::Result> { [INFO] [stdout] 93 │- ::rust_sitter::__private::parse::(input, language) [INFO] [stdout] 94 │- } [INFO] [stdout] 95 │-} [INFO] [stdout] 0 │+mod grammar { pub struct NumberList { numbers : Vec < Number > , } impl :: rust_sitter :: Extract < NumberList > for NumberList { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | NumberList { numbers : { :: rust_sitter :: __private :: extract_field :: < Vec < Number > , _ > (cursor , source , last_idx , "numbers" , None) } }) } } pub struct Number { v : i32 } impl :: rust_sitter :: Extract < Number > for Number { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Number { v : { :: rust_sitter :: __private :: extract_field :: < rust_sitter :: WithLeaf < i32 > , _ > (cursor , source , last_idx , "v" , Some (& | v | v . parse () . unwrap ())) } }) } } struct Whitespace { _whitespace : () , } impl :: rust_sitter :: Extract < Whitespace > for Whitespace { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Whitespace { _whitespace : { :: rust_sitter :: __private :: extract_field :: < () , _ > (cursor , source , last_idx , "_whitespace" , None) } }) } } extern "C" { fn tree_sitter_test () -> :: rust_sitter :: tree_sitter :: Language ; } pub fn language () -> :: rust_sitter :: tree_sitter :: Language { unsafe { tree_sitter_test () } } # [doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] # [doc = "[`NumberList`]"] # [doc = r" instance containing the parsed structured data."] pub fn parse (input : & str) -> core :: result :: Result < NumberList , Vec < :: rust_sitter :: errors :: ParseError > > { :: rust_sitter :: __private :: parse :: < NumberList > (input , language) } } [INFO] [stdout] ────────────┴─────────────────────────────────────────────────────────────────── [INFO] [stdout] [INFO] [stdout] thread 'tests::struct_repeat' (33) panicked at src/lib.rs:394:9: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileIo(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }, "/opt/rustwide/workdir/src/snapshots/rust_sitter_macro__tests__struct_repeat.snap.new") [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::libunwind::trace::h9ea1e07ac77a25d7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h72b75eb83b53d15a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x713ee9e7b1c2 - std::sys::backtrace::_print_fmt::h255777b7ec902439 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x713ee9e7b1c2 - ::fmt::h8a1ac49fcd7ee8ce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x713ee9eab40f - core::fmt::rt::Argument::fmt::h635cbf3c6754cc90 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x713ee9eab40f - core::fmt::write::hbdcc0ec4f1bab1db [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x713ee9e2c943 - std::io::default_write_fmt::h2580ece0d4b58e51 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x713ee9e2c943 - std::io::Write::write_fmt::hac9e42858f273b87 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x713ee9e41e92 - std::sys::backtrace::BacktraceLock::print::h052febbd86f7bf07 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x713ee9e4a2ba - std::panicking::default_hook::{{closure}}::h66aeee20dd470abb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x713ee9e4a14c - std::panicking::default_hook::h9d66b9642014ce48 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6289ebb7161e - as core::ops::function::Fn>::call::h8c698701e444e564 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 12: 0x6289ebb7161e - test::test_main_with_exit_callback::{{closure}}::ha1c98e7b69c4defb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x713ee9e4a96f - as core::ops::function::Fn>::call::hc4f222a8a57c637a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 14: 0x713ee9e4a96f - std::panicking::panic_with_hook::h6d5921a1a1fa5a8e [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x713ee9e4a71a - std::panicking::panic_handler::{{closure}}::hafeef6f707d43542 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x713ee9e41fc9 - std::sys::backtrace::__rust_end_short_backtrace::h08cbc3319a3d0120 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x713ee9e1e4ad - __rustc[ce5c411ff86ab1b2]::rust_begin_unwind [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x713ee9ebb410 - core::panicking::panic_fmt::h774fb860369a0f7b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x713ee9eb9d56 - core::result::unwrap_failed::h72ee8fcbf1bf8ff9 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x6289eba31160 - core::result::Result::unwrap::h85aa971974d63926 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x6289eba31160 - rust_sitter_macro::tests::struct_repeat::h32527b2d8fe0e04a [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:394:9 [INFO] [stdout] 22: 0x6289eba312bd - rust_sitter_macro::tests::struct_repeat::{{closure}}::h07bfaf6a58e6a751 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:393:27 [INFO] [stdout] 23: 0x6289eba46056 - core::ops::function::FnOnce::call_once::h6d0cb4562407388b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6289ebb7146b - core::ops::function::FnOnce::call_once::h4f6eabe90cccb47d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x6289ebb7146b - test::__rust_begin_short_backtrace::h94208530f2b4c8c7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x6289ebb8547d - test::run_test_in_process::{{closure}}::hbdc6a45a78c46404 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x6289ebb8547d - as core::ops::function::FnOnce<()>>::call_once::h7f9d8efc7eedd165 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x6289ebb8547d - std::panicking::catch_unwind::do_call::he5edbaf126c13b99 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x6289ebb8547d - std::panicking::catch_unwind::h3d6a8652eceeabce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x6289ebb8547d - std::panic::catch_unwind::hbef0c501dd7bb498 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x6289ebb8547d - test::run_test_in_process::h400008a46a5006a0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x6289ebb8547d - test::run_test::{{closure}}::h9a131655b31d9427 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x6289ebb5e9c4 - test::run_test::{{closure}}::he4a7177c216308c0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x6289ebb5e9c4 - std::sys::backtrace::__rust_begin_short_backtrace::hd3980e9c55d6c539 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h18552df67c7aa9b8 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 36: 0x6289ebb622fa - as core::ops::function::FnOnce<()>>::call_once::h3d7b285234641a08 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x6289ebb622fa - std::panicking::catch_unwind::do_call::h5a2b5cf36528a5b2 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x6289ebb622fa - std::panicking::catch_unwind::h7e8b531bbda77d20 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x6289ebb622fa - std::panic::catch_unwind::hf9bbb2040b4f1e6c [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::h600f92cf68549574 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 41: 0x6289ebb622fa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb6607307df8a1847 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x713ee9e3c8ef - as core::ops::function::FnOnce>::call_once::h6891ad53a5ed6f52 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2085:9 [INFO] [stdout] 43: 0x713ee9e3c8ef - std::sys::thread::unix::Thread::new::thread_start::h7f3e77fa86df70af [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/thread/unix.rs:124:17 [INFO] [stdout] 44: 0x713ee9bd6aa4 - [INFO] [stdout] 45: 0x713ee9c63a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- tests::struct_extra stdout ---- [INFO] [stdout] ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ Snapshot Summary ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ [INFO] [stdout] Snapshot file: src/snapshots/rust_sitter_macro__tests__struct_extra.snap [INFO] [stdout] Snapshot: struct_extra [INFO] [stdout] Source: src/lib.rs:341 [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] Expression: rustfmt_code(&expand_grammar(parse_quote! [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::grammar("test")] mod grammar [INFO] [stdout] { [INFO] [stdout] #[rust_sitter::language] pub enum Expression [INFO] [stdout] { [INFO] [stdout] Number(#[rust_sitter::leaf(pattern = r"\d+", transform = |v| [INFO] [stdout] v.parse().unwrap())] i32,), [INFO] [stdout] } #[rust_sitter::extra] struct Whitespace [INFO] [stdout] { #[rust_sitter::leaf(pattern = r"\s")] _whitespace: (), } [INFO] [stdout] } [INFO] [stdout] })? .to_token_stream().to_string()) [INFO] [stdout] ──────────────────────────────────────────────────────────────────────────────── [INFO] [stdout] -old snapshot [INFO] [stdout] +new results [INFO] [stdout] ────────────┬─────────────────────────────────────────────────────────────────── [INFO] [stdout] 0 │-mod grammar { [INFO] [stdout] 1 │- pub enum Expression { [INFO] [stdout] 2 │- Number(i32), [INFO] [stdout] 3 │- } [INFO] [stdout] 4 │- impl ::rust_sitter::Extract for Expression { [INFO] [stdout] 5 │- type LeafFn = (); [INFO] [stdout] 6 │- #[allow(non_snake_case)] [INFO] [stdout] 7 │- fn extract( [INFO] [stdout] 8 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 9 │- source: &[u8], [INFO] [stdout] 10 │- _last_idx: usize, [INFO] [stdout] 11 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 12 │- ) -> Self { [INFO] [stdout] 13 │- let node = node.unwrap(); [INFO] [stdout] 14 │- let mut cursor = node.walk(); [INFO] [stdout] 15 │- assert!( [INFO] [stdout] 16 │- cursor.goto_first_child(), [INFO] [stdout] 17 │- "Could not find a child corresponding to any enum branch" [INFO] [stdout] 18 │- ); [INFO] [stdout] 19 │- loop { [INFO] [stdout] 20 │- let node = cursor.node(); [INFO] [stdout] 21 │- match node.kind() { [INFO] [stdout] 22 │- "Expression_Number" => { [INFO] [stdout] 23 │- return ::rust_sitter::__private::extract_struct_or_variant( [INFO] [stdout] 24 │- node, [INFO] [stdout] 25 │- move |cursor, last_idx| { [INFO] [stdout] 26 │- Expression::Number({ [INFO] [stdout] 27 │- ::rust_sitter::__private::extract_field::< [INFO] [stdout] 28 │- rust_sitter::WithLeaf, [INFO] [stdout] 29 │- _, [INFO] [stdout] 30 │- >( [INFO] [stdout] 31 │- cursor, source, last_idx, "0", Some(&|v| v.parse().unwrap()) [INFO] [stdout] 32 │- ) [INFO] [stdout] 33 │- }) [INFO] [stdout] 34 │- }, [INFO] [stdout] 35 │- ) [INFO] [stdout] 36 │- } [INFO] [stdout] 37 │- _ => { [INFO] [stdout] 38 │- if !cursor.goto_next_sibling() { [INFO] [stdout] 39 │- panic!("Could not find a child corresponding to any enum branch") [INFO] [stdout] 40 │- } [INFO] [stdout] 41 │- } [INFO] [stdout] 42 │- } [INFO] [stdout] 43 │- } [INFO] [stdout] 44 │- } [INFO] [stdout] 45 │- } [INFO] [stdout] 46 │- struct Whitespace { [INFO] [stdout] 47 │- _whitespace: (), [INFO] [stdout] 48 │- } [INFO] [stdout] 49 │- impl ::rust_sitter::Extract for Whitespace { [INFO] [stdout] 50 │- type LeafFn = (); [INFO] [stdout] 51 │- #[allow(non_snake_case)] [INFO] [stdout] 52 │- fn extract( [INFO] [stdout] 53 │- node: Option<::rust_sitter::tree_sitter::Node>, [INFO] [stdout] 54 │- source: &[u8], [INFO] [stdout] 55 │- last_idx: usize, [INFO] [stdout] 56 │- _leaf_fn: Option<&Self::LeafFn>, [INFO] [stdout] 57 │- ) -> Self { [INFO] [stdout] 58 │- let node = node.unwrap(); [INFO] [stdout] 59 │- ::rust_sitter::__private::extract_struct_or_variant(node, move |cursor, last_idx| { [INFO] [stdout] 60 │- Whitespace { [INFO] [stdout] 61 │- _whitespace: { [INFO] [stdout] 62 │- ::rust_sitter::__private::extract_field::<(), _>( [INFO] [stdout] 63 │- cursor, [INFO] [stdout] 64 │- source, [INFO] [stdout] 65 │- last_idx, [INFO] [stdout] 66 │- "_whitespace", [INFO] [stdout] 67 │- None, [INFO] [stdout] 68 │- ) [INFO] [stdout] 69 │- }, [INFO] [stdout] 70 │- } [INFO] [stdout] 71 │- }) [INFO] [stdout] 72 │- } [INFO] [stdout] 73 │- } [INFO] [stdout] 74 │- extern "C" { [INFO] [stdout] 75 │- fn tree_sitter_test() -> ::rust_sitter::tree_sitter::Language; [INFO] [stdout] 76 │- } [INFO] [stdout] 77 │- pub fn language() -> ::rust_sitter::tree_sitter::Language { [INFO] [stdout] 78 │- unsafe { tree_sitter_test() } [INFO] [stdout] 79 │- } [INFO] [stdout] 80 │- #[doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] [INFO] [stdout] 81 │- #[doc = "[`Expression`]"] [INFO] [stdout] 82 │- #[doc = r" instance containing the parsed structured data."] [INFO] [stdout] 83 │- pub fn parse( [INFO] [stdout] 84 │- input: &str, [INFO] [stdout] 85 │- ) -> core::result::Result> { [INFO] [stdout] 86 │- ::rust_sitter::__private::parse::(input, language) [INFO] [stdout] 87 │- } [INFO] [stdout] 88 │-} [INFO] [stdout] 0 │+mod grammar { pub enum Expression { Number (i32 ,) , } impl :: rust_sitter :: Extract < Expression > for Expression { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , _last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; let mut cursor = node . walk () ; assert ! (cursor . goto_first_child () , "Could not find a child corresponding to any enum branch") ; loop { let node = cursor . node () ; match node . kind () { "Expression_Number" => return :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Expression :: Number ({ :: rust_sitter :: __private :: extract_field :: < rust_sitter :: WithLeaf < i32 > , _ > (cursor , source , last_idx , "0" , Some (& | v | v . parse () . unwrap ())) })) , _ => if ! cursor . goto_next_sibling () { panic ! ("Could not find a child corresponding to any enum branch") } } } } } struct Whitespace { _whitespace : () , } impl :: rust_sitter :: Extract < Whitespace > for Whitespace { type LeafFn = () ; # [allow (non_snake_case)] fn extract (node : Option < :: rust_sitter :: tree_sitter :: Node > , source : & [u8] , last_idx : usize , _leaf_fn : Option < & Self :: LeafFn >) -> Self { let node = node . unwrap () ; :: rust_sitter :: __private :: extract_struct_or_variant (node , move | cursor , last_idx | Whitespace { _whitespace : { :: rust_sitter :: __private :: extract_field :: < () , _ > (cursor , source , last_idx , "_whitespace" , None) } }) } } extern "C" { fn tree_sitter_test () -> :: rust_sitter :: tree_sitter :: Language ; } pub fn language () -> :: rust_sitter :: tree_sitter :: Language { unsafe { tree_sitter_test () } } # [doc = r" Parse an input string according to the grammar. Returns either any parsing errors that happened, or a"] # [doc = "[`Expression`]"] # [doc = r" instance containing the parsed structured data."] pub fn parse (input : & str) -> core :: result :: Result < Expression , Vec < :: rust_sitter :: errors :: ParseError > > { :: rust_sitter :: __private :: parse :: < Expression > (input , language) } } [INFO] [stdout] ────────────┴─────────────────────────────────────────────────────────────────── [INFO] [stdout] [INFO] [stdout] thread 'tests::struct_extra' (31) panicked at src/lib.rs:341:9: [INFO] [stdout] called `Result::unwrap()` on an `Err` value: FileIo(Os { code: 30, kind: ReadOnlyFilesystem, message: "Read-only file system" }, "/opt/rustwide/workdir/src/snapshots/rust_sitter_macro__tests__struct_extra.snap.new") [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::libunwind::trace::h9ea1e07ac77a25d7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x713ee9e7b1c2 - std::backtrace_rs::backtrace::trace_unsynchronized::h72b75eb83b53d15a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x713ee9e7b1c2 - std::sys::backtrace::_print_fmt::h255777b7ec902439 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x713ee9e7b1c2 - ::fmt::h8a1ac49fcd7ee8ce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x713ee9eab40f - core::fmt::rt::Argument::fmt::h635cbf3c6754cc90 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x713ee9eab40f - core::fmt::write::hbdcc0ec4f1bab1db [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/fmt/mod.rs:1469:25 [INFO] [stdout] 6: 0x713ee9e2c943 - std::io::default_write_fmt::h2580ece0d4b58e51 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x713ee9e2c943 - std::io::Write::write_fmt::hac9e42858f273b87 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x713ee9e41e92 - std::sys::backtrace::BacktraceLock::print::h052febbd86f7bf07 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x713ee9e4a2ba - std::panicking::default_hook::{{closure}}::h66aeee20dd470abb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x713ee9e4a14c - std::panicking::default_hook::h9d66b9642014ce48 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x6289ebb7161e - as core::ops::function::Fn>::call::h8c698701e444e564 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 12: 0x6289ebb7161e - test::test_main_with_exit_callback::{{closure}}::ha1c98e7b69c4defb [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x713ee9e4a96f - as core::ops::function::Fn>::call::hc4f222a8a57c637a [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2099:9 [INFO] [stdout] 14: 0x713ee9e4a96f - std::panicking::panic_with_hook::h6d5921a1a1fa5a8e [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x713ee9e4a71a - std::panicking::panic_handler::{{closure}}::hafeef6f707d43542 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x713ee9e41fc9 - std::sys::backtrace::__rust_end_short_backtrace::h08cbc3319a3d0120 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x713ee9e1e4ad - __rustc[ce5c411ff86ab1b2]::rust_begin_unwind [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x713ee9ebb410 - core::panicking::panic_fmt::h774fb860369a0f7b [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panicking.rs:80:14 [INFO] [stdout] 19: 0x713ee9eb9d56 - core::result::unwrap_failed::h72ee8fcbf1bf8ff9 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1862:5 [INFO] [stdout] 20: 0x6289eba2fbd7 - core::result::Result::unwrap::h85aa971974d63926 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/result.rs:1233:23 [INFO] [stdout] 21: 0x6289eba2fbd7 - rust_sitter_macro::tests::struct_extra::h894fc932f836de13 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:341:9 [INFO] [stdout] 22: 0x6289eba2fddd - rust_sitter_macro::tests::struct_extra::{{closure}}::h219ac9e6d8bd6754 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:340:26 [INFO] [stdout] 23: 0x6289eba45ef6 - core::ops::function::FnOnce::call_once::h4039e55c042d9c04 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x6289ebb7146b - core::ops::function::FnOnce::call_once::h4f6eabe90cccb47d [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x6289ebb7146b - test::__rust_begin_short_backtrace::h94208530f2b4c8c7 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x6289ebb8547d - test::run_test_in_process::{{closure}}::hbdc6a45a78c46404 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x6289ebb8547d - as core::ops::function::FnOnce<()>>::call_once::h7f9d8efc7eedd165 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x6289ebb8547d - std::panicking::catch_unwind::do_call::he5edbaf126c13b99 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x6289ebb8547d - std::panicking::catch_unwind::h3d6a8652eceeabce [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x6289ebb8547d - std::panic::catch_unwind::hbef0c501dd7bb498 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x6289ebb8547d - test::run_test_in_process::h400008a46a5006a0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x6289ebb8547d - test::run_test::{{closure}}::h9a131655b31d9427 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x6289ebb5e9c4 - test::run_test::{{closure}}::he4a7177c216308c0 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x6289ebb5e9c4 - std::sys::backtrace::__rust_begin_short_backtrace::hd3980e9c55d6c539 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h18552df67c7aa9b8 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:562:17 [INFO] [stdout] 36: 0x6289ebb622fa - as core::ops::function::FnOnce<()>>::call_once::h3d7b285234641a08 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x6289ebb622fa - std::panicking::catch_unwind::do_call::h5a2b5cf36528a5b2 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x6289ebb622fa - std::panicking::catch_unwind::h7e8b531bbda77d20 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x6289ebb622fa - std::panic::catch_unwind::hf9bbb2040b4f1e6c [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x6289ebb622fa - std::thread::Builder::spawn_unchecked_::{{closure}}::h600f92cf68549574 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/thread/mod.rs:560:30 [INFO] [stdout] 41: 0x6289ebb622fa - core::ops::function::FnOnce::call_once{{vtable.shim}}::hb6607307df8a1847 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x713ee9e3c8ef - as core::ops::function::FnOnce>::call_once::h6891ad53a5ed6f52 [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/alloc/src/boxed.rs:2085:9 [INFO] [stdout] 43: 0x713ee9e3c8ef - std::sys::thread::unix::Thread::new::thread_start::h7f3e77fa86df70af [INFO] [stdout] at /rustc/c2e32f1c9652b13ed99608599c1e855462f421f3/library/std/src/sys/thread/unix.rs:124:17 [INFO] [stdout] 44: 0x713ee9bd6aa4 - [INFO] [stdout] 45: 0x713ee9c63a64 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] tests::enum_prec_left [INFO] [stdout] tests::enum_recursive [INFO] [stdout] tests::enum_transformed_fields [INFO] [stdout] tests::enum_with_named_field [INFO] [stdout] tests::enum_with_unamed_vector [INFO] [stdout] tests::grammar_unboxed_field [INFO] [stdout] tests::spanned_in_vec [INFO] [stdout] tests::struct_extra [INFO] [stdout] tests::struct_optional [INFO] [stdout] tests::struct_repeat [INFO] [stdout] [INFO] [stdout] test result: FAILED. 0 passed; 10 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.37s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "56cf935f79444dcd6a31a5a8a15c9e9e17a0bdda6fe738911f41834feb5c109a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "56cf935f79444dcd6a31a5a8a15c9e9e17a0bdda6fe738911f41834feb5c109a", kill_on_drop: false }` [INFO] [stdout] 56cf935f79444dcd6a31a5a8a15c9e9e17a0bdda6fe738911f41834feb5c109a