Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 12 additions & 0 deletions .changeset/fix-jsx-slot-indices.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
---
"@biomejs/biome": patch
---

Properly handle `name`, `type_arguments`, and `attributes` slots for `JsxOpeningElement` and `JsxSelfClosingElement` GritQL patterns.

The following biome search commands no longer throw errors:

```shell
biome search 'JsxOpeningElement(name = $elem_name) where { $elem_name <: "div" }'
biome search 'JsxSelfClosingElement(name = $elem_name) where { $elem_name <: "div" }'
```
Original file line number Diff line number Diff line change
Expand Up @@ -137,12 +137,12 @@ pub const LEGACY_TREESITTER_COMPATIBILITY_PATTERNS: &[LegacyTreeSitterPattern] =
LegacyTreeSitterPattern {
name: "jsx_self_closing_element",
kind: JsSyntaxKind::JSX_SELF_CLOSING_ELEMENT,
slots: &[],
slots: &[("name", 1), ("type_arguments", 2), ("attributes", 3)],
},
LegacyTreeSitterPattern {
name: "jsx_opening_element",
kind: JsSyntaxKind::JSX_OPENING_ELEMENT,
slots: &[],
slots: &[("name", 1), ("type_arguments", 2), ("attributes", 3)],
},
LegacyTreeSitterPattern {
name: "jsx_closing_element",
Expand Down

This file was deleted.

12 changes: 0 additions & 12 deletions crates/biome_grit_patterns/tests/specs/tsx/jsx_attributes.snap

This file was deleted.

This file was deleted.

16 changes: 16 additions & 0 deletions crates/biome_grit_patterns/tests/specs/tsx/jsx_slots.grit
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
or {
// Legacy patterns
jsx_opening_element(name = "div"),
jsx_self_closing_element(name = "span"),
jsx_self_closing_element(type_arguments = TsTypeArguments()),
jsx_attribute(name = "className"),

// Native patterns
JsxOpeningElement(name = "div"),
JsxSelfClosingElement(name = "button"),
JsxSelfClosingElement(type_arguments = TsTypeArguments()),
JsxAttribute(name = "id"),
JsxAttribute($name, $value) as $attr where {
$name <: "style"
},
}
20 changes: 20 additions & 0 deletions crates/biome_grit_patterns/tests/specs/tsx/jsx_slots.snap
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
---
source: crates/biome_grit_patterns/tests/spec_tests.rs
assertion_line: 94
expression: jsx_slots
---
SnapshotResult {
messages: [],
matched_ranges: [
"1:1-1:28",
"1:6-1:27",
"2:3-2:11",
"3:3-3:22",
"3:11-3:19",
"5:3-5:24",
"6:3-6:19",
"6:8-6:18",
],
rewritten_files: [],
created_files: [],
}
7 changes: 7 additions & 0 deletions crates/biome_grit_patterns/tests/specs/tsx/jsx_slots.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
<div className="container">
<span />
<button id="btn" />
<input disabled />
<Component<string> />
<div style={{}}>{children}</div>
</div>
4 changes: 2 additions & 2 deletions xtask/codegen/src/generate_grit_mappings.rs
Original file line number Diff line number Diff line change
Expand Up @@ -285,12 +285,12 @@ const JS_TREESITTER_PATTERNS: &[TreeSitterPattern] = &[
TreeSitterPattern {
name: "jsx_self_closing_element",
biome_kind: "JSX_SELF_CLOSING_ELEMENT",
slots: &[],
slots: &[("name", 1), ("type_arguments", 2), ("attributes", 3)],
},
TreeSitterPattern {
name: "jsx_opening_element",
biome_kind: "JSX_OPENING_ELEMENT",
slots: &[],
slots: &[("name", 1), ("type_arguments", 2), ("attributes", 3)],
},
TreeSitterPattern {
name: "jsx_closing_element",
Expand Down
Loading