From 790037c18697423a3110121126d93788d4d4ba8a Mon Sep 17 00:00:00 2001 From: Antony Blakey Date: Mon, 8 Apr 2024 11:27:03 +0100 Subject: [PATCH] Fix nested bindings in queries --- crates/codegen/parser/runtime/src/query/engine.rs | 1 + .../slang_solidity/src/generated/query/engine.rs | 1 + .../slang_testlang/src/generated/query/engine.rs | 1 + .../outputs/cargo/tests/src/query/engine_tests.rs | 11 +++++++++++ 4 files changed, 14 insertions(+) diff --git a/crates/codegen/parser/runtime/src/query/engine.rs b/crates/codegen/parser/runtime/src/query/engine.rs index cb41f382d4..7be82f4133 100644 --- a/crates/codegen/parser/runtime/src/query/engine.rs +++ b/crates/codegen/parser/runtime/src/query/engine.rs @@ -181,6 +181,7 @@ impl Combinator for BindingCombinator { .entry(self.matcher.name.clone()) .or_default() .push(self.cursor.clone()); + self.child.accumulate_bindings(bindings); } } diff --git a/crates/solidity/outputs/cargo/slang_solidity/src/generated/query/engine.rs b/crates/solidity/outputs/cargo/slang_solidity/src/generated/query/engine.rs index 6cdb482c51..63ea8aa85a 100644 --- a/crates/solidity/outputs/cargo/slang_solidity/src/generated/query/engine.rs +++ b/crates/solidity/outputs/cargo/slang_solidity/src/generated/query/engine.rs @@ -183,6 +183,7 @@ impl Combinator for BindingCombinator { .entry(self.matcher.name.clone()) .or_default() .push(self.cursor.clone()); + self.child.accumulate_bindings(bindings); } } diff --git a/crates/testlang/outputs/cargo/slang_testlang/src/generated/query/engine.rs b/crates/testlang/outputs/cargo/slang_testlang/src/generated/query/engine.rs index 6cdb482c51..63ea8aa85a 100644 --- a/crates/testlang/outputs/cargo/slang_testlang/src/generated/query/engine.rs +++ b/crates/testlang/outputs/cargo/slang_testlang/src/generated/query/engine.rs @@ -183,6 +183,7 @@ impl Combinator for BindingCombinator { .entry(self.matcher.name.clone()) .or_default() .push(self.cursor.clone()); + self.child.accumulate_bindings(bindings); } } diff --git a/crates/testlang/outputs/cargo/tests/src/query/engine_tests.rs b/crates/testlang/outputs/cargo/tests/src/query/engine_tests.rs index 2d406bf0da..e102eedef7 100644 --- a/crates/testlang/outputs/cargo/tests/src/query/engine_tests.rs +++ b/crates/testlang/outputs/cargo/tests/src/query/engine_tests.rs @@ -250,3 +250,14 @@ fn test_optional() { }, ); } + +#[test] +fn test_nested() { + run_query_test( + &common_test_tree(), + "@root [TreeNode ... @z [DelimitedIdentifier] [_] ]", + query_results! { + {root: ["ABCDE"], z: ["C"]} + }, + ); +}