[INFO] fetching crate rust-sitter-macro 0.4.5... [INFO] testing rust-sitter-macro-0.4.5 against beta-2025-09-21 for beta-1.91-3 [INFO] extracting crate rust-sitter-macro 0.4.5 into /workspace/builds/worker-4-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-4-tc2/source/Cargo.toml [INFO] validating manifest of crates.io crate rust-sitter-macro 0.4.5 on toolchain beta-2025-09-21 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+beta-2025-09-21" "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" "+beta-2025-09-21" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 253c12a8ebc2f8e1230bc456f3b681a0f69f2088b10058ae869ad79dc3f4c609 [INFO] running `Command { std: "docker" "start" "-a" "253c12a8ebc2f8e1230bc456f3b681a0f69f2088b10058ae869ad79dc3f4c609", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "253c12a8ebc2f8e1230bc456f3b681a0f69f2088b10058ae869ad79dc3f4c609", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "253c12a8ebc2f8e1230bc456f3b681a0f69f2088b10058ae869ad79dc3f4c609", kill_on_drop: false }` [INFO] [stdout] 253c12a8ebc2f8e1230bc456f3b681a0f69f2088b10058ae869ad79dc3f4c609 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 11834f8103906ae262a5bcef9c8a3e9a9b09d97cdc9868d37938a9e75620c518 [INFO] running `Command { std: "docker" "start" "-a" "11834f8103906ae262a5bcef9c8a3e9a9b09d97cdc9868d37938a9e75620c518", kill_on_drop: false }` [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 5.68s [INFO] running `Command { std: "docker" "inspect" "11834f8103906ae262a5bcef9c8a3e9a9b09d97cdc9868d37938a9e75620c518", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "11834f8103906ae262a5bcef9c8a3e9a9b09d97cdc9868d37938a9e75620c518", kill_on_drop: false }` [INFO] [stdout] 11834f8103906ae262a5bcef9c8a3e9a9b09d97cdc9868d37938a9e75620c518 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 5d8af65611e295a8dd969655f1430fdcc03d0b364f13502e689f43ce56ae220b [INFO] running `Command { std: "docker" "start" "-a" "5d8af65611e295a8dd969655f1430fdcc03d0b364f13502e689f43ce56ae220b", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.169 [INFO] [stderr] Compiling syn v2.0.98 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling once_cell v1.20.3 [INFO] [stderr] Compiling bitflags v2.8.0 [INFO] [stderr] Compiling linux-raw-sys v0.4.15 [INFO] [stderr] Compiling cfg-if v1.0.0 [INFO] [stderr] Compiling similar v2.7.0 [INFO] [stderr] Compiling linked-hash-map v0.5.6 [INFO] [stderr] Compiling getrandom v0.3.1 [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 10.27s [INFO] running `Command { std: "docker" "inspect" "5d8af65611e295a8dd969655f1430fdcc03d0b364f13502e689f43ce56ae220b", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5d8af65611e295a8dd969655f1430fdcc03d0b364f13502e689f43ce56ae220b", kill_on_drop: false }` [INFO] [stdout] 5d8af65611e295a8dd969655f1430fdcc03d0b364f13502e689f43ce56ae220b [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-4-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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2025-09-21" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] c9456d3bb58e1e67bfea73332a477720b1e33dfc523b2e19d3f6ea9b09755b45 [INFO] running `Command { std: "docker" "start" "-a" "c9456d3bb58e1e67bfea73332a477720b1e33dfc523b2e19d3f6ea9b09755b45", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.05s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/rust_sitter_macro-12a34b6c318ef14e) [INFO] [stdout] [INFO] [stdout] running 10 tests [INFO] [stderr] error: 'rustfmt' is not installed for the toolchain 'beta-2025-09-21-x86_64-unknown-linux-gnu'. [INFO] [stderr] To install, run `rustup component add --toolchain beta-2025-09-21-x86_64-unknown-linux-gnu rustfmt` [INFO] [stderr] error: 'rustfmt' is not installed for the toolchain 'beta-2025-09-21-x86_64-unknown-linux-gnu'. [INFO] [stderr] To install, run `rustup component add --toolchain beta-2025-09-21-x86_64-unknown-linux-gnu rustfmt` [INFO] [stderr] error: 'rustfmt' is not installed for the toolchain 'beta-2025-09-21-x86_64-unknown-linux-gnu'. [INFO] [stderr] To install, run `rustup component add --toolchain beta-2025-09-21-x86_64-unknown-linux-gnu rustfmt` [INFO] [stderr] error: 'rustfmt' is not installed for the toolchain 'beta-2025-09-21-x86_64-unknown-linux-gnu'. [INFO] [stderr] To install, run `rustup component add --toolchain beta-2025-09-21-x86_64-unknown-linux-gnu rustfmt` [INFO] [stderr] error: 'rustfmt' is not installed for the toolchain 'beta-2025-09-21-x86_64-unknown-linux-gnu'. [INFO] [stderr] To install, run `rustup component add --toolchain beta-2025-09-21-x86_64-unknown-linux-gnu rustfmt` [INFO] [stderr] error: 'rustfmt' is not installed for the toolchain 'beta-2025-09-21-x86_64-unknown-linux-gnu'. [INFO] [stderr] To install, run `rustup component add --toolchain beta-2025-09-21-x86_64-unknown-linux-gnu rustfmt` [INFO] [stderr] error: 'rustfmt' is not installed for the toolchain 'beta-2025-09-21-x86_64-unknown-linux-gnu'. [INFO] [stderr] To install, run `rustup component add --toolchain beta-2025-09-21-x86_64-unknown-linux-gnu rustfmt` [INFO] [stderr] error: 'rustfmt' is not installed for the toolchain 'beta-2025-09-21-x86_64-unknown-linux-gnu'. [INFO] [stderr] To install, run `rustup component add --toolchain beta-2025-09-21-x86_64-unknown-linux-gnu rustfmt` [INFO] [stderr] error: 'rustfmt' is not installed for the toolchain 'beta-2025-09-21-x86_64-unknown-linux-gnu'. [INFO] [stderr] To install, run `rustup component add --toolchain beta-2025-09-21-x86_64-unknown-linux-gnu rustfmt` [INFO] [stderr] error: 'rustfmt' is not installed for the toolchain 'beta-2025-09-21-x86_64-unknown-linux-gnu'. [INFO] [stderr] To install, run `rustup component add --toolchain beta-2025-09-21-x86_64-unknown-linux-gnu rustfmt` [INFO] [stdout] test tests::struct_optional ... FAILED [INFO] [stdout] test tests::enum_prec_left ... FAILED [INFO] [stdout] test tests::enum_recursive ... FAILED [INFO] [stdout] test tests::enum_with_named_field ... FAILED [INFO] [stdout] test tests::struct_repeat ... FAILED [INFO] [stdout] test tests::grammar_unboxed_field ... FAILED [INFO] [stdout] test tests::spanned_in_vec ... FAILED [INFO] [stdout] test tests::enum_transformed_fields ... FAILED [INFO] [stdout] test tests::struct_extra ... FAILED [INFO] [stdout] test tests::enum_with_unamed_vector ... 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' (33) 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: 0x70c714f173e2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x70c714f173e2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x70c714f173e2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x70c714f173e2 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x70c714f4835f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x70c714f4835f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x70c714ec8d31 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x70c714ec8d31 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x70c714eddd22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x70c714ee5fea - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x70c714ee5e7c - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x564a8299037e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x564a8299037e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x70c714ee674f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x70c714ee674f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x70c714ee64fa - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x70c714edde59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x70c714eb9ddd - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x70c714f58a00 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x70c714f57366 - core::result::unwrap_failed::hdde076be853d034f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5 [INFO] [stdout] 20: 0x564a8284f021 - core::result::Result::unwrap::h6e584d340bc3d345 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23 [INFO] [stdout] 21: 0x564a8284f021 - rust_sitter_macro::tests::struct_optional::hd6da1d3162283a7e [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:424:9 [INFO] [stdout] 22: 0x564a8284f21d - rust_sitter_macro::tests::struct_optional::{{closure}}::hb6afc86490fc1b10 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:423:29 [INFO] [stdout] 23: 0x564a82866846 - core::ops::function::FnOnce::call_once::h7b3388292dbbb499 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x564a8299013b - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x564a8299013b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x564a829a5da5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x564a829a5da5 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x564a829a5da5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x564a829a5da5 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x564a829a5da5 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x564a829a5da5 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x564a829a5da5 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x564a8297c594 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x564a8297c594 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x564a8297fe5a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x564a8297fe5a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x564a8297fe5a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x564a8297fe5a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x564a8297fe5a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x70c714ed84df - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x70c714ed84df - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 44: 0x70c714c73aa4 - [INFO] [stdout] 45: 0x70c714d00a34 - 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' (25) 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: 0x70c714f173e2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x70c714f173e2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x70c714f173e2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x70c714f173e2 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x70c714f4835f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x70c714f4835f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x70c714ec8d31 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x70c714ec8d31 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x70c714eddd22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x70c714ee5fea - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x70c714ee5e7c - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x564a8299037e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x564a8299037e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x70c714ee674f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x70c714ee674f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x70c714ee64fa - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x70c714edde59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x70c714eb9ddd - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x70c714f58a00 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x70c714f57366 - core::result::unwrap_failed::hdde076be853d034f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5 [INFO] [stdout] 20: 0x564a8284b0cc - core::result::Result::unwrap::h6e584d340bc3d345 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23 [INFO] [stdout] 21: 0x564a8284b0cc - rust_sitter_macro::tests::enum_prec_left::h97aa57c909fac501 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:312:9 [INFO] [stdout] 22: 0x564a8284b21d - rust_sitter_macro::tests::enum_prec_left::{{closure}}::h1e2dd7c574b4a37e [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:311:28 [INFO] [stdout] 23: 0x564a828668b6 - core::ops::function::FnOnce::call_once::h8e38376b9508741d [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x564a8299013b - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x564a8299013b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x564a829a5da5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x564a829a5da5 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x564a829a5da5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x564a829a5da5 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x564a829a5da5 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x564a829a5da5 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x564a829a5da5 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x564a8297c594 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x564a8297c594 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x564a8297fe5a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x564a8297fe5a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x564a8297fe5a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x564a8297fe5a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x564a8297fe5a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x70c714ed84df - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x70c714ed84df - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 44: 0x70c714c73aa4 - [INFO] [stdout] 45: 0x70c714d00a34 - 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' (26) 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: 0x70c714f173e2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x70c714f173e2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x70c714f173e2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x70c714f173e2 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x70c714f4835f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x70c714f4835f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x70c714ec8d31 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x70c714ec8d31 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x70c714eddd22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x70c714ee5fea - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x70c714ee5e7c - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x564a8299037e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x564a8299037e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x70c714ee674f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x70c714ee674f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x70c714ee64fa - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x70c714edde59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x70c714eb9ddd - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x70c714f58a00 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x70c714f57366 - core::result::unwrap_failed::hdde076be853d034f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5 [INFO] [stdout] 20: 0x564a8284c474 - core::result::Result::unwrap::h6e584d340bc3d345 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23 [INFO] [stdout] 21: 0x564a8284c474 - rust_sitter_macro::tests::enum_recursive::hc0ad80192edaa654 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:285:9 [INFO] [stdout] 22: 0x564a8284c5cd - rust_sitter_macro::tests::enum_recursive::{{closure}}::h204f46fc9269cf73 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:284:28 [INFO] [stdout] 23: 0x564a82866a16 - core::ops::function::FnOnce::call_once::he34c95009ab4acba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x564a8299013b - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x564a8299013b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x564a829a5da5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x564a829a5da5 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x564a829a5da5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x564a829a5da5 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x564a829a5da5 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x564a829a5da5 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x564a829a5da5 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x564a8297c594 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x564a8297c594 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x564a8297fe5a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x564a8297fe5a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x564a8297fe5a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x564a8297fe5a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x564a8297fe5a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x70c714ed84df - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x70c714ed84df - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 44: 0x70c714c73aa4 - [INFO] [stdout] 45: 0x70c714d00a34 - 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' (28) 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] [stdout] stack backtrace: [INFO] [stdout] 0: 0x70c714f173e2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x70c714f173e2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x70c714f173e2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x70c714f173e2 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x70c714f4835f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x70c714f4835f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x70c714ec8d31 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x70c714ec8d31 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x70c714eddd22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x70c714ee5fea - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x70c714ee5e7c - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x564a8299037e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x564a8299037e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x70c714ee674f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x70c714ee674f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x70c714ee64fa - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x70c714edde59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x70c714eb9ddd - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x70c714f58a00 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x70c714f57366 - core::result::unwrap_failed::hdde076be853d034f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5 [INFO] [stdout] 20: 0x564a8285043b - core::result::Result::unwrap::h6e584d340bc3d345 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23 [INFO] [stdout] 21: 0x564a8285043b - rust_sitter_macro::tests::enum_with_named_field::h16e741541513eeff [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:477:9 [INFO] [stdout] 22: 0x564a8285058d - rust_sitter_macro::tests::enum_with_named_field::{{closure}}::h6fbc3d108c996648 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:476:35 [INFO] [stdout] 23: 0x564a82866996 - core::ops::function::FnOnce::call_once::hcccef34cb7660af7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x564a8299013b - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x564a8299013b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x564a829a5da5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x564a829a5da5 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x564a829a5da5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x564a829a5da5 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x564a829a5da5 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x564a829a5da5 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x564a829a5da5 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x564a8297c594 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x564a8297c594 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x564a8297fe5a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x564a8297fe5a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x564a8297fe5a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x564a8297fe5a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x564a8297fe5a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x70c714ed84df - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x70c714ed84df - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 44: 0x70c714c73aa4 - [INFO] [stdout] 45: 0x70c714d00a34 - 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' (34) 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: 0x70c714f173e2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x70c714f173e2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x70c714f173e2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x70c714f173e2 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x70c714f4835f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x70c714f4835f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x70c714ec8d31 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x70c714ec8d31 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x70c714eddd22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x70c714ee5fea - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x70c714ee5e7c - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x564a8299037e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x564a8299037e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x70c714ee674f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x70c714ee674f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x70c714ee64fa - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x70c714edde59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x70c714eb9ddd - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x70c714f58a00 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x70c714f57366 - core::result::unwrap_failed::hdde076be853d034f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5 [INFO] [stdout] 20: 0x564a82849b20 - core::result::Result::unwrap::h6e584d340bc3d345 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23 [INFO] [stdout] 21: 0x564a82849b20 - rust_sitter_macro::tests::struct_repeat::h569190171f1bbe64 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:394:9 [INFO] [stdout] 22: 0x564a82849c7d - rust_sitter_macro::tests::struct_repeat::{{closure}}::h0237fe76c0402e7d [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:393:27 [INFO] [stdout] 23: 0x564a828669d6 - core::ops::function::FnOnce::call_once::he262592cafb656fe [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x564a8299013b - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x564a8299013b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x564a829a5da5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x564a829a5da5 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x564a829a5da5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x564a829a5da5 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x564a829a5da5 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x564a829a5da5 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x564a829a5da5 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x564a8297c594 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x564a8297c594 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x564a8297fe5a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x564a8297fe5a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x564a8297fe5a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x564a8297fe5a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x564a8297fe5a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x70c714ed84df - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x70c714ed84df - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 44: 0x70c714c73aa4 - [INFO] [stdout] 45: 0x70c714d00a34 - 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' (30) 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: 0x70c714f173e2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x70c714f173e2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x70c714f173e2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x70c714f173e2 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x70c714f4835f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x70c714f4835f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x70c714ec8d31 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x70c714ec8d31 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x70c714eddd22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x70c714ee5fea - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x70c714ee5e7c - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x564a8299037e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x564a8299037e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x70c714ee674f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x70c714ee674f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x70c714ee64fa - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x70c714edde59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x70c714eb9ddd - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x70c714f58a00 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x70c714f57366 - core::result::unwrap_failed::hdde076be853d034f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5 [INFO] [stdout] 20: 0x564a828516bf - core::result::Result::unwrap::h6e584d340bc3d345 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23 [INFO] [stdout] 21: 0x564a828516bf - rust_sitter_macro::tests::grammar_unboxed_field::hc5bb68dadadf1c79 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:368:9 [INFO] [stdout] 22: 0x564a8285181d - rust_sitter_macro::tests::grammar_unboxed_field::{{closure}}::h05946d9f5d2e3898 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:367:35 [INFO] [stdout] 23: 0x564a82866526 - core::ops::function::FnOnce::call_once::h00e9c3fbd0515c98 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x564a8299013b - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x564a8299013b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x564a829a5da5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x564a829a5da5 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x564a829a5da5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x564a829a5da5 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x564a829a5da5 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x564a829a5da5 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x564a829a5da5 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x564a8297c594 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x564a8297c594 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x564a8297fe5a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x564a8297fe5a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x564a8297fe5a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x564a8297fe5a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x564a8297fe5a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x70c714ed84df - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x70c714ed84df - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 44: 0x70c714c73aa4 - [INFO] [stdout] 45: 0x70c714d00a34 - 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' (31) 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: 0x70c714f173e2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x70c714f173e2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x70c714f173e2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x70c714f173e2 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x70c714f4835f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x70c714f4835f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x70c714ec8d31 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x70c714ec8d31 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x70c714eddd22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x70c714ee5fea - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x70c714ee5e7c - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x564a8299037e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x564a8299037e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x70c714ee674f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x70c714ee674f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x70c714ee64fa - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x70c714edde59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x70c714eb9ddd - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x70c714f58a00 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x70c714f57366 - core::result::unwrap_failed::hdde076be853d034f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5 [INFO] [stdout] 20: 0x564a8284daa8 - core::result::Result::unwrap::h6e584d340bc3d345 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23 [INFO] [stdout] 21: 0x564a8284daa8 - rust_sitter_macro::tests::spanned_in_vec::h0d9c8b310749f3a1 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:504:9 [INFO] [stdout] 22: 0x564a8284dbfd - rust_sitter_macro::tests::spanned_in_vec::{{closure}}::h69fcefaed6d51b64 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:503:28 [INFO] [stdout] 23: 0x564a82866666 - core::ops::function::FnOnce::call_once::h361f734a7bae117d [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x564a8299013b - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x564a8299013b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x564a829a5da5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x564a829a5da5 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x564a829a5da5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x564a829a5da5 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x564a829a5da5 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x564a829a5da5 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x564a829a5da5 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x564a8297c594 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x564a8297c594 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x564a8297fe5a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x564a8297fe5a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x564a8297fe5a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x564a8297fe5a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x564a8297fe5a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x70c714ed84df - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x70c714ed84df - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 44: 0x70c714c73aa4 - [INFO] [stdout] 45: 0x70c714d00a34 - 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' (27) 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: 0x70c714f173e2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x70c714f173e2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x70c714f173e2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x70c714f173e2 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x70c714f4835f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x70c714f4835f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x70c714ec8d31 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x70c714ec8d31 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x70c714eddd22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x70c714ee5fea - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x70c714ee5e7c - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x564a8299037e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x564a8299037e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x70c714ee674f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x70c714ee674f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x70c714ee64fa - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x70c714edde59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x70c714eb9ddd - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x70c714f58a00 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x70c714f57366 - core::result::unwrap_failed::hdde076be853d034f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5 [INFO] [stdout] 20: 0x564a828527ca - core::result::Result::unwrap::h6e584d340bc3d345 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23 [INFO] [stdout] 21: 0x564a828527ca - rust_sitter_macro::tests::enum_transformed_fields::h6e1b10cad3a8ed1b [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:263:9 [INFO] [stdout] 22: 0x564a828529bd - rust_sitter_macro::tests::enum_transformed_fields::{{closure}}::h79f08f69e55b7a1c [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:262:37 [INFO] [stdout] 23: 0x564a828667d6 - core::ops::function::FnOnce::call_once::h6650afcdfa930021 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x564a8299013b - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x564a8299013b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x564a829a5da5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x564a829a5da5 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x564a829a5da5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x564a829a5da5 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x564a829a5da5 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x564a829a5da5 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x564a829a5da5 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x564a8297c594 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x564a8297c594 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x564a8297fe5a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x564a8297fe5a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x564a8297fe5a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x564a8297fe5a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x564a8297fe5a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x70c714ed84df - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x70c714ed84df - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 44: 0x70c714c73aa4 - [INFO] [stdout] 45: 0x70c714d00a34 - 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' (32) 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: 0x70c714f173e2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x70c714f173e2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x70c714f173e2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x70c714f173e2 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x70c714f4835f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x70c714f4835f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x70c714ec8d31 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x70c714ec8d31 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x70c714eddd22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x70c714ee5fea - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x70c714ee5e7c - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x564a8299037e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x564a8299037e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x70c714ee674f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x70c714ee674f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x70c714ee64fa - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x70c714edde59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x70c714eb9ddd - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x70c714f58a00 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x70c714f57366 - core::result::unwrap_failed::hdde076be853d034f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5 [INFO] [stdout] 20: 0x564a828485a7 - core::result::Result::unwrap::h6e584d340bc3d345 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23 [INFO] [stdout] 21: 0x564a828485a7 - rust_sitter_macro::tests::struct_extra::h16492cd3a215bfc2 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:341:9 [INFO] [stdout] 22: 0x564a828486fd - rust_sitter_macro::tests::struct_extra::{{closure}}::h60a3060eb269ea78 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:340:26 [INFO] [stdout] 23: 0x564a82866796 - core::ops::function::FnOnce::call_once::h53cab8d683d7cf3e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x564a8299013b - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x564a8299013b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x564a829a5da5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x564a829a5da5 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x564a829a5da5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x564a829a5da5 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x564a829a5da5 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x564a829a5da5 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x564a829a5da5 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x564a8297c594 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x564a8297c594 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x564a8297fe5a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x564a8297fe5a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x564a8297fe5a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x564a8297fe5a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x564a8297fe5a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x70c714ed84df - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x70c714ed84df - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 44: 0x70c714c73aa4 - [INFO] [stdout] 45: 0x70c714d00a34 - 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' (29) 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: 0x70c714f173e2 - std::backtrace_rs::backtrace::libunwind::trace::hcab59e1e990fdc24 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x70c714f173e2 - std::backtrace_rs::backtrace::trace_unsynchronized::he24cc57f3d2f47b7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x70c714f173e2 - std::sys::backtrace::_print_fmt::hf8d65ede198eeb54 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x70c714f173e2 - ::fmt::h67edf0e4d33c343c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x70c714f4835f - core::fmt::rt::Argument::fmt::hef94184842aeafdd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x70c714f4835f - core::fmt::write::hcf0c66b48a8fa606 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x70c714ec8d31 - std::io::default_write_fmt::h69967ac0ba93195f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x70c714ec8d31 - std::io::Write::write_fmt::h8db9396209deaa1c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x70c714eddd22 - std::sys::backtrace::BacktraceLock::print::h07e5435aa717b414 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x70c714ee5fea - std::panicking::default_hook::{{closure}}::h91001850288db5f7 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x70c714ee5e7c - std::panicking::default_hook::h2346dbb704ef5512 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x564a8299037e - as core::ops::function::Fn>::call::h18383b2e29377420 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x564a8299037e - test::test_main_with_exit_callback::{{closure}}::h272d7ef99aef06dc [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x70c714ee674f - as core::ops::function::Fn>::call::h6dba6e441651a0d1 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x70c714ee674f - std::panicking::panic_with_hook::hd2b063a6090d23a4 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x70c714ee64fa - std::panicking::panic_handler::{{closure}}::he666d95f139a333e [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x70c714edde59 - std::sys::backtrace::__rust_end_short_backtrace::h631ad224854ebee5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x70c714eb9ddd - __rustc[1d67440d6e82e4f]::rust_begin_unwind [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x70c714f58a00 - core::panicking::panic_fmt::h420ddb7fd73daf53 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x70c714f57366 - core::result::unwrap_failed::hdde076be853d034f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1855:5 [INFO] [stdout] 20: 0x564a82853b81 - core::result::Result::unwrap::h6e584d340bc3d345 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/result.rs:1226:23 [INFO] [stdout] 21: 0x564a82853b81 - rust_sitter_macro::tests::enum_with_unamed_vector::h57976a7b7f048f98 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:450:9 [INFO] [stdout] 22: 0x564a82853cdd - rust_sitter_macro::tests::enum_with_unamed_vector::{{closure}}::h690045f5c786aaf8 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:449:37 [INFO] [stdout] 23: 0x564a828665f6 - core::ops::function::FnOnce::call_once::h2960941966bddb16 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 24: 0x564a8299013b - core::ops::function::FnOnce::call_once::h70887edf07a630ba [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 25: 0x564a8299013b - test::__rust_begin_short_backtrace::h27763c4cbbdb8601 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x564a829a5da5 - test::run_test_in_process::{{closure}}::h4dc8bc6d5e3924d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x564a829a5da5 - as core::ops::function::FnOnce<()>>::call_once::h75905e8ffe81974f [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 28: 0x564a829a5da5 - std::panicking::catch_unwind::do_call::h0bc60366ba66eba5 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x564a829a5da5 - std::panicking::catch_unwind::hae1ec7bf94407afa [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x564a829a5da5 - std::panic::catch_unwind::h0f4ff4773d84d3cd [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x564a829a5da5 - test::run_test_in_process::h03fbc77ae48b3f10 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x564a829a5da5 - test::run_test::{{closure}}::h83476a9c453dc4d3 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x564a8297c594 - test::run_test::{{closure}}::h515482ad1e7fe7de [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x564a8297c594 - std::sys::backtrace::__rust_begin_short_backtrace::hed09f6ac5fe9d647 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h988e2cd969319888 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x564a8297fe5a - as core::ops::function::FnOnce<()>>::call_once::hd70e28dc46ec20be [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/panic/unwind_safe.rs:274:9 [INFO] [stdout] 37: 0x564a8297fe5a - std::panicking::catch_unwind::do_call::hdc29e11311eb7655 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x564a8297fe5a - std::panicking::catch_unwind::h9e402d6a96fef41c [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x564a8297fe5a - std::panic::catch_unwind::h9213c0c54aec70e0 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x564a8297fe5a - std::thread::Builder::spawn_unchecked_::{{closure}}::h6262965869ed2b87 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x564a8297fe5a - core::ops::function::FnOnce::call_once{{vtable.shim}}::h05c05ed02619e462 [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/core/src/ops/function.rs:250:5 [INFO] [stdout] 42: 0x70c714ed84df - as core::ops::function::FnOnce>::call_once::h2044e71c41d3958a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x70c714ed84df - std::sys::thread::unix::Thread::new::thread_start::hf277835320aa8e5a [INFO] [stdout] at /rustc/bb624dcb4c8ab987e10c0808d92d76f3b84dd117/library/std/src/sys/thread/unix.rs:126:17 [INFO] [stdout] 44: 0x70c714c73aa4 - [INFO] [stdout] 45: 0x70c714d00a34 - 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 6.37s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] running `Command { std: "docker" "inspect" "c9456d3bb58e1e67bfea73332a477720b1e33dfc523b2e19d3f6ea9b09755b45", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c9456d3bb58e1e67bfea73332a477720b1e33dfc523b2e19d3f6ea9b09755b45", kill_on_drop: false }` [INFO] [stdout] c9456d3bb58e1e67bfea73332a477720b1e33dfc523b2e19d3f6ea9b09755b45