[INFO] fetching crate rust-sitter-macro 0.4.5... [INFO] testing rust-sitter-macro-0.4.5 against master#cdb45c87e2cd43495379f7e867e3cc15dcee9f93 for pr-145838-1 [INFO] extracting crate rust-sitter-macro 0.4.5 into /workspace/builds/worker-3-tc1/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-3-tc1/source/Cargo.toml [INFO] validating manifest of crates.io crate rust-sitter-macro 0.4.5 on toolchain cdb45c87e2cd43495379f7e867e3cc15dcee9f93 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "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" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded rust-sitter-common v0.4.5 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/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:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 3817b21a88f17060879979911654a95e98c379d2a2d3b2b2793060b320e90785 [INFO] running `Command { std: "docker" "start" "-a" "3817b21a88f17060879979911654a95e98c379d2a2d3b2b2793060b320e90785", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "3817b21a88f17060879979911654a95e98c379d2a2d3b2b2793060b320e90785", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "3817b21a88f17060879979911654a95e98c379d2a2d3b2b2793060b320e90785", kill_on_drop: false }` [INFO] [stdout] 3817b21a88f17060879979911654a95e98c379d2a2d3b2b2793060b320e90785 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] aea885417cb67a2fc5cf88a6102bf35ef3a71e5465bdea47760884c52ad8b65a [INFO] running `Command { std: "docker" "start" "-a" "aea885417cb67a2fc5cf88a6102bf35ef3a71e5465bdea47760884c52ad8b65a", kill_on_drop: false }` [INFO] [stderr] Compiling proc-macro2 v1.0.93 [INFO] [stderr] Compiling unicode-ident v1.0.17 [INFO] [stderr] Compiling quote v1.0.38 [INFO] [stderr] Compiling syn v2.0.98 [INFO] [stderr] Compiling rust-sitter-common v0.4.5 [INFO] [stderr] Compiling rust-sitter-macro v0.4.5 (/opt/rustwide/workdir) [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 6.49s [INFO] running `Command { std: "docker" "inspect" "aea885417cb67a2fc5cf88a6102bf35ef3a71e5465bdea47760884c52ad8b65a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "aea885417cb67a2fc5cf88a6102bf35ef3a71e5465bdea47760884c52ad8b65a", kill_on_drop: false }` [INFO] [stdout] aea885417cb67a2fc5cf88a6102bf35ef3a71e5465bdea47760884c52ad8b65a [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 77c6c55ece8be4923debd5916497c5733ce993d707f6e659d2fd3157322a1738 [INFO] running `Command { std: "docker" "start" "-a" "77c6c55ece8be4923debd5916497c5733ce993d707f6e659d2fd3157322a1738", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.169 [INFO] [stderr] Compiling getrandom v0.3.1 [INFO] [stderr] Compiling once_cell v1.20.3 [INFO] [stderr] Compiling rustix v0.38.44 [INFO] [stderr] Compiling bitflags v2.8.0 [INFO] [stderr] Compiling linked-hash-map v0.5.6 [INFO] [stderr] Compiling similar v2.7.0 [INFO] [stderr] Compiling syn v2.0.98 [INFO] [stderr] Compiling console v0.15.10 [INFO] [stderr] Compiling tempfile v3.17.1 [INFO] [stderr] Compiling rust-sitter-common v0.4.5 [INFO] [stderr] Compiling pin-project-internal v1.1.9 [INFO] [stderr] Compiling rust-sitter-macro v0.4.5 (/opt/rustwide/workdir) [INFO] [stderr] Compiling pin-project v1.1.9 [INFO] [stderr] Compiling insta v1.42.1 [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 9.74s [INFO] running `Command { std: "docker" "inspect" "77c6c55ece8be4923debd5916497c5733ce993d707f6e659d2fd3157322a1738", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "77c6c55ece8be4923debd5916497c5733ce993d707f6e659d2fd3157322a1738", kill_on_drop: false }` [INFO] [stdout] 77c6c55ece8be4923debd5916497c5733ce993d707f6e659d2fd3157322a1738 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:7ad1b28ee6f5f7f699f6cf7015098d6ccdd96d6f2d78dd06228f5b4c9faf309c" "/opt/rustwide/cargo-home/bin/cargo" "+cdb45c87e2cd43495379f7e867e3cc15dcee9f93" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 86601dd7b95a342a7fc3f424f05323b809b61ba84161d162288fc81ca343bc37 [INFO] running `Command { std: "docker" "start" "-a" "86601dd7b95a342a7fc3f424f05323b809b61ba84161d162288fc81ca343bc37", kill_on_drop: false }` [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.09s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/rust_sitter_macro-f994f512f19f167e) [INFO] [stdout] [INFO] [stdout] running 10 tests [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'cdb45c87e2cd43495379f7e867e3cc15dcee9f93'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'cdb45c87e2cd43495379f7e867e3cc15dcee9f93'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'cdb45c87e2cd43495379f7e867e3cc15dcee9f93'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'cdb45c87e2cd43495379f7e867e3cc15dcee9f93'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'cdb45c87e2cd43495379f7e867e3cc15dcee9f93'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'cdb45c87e2cd43495379f7e867e3cc15dcee9f93'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'cdb45c87e2cd43495379f7e867e3cc15dcee9f93'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'cdb45c87e2cd43495379f7e867e3cc15dcee9f93'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'cdb45c87e2cd43495379f7e867e3cc15dcee9f93'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stderr] error: 'rustfmt' is not installed for the custom toolchain 'cdb45c87e2cd43495379f7e867e3cc15dcee9f93'. [INFO] [stderr] note: this is a custom toolchain, which cannot use `rustup component add` [INFO] [stderr] help: if you built this toolchain from source, and used `rustup toolchain link`, then you may be able to build the component with `x.py` [INFO] [stdout] test tests::grammar_unboxed_field ... FAILED [INFO] [stdout] test tests::enum_with_unamed_vector ... FAILED [INFO] [stdout] test tests::enum_prec_left ... FAILED [INFO] [stdout] test tests::struct_optional ... FAILED [INFO] [stdout] test tests::enum_with_named_field ... FAILED [INFO] [stdout] test tests::struct_repeat ... FAILED [INFO] [stdout] test tests::enum_transformed_fields ... FAILED [INFO] [stdout] test tests::enum_recursive ... FAILED [INFO] [stdout] test tests::struct_extra ... FAILED [INFO] [stderr] error: test failed, to rerun pass `--lib` [INFO] [stdout] test tests::spanned_in_vec ... FAILED [INFO] [stdout] [INFO] [stdout] failures: [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: 0x7fe1516a7152 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x7fe1516a7152 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x7fe1516a7152 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x7fe1516a7152 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x7fe1516d84df - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x7fe1516d84df - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x7fe1516593d3 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x7fe1516593d3 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x7fe15166e0e2 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x7fe15167643a - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x7fe1516762cc - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55a979e4305e - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x55a979e4305e - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x7fe151676b7e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x7fe151676b7e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x7fe15167689a - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x7fe15166e219 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x7fe15164a55d - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x7fe1516e8c20 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x7fe1516e75b6 - core::result::unwrap_failed::h3ce108722ad88f1e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x55a979d05a0f - core::result::Result::unwrap::h0ac3d2d6ca551674 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x55a979d05a0f - rust_sitter_macro::tests::grammar_unboxed_field::h543be95d2a5b965e [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:368:9 [INFO] [stdout] 22: 0x55a979d05b6d - rust_sitter_macro::tests::grammar_unboxed_field::{{closure}}::h0e47fde3c199e38a [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:367:35 [INFO] [stdout] 23: 0x55a979d0e7e6 - core::ops::function::FnOnce::call_once::hd4294031da758592 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x55a979e42e5b - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x55a979e42e5b - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x55a979e58905 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x55a979e58905 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x55a979e58905 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x55a979e58905 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x55a979e58905 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x55a979e58905 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x55a979e58905 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x55a979e2f324 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x55a979e2f324 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x55a979e32c0a - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x55a979e32c0a - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x55a979e32c0a - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x55a979e32c0a - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x55a979e32c0a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x7fe151666ebf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x7fe151666ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7fe1513feaa4 - [INFO] [stdout] 45: 0x7fe15148ba34 - 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: 0x7fe1516a7152 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x7fe1516a7152 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x7fe1516a7152 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x7fe1516a7152 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x7fe1516d84df - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x7fe1516d84df - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x7fe1516593d3 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x7fe1516593d3 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x7fe15166e0e2 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x7fe15167643a - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x7fe1516762cc - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55a979e4305e - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x55a979e4305e - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x7fe151676b7e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x7fe151676b7e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x7fe15167689a - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x7fe15166e219 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x7fe15164a55d - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x7fe1516e8c20 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x7fe1516e75b6 - core::result::unwrap_failed::h3ce108722ad88f1e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x55a979d07ed1 - core::result::Result::unwrap::h0ac3d2d6ca551674 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x55a979d07ed1 - rust_sitter_macro::tests::enum_with_unamed_vector::h95c54bb9fc9ad667 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:450:9 [INFO] [stdout] 22: 0x55a979d080cd - rust_sitter_macro::tests::enum_with_unamed_vector::{{closure}}::habdf5e100311788d [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:449:37 [INFO] [stdout] 23: 0x55a979d0e336 - core::ops::function::FnOnce::call_once::h1806897c6db20d90 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x55a979e42e5b - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x55a979e42e5b - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x55a979e58905 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x55a979e58905 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x55a979e58905 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x55a979e58905 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x55a979e58905 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x55a979e58905 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x55a979e58905 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x55a979e2f324 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x55a979e2f324 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x55a979e32c0a - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x55a979e32c0a - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x55a979e32c0a - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x55a979e32c0a - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x55a979e32c0a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x7fe151666ebf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x7fe151666ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7fe1513feaa4 - [INFO] [stdout] 45: 0x7fe15148ba34 - 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: 0x7fe1516a7152 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x7fe1516a7152 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x7fe1516a7152 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x7fe1516a7152 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x7fe1516d84df - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x7fe1516d84df - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x7fe1516593d3 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x7fe1516593d3 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x7fe15166e0e2 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x7fe15167643a - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x7fe1516762cc - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55a979e4305e - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x55a979e4305e - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x7fe151676b7e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x7fe151676b7e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x7fe15167689a - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x7fe15166e219 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x7fe15164a55d - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x7fe1516e8c20 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x7fe1516e75b6 - core::result::unwrap_failed::h3ce108722ad88f1e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x55a979cff41c - core::result::Result::unwrap::h0ac3d2d6ca551674 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x55a979cff41c - rust_sitter_macro::tests::enum_prec_left::hdbd589f3937ce10b [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:312:9 [INFO] [stdout] 22: 0x55a979cff56d - rust_sitter_macro::tests::enum_prec_left::{{closure}}::h5fc6ad39058c77c7 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:311:28 [INFO] [stdout] 23: 0x55a979d0e436 - core::ops::function::FnOnce::call_once::h4a3fa290eb15a836 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x55a979e42e5b - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x55a979e42e5b - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x55a979e58905 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x55a979e58905 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x55a979e58905 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x55a979e58905 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x55a979e58905 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x55a979e58905 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x55a979e58905 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x55a979e2f324 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x55a979e2f324 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x55a979e32c0a - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x55a979e32c0a - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x55a979e32c0a - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x55a979e32c0a - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x55a979e32c0a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x7fe151666ebf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x7fe151666ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7fe1513feaa4 - [INFO] [stdout] 45: 0x7fe15148ba34 - clone [INFO] [stdout] 46: 0x0 - [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' (34) 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: 0x7fe1516a7152 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x7fe1516a7152 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x7fe1516a7152 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x7fe1516a7152 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x7fe1516d84df - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x7fe1516d84df - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x7fe1516593d3 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x7fe1516593d3 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x7fe15166e0e2 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x7fe15167643a - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x7fe1516762cc - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55a979e4305e - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x55a979e4305e - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x7fe151676b7e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x7fe151676b7e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x7fe15167689a - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x7fe15166e219 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x7fe15164a55d - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x7fe1516e8c20 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x7fe1516e75b6 - core::result::unwrap_failed::h3ce108722ad88f1e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x55a979d03371 - core::result::Result::unwrap::h0ac3d2d6ca551674 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x55a979d03371 - rust_sitter_macro::tests::struct_optional::h954d666c0e2ed780 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:424:9 [INFO] [stdout] 22: 0x55a979d034cd - rust_sitter_macro::tests::struct_optional::{{closure}}::h17ef9ab06c39dfa2 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:423:29 [INFO] [stdout] 23: 0x55a979d0e686 - core::ops::function::FnOnce::call_once::h9832459ab1bf2adc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x55a979e42e5b - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x55a979e42e5b - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x55a979e58905 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x55a979e58905 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x55a979e58905 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x55a979e58905 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x55a979e58905 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x55a979e58905 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x55a979e58905 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x55a979e2f324 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x55a979e2f324 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x55a979e32c0a - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x55a979e32c0a - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x55a979e32c0a - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x55a979e32c0a - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x55a979e32c0a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x7fe151666ebf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x7fe151666ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7fe1513feaa4 - [INFO] [stdout] 45: 0x7fe15148ba34 - 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: 0x7fe1516a7152 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x7fe1516a7152 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x7fe1516a7152 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x7fe1516a7152 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x7fe1516d84df - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x7fe1516d84df - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x7fe1516593d3 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x7fe1516593d3 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x7fe15166e0e2 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x7fe15167643a - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x7fe1516762cc - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55a979e4305e - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x55a979e4305e - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x7fe151676b7e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x7fe151676b7e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x7fe15167689a - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x7fe15166e219 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x7fe15164a55d - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x7fe1516e8c20 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x7fe1516e75b6 - core::result::unwrap_failed::h3ce108722ad88f1e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x55a979d0478b - core::result::Result::unwrap::h0ac3d2d6ca551674 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x55a979d0478b - rust_sitter_macro::tests::enum_with_named_field::h1c4083ae95afe4d1 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:477:9 [INFO] [stdout] 22: 0x55a979d0497d - rust_sitter_macro::tests::enum_with_named_field::{{closure}}::hfd04e8e724c354e1 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:476:35 [INFO] [stdout] 23: 0x55a979d0e6c6 - core::ops::function::FnOnce::call_once::h9e922ca5783ec63b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x55a979e42e5b - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x55a979e42e5b - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x55a979e58905 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x55a979e58905 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x55a979e58905 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x55a979e58905 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x55a979e58905 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x55a979e58905 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x55a979e58905 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x55a979e2f324 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x55a979e2f324 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x55a979e32c0a - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x55a979e32c0a - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x55a979e32c0a - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x55a979e32c0a - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x55a979e32c0a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x7fe151666ebf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x7fe151666ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7fe1513feaa4 - [INFO] [stdout] 45: 0x7fe15148ba34 - 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' (35) 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: 0x7fe1516a7152 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x7fe1516a7152 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x7fe1516a7152 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x7fe1516a7152 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x7fe1516d84df - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x7fe1516d84df - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x7fe1516593d3 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x7fe1516593d3 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x7fe15166e0e2 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x7fe15167643a - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x7fe1516762cc - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55a979e4305e - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x55a979e4305e - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x7fe151676b7e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x7fe151676b7e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x7fe15167689a - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x7fe15166e219 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x7fe15164a55d - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x7fe1516e8c20 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x7fe1516e75b6 - core::result::unwrap_failed::h3ce108722ad88f1e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x55a979cfde70 - core::result::Result::unwrap::h0ac3d2d6ca551674 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x55a979cfde70 - rust_sitter_macro::tests::struct_repeat::hcf82d2852913e5d9 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:394:9 [INFO] [stdout] 22: 0x55a979cfe06d - rust_sitter_macro::tests::struct_repeat::{{closure}}::hb407b28c6a77f80d [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:393:27 [INFO] [stdout] 23: 0x55a979d0e266 - core::ops::function::FnOnce::call_once::h0a24a8a565ef72d7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x55a979e42e5b - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x55a979e42e5b - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x55a979e58905 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x55a979e58905 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x55a979e58905 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x55a979e58905 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x55a979e58905 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x55a979e58905 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x55a979e58905 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x55a979e2f324 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x55a979e2f324 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x55a979e32c0a - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x55a979e32c0a - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x55a979e32c0a - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x55a979e32c0a - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x55a979e32c0a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x7fe151666ebf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x7fe151666ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7fe1513feaa4 - [INFO] [stdout] 45: 0x7fe15148ba34 - 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: 0x7fe1516a7152 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x7fe1516a7152 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x7fe1516a7152 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x7fe1516a7152 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x7fe1516d84df - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x7fe1516d84df - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x7fe1516593d3 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x7fe1516593d3 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x7fe15166e0e2 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x7fe15167643a - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x7fe1516762cc - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55a979e4305e - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x55a979e4305e - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x7fe151676b7e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x7fe151676b7e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x7fe15167689a - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x7fe15166e219 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x7fe15164a55d - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x7fe1516e8c20 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x7fe1516e75b6 - core::result::unwrap_failed::h3ce108722ad88f1e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x55a979d06b1a - core::result::Result::unwrap::h0ac3d2d6ca551674 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x55a979d06b1a - rust_sitter_macro::tests::enum_transformed_fields::he72e2ad3c8de24c7 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:263:9 [INFO] [stdout] 22: 0x55a979d06d0d - rust_sitter_macro::tests::enum_transformed_fields::{{closure}}::hc1f73d0973dd4919 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:262:37 [INFO] [stdout] 23: 0x55a979d0e5a6 - core::ops::function::FnOnce::call_once::h78818b3ee480f579 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x55a979e42e5b - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x55a979e42e5b - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x55a979e58905 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x55a979e58905 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x55a979e58905 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x55a979e58905 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x55a979e58905 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x55a979e58905 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x55a979e58905 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x55a979e2f324 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x55a979e2f324 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x55a979e32c0a - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x55a979e32c0a - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x55a979e32c0a - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x55a979e32c0a - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x55a979e32c0a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x7fe151666ebf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x7fe151666ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7fe1513feaa4 - [INFO] [stdout] 45: 0x7fe15148ba34 - 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: 0x7fe1516a7152 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x7fe1516a7152 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x7fe1516a7152 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x7fe1516a7152 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x7fe1516d84df - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x7fe1516d84df - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x7fe1516593d3 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x7fe1516593d3 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x7fe15166e0e2 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x7fe15167643a - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x7fe1516762cc - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55a979e4305e - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x55a979e4305e - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x7fe151676b7e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x7fe151676b7e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x7fe15167689a - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x7fe15166e219 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x7fe15164a55d - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x7fe1516e8c20 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x7fe1516e75b6 - core::result::unwrap_failed::h3ce108722ad88f1e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x55a979d007c4 - core::result::Result::unwrap::h0ac3d2d6ca551674 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x55a979d007c4 - rust_sitter_macro::tests::enum_recursive::h4b8ffaa327bfc12b [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:285:9 [INFO] [stdout] 22: 0x55a979d0091d - rust_sitter_macro::tests::enum_recursive::{{closure}}::h35282666d365e021 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:284:28 [INFO] [stdout] 23: 0x55a979d0e536 - core::ops::function::FnOnce::call_once::h6136e569d89414f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x55a979e42e5b - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x55a979e42e5b - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x55a979e58905 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x55a979e58905 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x55a979e58905 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x55a979e58905 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x55a979e58905 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x55a979e58905 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x55a979e58905 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x55a979e2f324 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x55a979e2f324 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x55a979e32c0a - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x55a979e32c0a - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x55a979e32c0a - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x55a979e32c0a - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x55a979e32c0a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x7fe151666ebf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x7fe151666ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7fe1513feaa4 - [INFO] [stdout] 45: 0x7fe15148ba34 - 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' (33) 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: 0x7fe1516a7152 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x7fe1516a7152 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x7fe1516a7152 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x7fe1516a7152 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x7fe1516d84df - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x7fe1516d84df - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x7fe1516593d3 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x7fe1516593d3 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x7fe15166e0e2 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x7fe15167643a - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x7fe1516762cc - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55a979e4305e - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x55a979e4305e - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x7fe151676b7e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x7fe151676b7e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x7fe15167689a - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x7fe15166e219 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x7fe15164a55d - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x7fe1516e8c20 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x7fe1516e75b6 - core::result::unwrap_failed::h3ce108722ad88f1e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x55a979cfc8f7 - core::result::Result::unwrap::h0ac3d2d6ca551674 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x55a979cfc8f7 - rust_sitter_macro::tests::struct_extra::h18bfc6ebee86d176 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:341:9 [INFO] [stdout] 22: 0x55a979cfcaed - rust_sitter_macro::tests::struct_extra::{{closure}}::hd81dda64cabe5489 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:340:26 [INFO] [stdout] 23: 0x55a979d0e3b6 - core::ops::function::FnOnce::call_once::h3ca82cf98755f831 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x55a979e42e5b - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x55a979e42e5b - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x55a979e58905 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x55a979e58905 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x55a979e58905 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x55a979e58905 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x55a979e58905 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x55a979e58905 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x55a979e58905 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x55a979e2f324 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x55a979e2f324 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x55a979e32c0a - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x55a979e32c0a - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x55a979e32c0a - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x55a979e32c0a - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x55a979e32c0a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x7fe151666ebf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x7fe151666ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7fe1513feaa4 - [INFO] [stdout] 45: 0x7fe15148ba34 - 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: 0x7fe1516a7152 - std::backtrace_rs::backtrace::libunwind::trace::h7cddb8376417e7cc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9 [INFO] [stdout] 1: 0x7fe1516a7152 - std::backtrace_rs::backtrace::trace_unsynchronized::hb4e41acf4b349ff1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14 [INFO] [stdout] 2: 0x7fe1516a7152 - std::sys::backtrace::_print_fmt::h1222b80910ba6eb5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:66:9 [INFO] [stdout] 3: 0x7fe1516a7152 - ::fmt::h5bb8a979ba5db788 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:39:26 [INFO] [stdout] 4: 0x7fe1516d84df - core::fmt::rt::Argument::fmt::h2ee2c138a50a7796 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/rt.rs:173:76 [INFO] [stdout] 5: 0x7fe1516d84df - core::fmt::write::h1e0dbf07fe3990bd [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/fmt/mod.rs:1468:25 [INFO] [stdout] 6: 0x7fe1516593d3 - std::io::default_write_fmt::h7d7ad5ed6a883d81 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:639:11 [INFO] [stdout] 7: 0x7fe1516593d3 - std::io::Write::write_fmt::hc477d9325b345ece [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/io/mod.rs:1954:13 [INFO] [stdout] 8: 0x7fe15166e0e2 - std::sys::backtrace::BacktraceLock::print::h788d486777205086 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:42:9 [INFO] [stdout] 9: 0x7fe15167643a - std::panicking::default_hook::{{closure}}::ha7bdfeb5949fc0fa [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:301:27 [INFO] [stdout] 10: 0x7fe1516762cc - std::panicking::default_hook::h6dad75ec721846f4 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:325:9 [INFO] [stdout] 11: 0x55a979e4305e - as core::ops::function::Fn>::call::h33799d04b0b96146 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 12: 0x55a979e4305e - test::test_main_with_exit_callback::{{closure}}::h880e31c829a2eb5d [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:145:21 [INFO] [stdout] 13: 0x7fe151676b7e - as core::ops::function::Fn>::call::h5e1b8c652ea49180 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1999:9 [INFO] [stdout] 14: 0x7fe151676b7e - std::panicking::panic_with_hook::hba00e869ada17676 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:842:13 [INFO] [stdout] 15: 0x7fe15167689a - std::panicking::panic_handler::{{closure}}::h3d21149c258e5ceb [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:707:13 [INFO] [stdout] 16: 0x7fe15166e219 - std::sys::backtrace::__rust_end_short_backtrace::h4f5d9b9dfb3e6ec1 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:174:18 [INFO] [stdout] 17: 0x7fe15164a55d - __rustc[9a7a9f9af7564de1]::rust_begin_unwind [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:698:5 [INFO] [stdout] 18: 0x7fe1516e8c20 - core::panicking::panic_fmt::h78e817a90331d98b [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panicking.rs:75:14 [INFO] [stdout] 19: 0x7fe1516e75b6 - core::result::unwrap_failed::h3ce108722ad88f1e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1852:5 [INFO] [stdout] 20: 0x55a979d01df8 - core::result::Result::unwrap::h0ac3d2d6ca551674 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/result.rs:1223:23 [INFO] [stdout] 21: 0x55a979d01df8 - rust_sitter_macro::tests::spanned_in_vec::h1032d072894a773a [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:504:9 [INFO] [stdout] 22: 0x55a979d01f4d - rust_sitter_macro::tests::spanned_in_vec::{{closure}}::hd6bb894037225259 [INFO] [stdout] at /opt/rustwide/workdir/src/lib.rs:503:28 [INFO] [stdout] 23: 0x55a979d0e2a6 - core::ops::function::FnOnce::call_once::h0e4c5e739a179be2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 24: 0x55a979e42e5b - core::ops::function::FnOnce::call_once::h7f4b4fba903e39d5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 25: 0x55a979e42e5b - test::__rust_begin_short_backtrace::h9277cb6a2ccfc000 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:663:18 [INFO] [stdout] 26: 0x55a979e58905 - test::run_test_in_process::{{closure}}::h9aea5ca90d1f4423 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:74 [INFO] [stdout] 27: 0x55a979e58905 - as core::ops::function::FnOnce<()>>::call_once::h364f5fe6cc8afa85 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 28: 0x55a979e58905 - std::panicking::catch_unwind::do_call::h2b2bec3317fe53ec [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 29: 0x55a979e58905 - std::panicking::catch_unwind::hc3763734156da4af [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 30: 0x55a979e58905 - std::panic::catch_unwind::h28038391e867eabc [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 31: 0x55a979e58905 - test::run_test_in_process::had0273166695a036 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:686:27 [INFO] [stdout] 32: 0x55a979e58905 - test::run_test::{{closure}}::h743d09d4bb476605 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:607:43 [INFO] [stdout] 33: 0x55a979e2f324 - test::run_test::{{closure}}::he950b8f9118d37e2 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/test/src/lib.rs:637:41 [INFO] [stdout] 34: 0x55a979e2f324 - std::sys::backtrace::__rust_begin_short_backtrace::hbfaffa6539f6abb7 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/backtrace.rs:158:18 [INFO] [stdout] 35: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hcce3c2c65b9c3b20 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:559:17 [INFO] [stdout] 36: 0x55a979e32c0a - as core::ops::function::FnOnce<()>>::call_once::hb66b30b6d37985a5 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/panic/unwind_safe.rs:272:9 [INFO] [stdout] 37: 0x55a979e32c0a - std::panicking::catch_unwind::do_call::h992bbe2c32dc1d79 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:590:40 [INFO] [stdout] 38: 0x55a979e32c0a - std::panicking::catch_unwind::h412991d5237de610 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panicking.rs:553:19 [INFO] [stdout] 39: 0x55a979e32c0a - std::panic::catch_unwind::ha82b139b3eb5840a [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/panic.rs:359:14 [INFO] [stdout] 40: 0x55a979e32c0a - std::thread::Builder::spawn_unchecked_::{{closure}}::ha823b36f5114938e [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/thread/mod.rs:557:30 [INFO] [stdout] 41: 0x55a979e32c0a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hf120e7b1db22ac07 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/core/src/ops/function.rs:253:5 [INFO] [stdout] 42: 0x7fe151666ebf - as core::ops::function::FnOnce>::call_once::h3e049222c99298ac [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/alloc/src/boxed.rs:1985:9 [INFO] [stdout] 43: 0x7fe151666ebf - std::sys::pal::unix::thread::Thread::new::thread_start::h942e336943ad5963 [INFO] [stdout] at /rustc/cdb45c87e2cd43495379f7e867e3cc15dcee9f93/library/std/src/sys/pal/unix/thread.rs:118:17 [INFO] [stdout] 44: 0x7fe1513feaa4 - [INFO] [stdout] 45: 0x7fe15148ba34 - clone [INFO] [stdout] 46: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] tests::enum_prec_left [INFO] [stdout] tests::enum_recursive [INFO] [stdout] tests::enum_transformed_fields [INFO] [stdout] tests::enum_with_named_field [INFO] [stdout] tests::enum_with_unamed_vector [INFO] [stdout] tests::grammar_unboxed_field [INFO] [stdout] tests::spanned_in_vec [INFO] [stdout] tests::struct_extra [INFO] [stdout] tests::struct_optional [INFO] [stdout] tests::struct_repeat [INFO] [stdout] [INFO] [stdout] test result: FAILED. 0 passed; 10 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.49s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "86601dd7b95a342a7fc3f424f05323b809b61ba84161d162288fc81ca343bc37", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "86601dd7b95a342a7fc3f424f05323b809b61ba84161d162288fc81ca343bc37", kill_on_drop: false }` [INFO] [stdout] 86601dd7b95a342a7fc3f424f05323b809b61ba84161d162288fc81ca343bc37