biome_css_parser 0.5.8

Biome's CSS parser
Documentation
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
---
source: crates/biome_css_parser/tests/spec_test.rs
expression: snapshot
---
## Input

```css
.chat-image {
	grid-row: span 2 / span 2;
	align-self: flex-end
}

#grid {
	display: grid;
	grid-template-columns: [first nav-start] 150px [main-start] 1fr [last];
	grid-template-rows: [first header-start] 50px [main-start] 1fr [footer-start] 50px [last];
}

```


## AST

```
CssRoot {
    bom_token: missing (optional),
    rules: CssRuleList [
        CssQualifiedRule {
            prelude: CssSelectorList [
                CssCompoundSelector {
                    nesting_selectors: CssNestedSelectorList [],
                    simple_selector: missing (optional),
                    sub_selectors: CssSubSelectorList [
                        CssClassSelector {
                            dot_token: DOT@0..1 "." [] [],
                            name: CssCustomIdentifier {
                                value_token: IDENT@1..12 "chat-image" [] [Whitespace(" ")],
                            },
                        },
                    ],
                },
            ],
            block: CssDeclarationOrRuleBlock {
                l_curly_token: L_CURLY@12..13 "{" [] [],
                items: CssDeclarationOrRuleList [
                    CssDeclarationWithSemicolon {
                        declaration: CssDeclaration {
                            property: CssGenericProperty {
                                name: CssIdentifier {
                                    value_token: IDENT@13..23 "grid-row" [Newline("\n"), Whitespace("\t")] [],
                                },
                                colon_token: COLON@23..25 ":" [] [Whitespace(" ")],
                                value: CssGenericComponentValueList [
                                    CssIdentifier {
                                        value_token: IDENT@25..30 "span" [] [Whitespace(" ")],
                                    },
                                    CssNumber {
                                        value_token: CSS_NUMBER_LITERAL@30..32 "2" [] [Whitespace(" ")],
                                    },
                                    CssGenericDelimiter {
                                        value: SLASH@32..34 "/" [] [Whitespace(" ")],
                                    },
                                    CssIdentifier {
                                        value_token: IDENT@34..39 "span" [] [Whitespace(" ")],
                                    },
                                    CssNumber {
                                        value_token: CSS_NUMBER_LITERAL@39..40 "2" [] [],
                                    },
                                ],
                            },
                            important: missing (optional),
                        },
                        semicolon_token: SEMICOLON@40..41 ";" [] [],
                    },
                    CssDeclarationWithSemicolon {
                        declaration: CssDeclaration {
                            property: CssGenericProperty {
                                name: CssIdentifier {
                                    value_token: IDENT@41..53 "align-self" [Newline("\n"), Whitespace("\t")] [],
                                },
                                colon_token: COLON@53..55 ":" [] [Whitespace(" ")],
                                value: CssGenericComponentValueList [
                                    CssIdentifier {
                                        value_token: IDENT@55..63 "flex-end" [] [],
                                    },
                                ],
                            },
                            important: missing (optional),
                        },
                        semicolon_token: missing (optional),
                    },
                ],
                r_curly_token: R_CURLY@63..65 "}" [Newline("\n")] [],
            },
        },
        CssQualifiedRule {
            prelude: CssSelectorList [
                CssCompoundSelector {
                    nesting_selectors: CssNestedSelectorList [],
                    simple_selector: missing (optional),
                    sub_selectors: CssSubSelectorList [
                        CssIdSelector {
                            hash_token: HASH@65..68 "#" [Newline("\n"), Newline("\n")] [],
                            name: CssCustomIdentifier {
                                value_token: IDENT@68..73 "grid" [] [Whitespace(" ")],
                            },
                        },
                    ],
                },
            ],
            block: CssDeclarationOrRuleBlock {
                l_curly_token: L_CURLY@73..74 "{" [] [],
                items: CssDeclarationOrRuleList [
                    CssDeclarationWithSemicolon {
                        declaration: CssDeclaration {
                            property: CssGenericProperty {
                                name: CssIdentifier {
                                    value_token: IDENT@74..83 "display" [Newline("\n"), Whitespace("\t")] [],
                                },
                                colon_token: COLON@83..85 ":" [] [Whitespace(" ")],
                                value: CssGenericComponentValueList [
                                    CssIdentifier {
                                        value_token: IDENT@85..89 "grid" [] [],
                                    },
                                ],
                            },
                            important: missing (optional),
                        },
                        semicolon_token: SEMICOLON@89..90 ";" [] [],
                    },
                    CssDeclarationWithSemicolon {
                        declaration: CssDeclaration {
                            property: CssGenericProperty {
                                name: CssIdentifier {
                                    value_token: IDENT@90..113 "grid-template-columns" [Newline("\n"), Whitespace("\t")] [],
                                },
                                colon_token: COLON@113..115 ":" [] [Whitespace(" ")],
                                value: CssGenericComponentValueList [
                                    CssBracketedValue {
                                        l_brack_token: L_BRACK@115..116 "[" [] [],
                                        items: CssBracketedValueList [
                                            CssCustomIdentifier {
                                                value_token: IDENT@116..122 "first" [] [Whitespace(" ")],
                                            },
                                            CssCustomIdentifier {
                                                value_token: IDENT@122..131 "nav-start" [] [],
                                            },
                                        ],
                                        r_brack_token: R_BRACK@131..133 "]" [] [Whitespace(" ")],
                                    },
                                    CssRegularDimension {
                                        value_token: CSS_NUMBER_LITERAL@133..136 "150" [] [],
                                        unit_token: IDENT@136..139 "px" [] [Whitespace(" ")],
                                    },
                                    CssBracketedValue {
                                        l_brack_token: L_BRACK@139..140 "[" [] [],
                                        items: CssBracketedValueList [
                                            CssCustomIdentifier {
                                                value_token: IDENT@140..150 "main-start" [] [],
                                            },
                                        ],
                                        r_brack_token: R_BRACK@150..152 "]" [] [Whitespace(" ")],
                                    },
                                    CssRegularDimension {
                                        value_token: CSS_NUMBER_LITERAL@152..153 "1" [] [],
                                        unit_token: IDENT@153..156 "fr" [] [Whitespace(" ")],
                                    },
                                    CssBracketedValue {
                                        l_brack_token: L_BRACK@156..157 "[" [] [],
                                        items: CssBracketedValueList [
                                            CssCustomIdentifier {
                                                value_token: IDENT@157..161 "last" [] [],
                                            },
                                        ],
                                        r_brack_token: R_BRACK@161..162 "]" [] [],
                                    },
                                ],
                            },
                            important: missing (optional),
                        },
                        semicolon_token: SEMICOLON@162..163 ";" [] [],
                    },
                    CssDeclarationWithSemicolon {
                        declaration: CssDeclaration {
                            property: CssGenericProperty {
                                name: CssIdentifier {
                                    value_token: IDENT@163..183 "grid-template-rows" [Newline("\n"), Whitespace("\t")] [],
                                },
                                colon_token: COLON@183..185 ":" [] [Whitespace(" ")],
                                value: CssGenericComponentValueList [
                                    CssBracketedValue {
                                        l_brack_token: L_BRACK@185..186 "[" [] [],
                                        items: CssBracketedValueList [
                                            CssCustomIdentifier {
                                                value_token: IDENT@186..192 "first" [] [Whitespace(" ")],
                                            },
                                            CssCustomIdentifier {
                                                value_token: IDENT@192..204 "header-start" [] [],
                                            },
                                        ],
                                        r_brack_token: R_BRACK@204..206 "]" [] [Whitespace(" ")],
                                    },
                                    CssRegularDimension {
                                        value_token: CSS_NUMBER_LITERAL@206..208 "50" [] [],
                                        unit_token: IDENT@208..211 "px" [] [Whitespace(" ")],
                                    },
                                    CssBracketedValue {
                                        l_brack_token: L_BRACK@211..212 "[" [] [],
                                        items: CssBracketedValueList [
                                            CssCustomIdentifier {
                                                value_token: IDENT@212..222 "main-start" [] [],
                                            },
                                        ],
                                        r_brack_token: R_BRACK@222..224 "]" [] [Whitespace(" ")],
                                    },
                                    CssRegularDimension {
                                        value_token: CSS_NUMBER_LITERAL@224..225 "1" [] [],
                                        unit_token: IDENT@225..228 "fr" [] [Whitespace(" ")],
                                    },
                                    CssBracketedValue {
                                        l_brack_token: L_BRACK@228..229 "[" [] [],
                                        items: CssBracketedValueList [
                                            CssCustomIdentifier {
                                                value_token: IDENT@229..241 "footer-start" [] [],
                                            },
                                        ],
                                        r_brack_token: R_BRACK@241..243 "]" [] [Whitespace(" ")],
                                    },
                                    CssRegularDimension {
                                        value_token: CSS_NUMBER_LITERAL@243..245 "50" [] [],
                                        unit_token: IDENT@245..248 "px" [] [Whitespace(" ")],
                                    },
                                    CssBracketedValue {
                                        l_brack_token: L_BRACK@248..249 "[" [] [],
                                        items: CssBracketedValueList [
                                            CssCustomIdentifier {
                                                value_token: IDENT@249..253 "last" [] [],
                                            },
                                        ],
                                        r_brack_token: R_BRACK@253..254 "]" [] [],
                                    },
                                ],
                            },
                            important: missing (optional),
                        },
                        semicolon_token: SEMICOLON@254..255 ";" [] [],
                    },
                ],
                r_curly_token: R_CURLY@255..257 "}" [Newline("\n")] [],
            },
        },
    ],
    eof_token: EOF@257..258 "" [Newline("\n")] [],
}
```

## CST

```
0: CSS_ROOT@0..258
  0: (empty)
  1: CSS_RULE_LIST@0..257
    0: CSS_QUALIFIED_RULE@0..65
      0: CSS_SELECTOR_LIST@0..12
        0: CSS_COMPOUND_SELECTOR@0..12
          0: CSS_NESTED_SELECTOR_LIST@0..0
          1: (empty)
          2: CSS_SUB_SELECTOR_LIST@0..12
            0: CSS_CLASS_SELECTOR@0..12
              0: DOT@0..1 "." [] []
              1: CSS_CUSTOM_IDENTIFIER@1..12
                0: IDENT@1..12 "chat-image" [] [Whitespace(" ")]
      1: CSS_DECLARATION_OR_RULE_BLOCK@12..65
        0: L_CURLY@12..13 "{" [] []
        1: CSS_DECLARATION_OR_RULE_LIST@13..63
          0: CSS_DECLARATION_WITH_SEMICOLON@13..41
            0: CSS_DECLARATION@13..40
              0: CSS_GENERIC_PROPERTY@13..40
                0: CSS_IDENTIFIER@13..23
                  0: IDENT@13..23 "grid-row" [Newline("\n"), Whitespace("\t")] []
                1: COLON@23..25 ":" [] [Whitespace(" ")]
                2: CSS_GENERIC_COMPONENT_VALUE_LIST@25..40
                  0: CSS_IDENTIFIER@25..30
                    0: IDENT@25..30 "span" [] [Whitespace(" ")]
                  1: CSS_NUMBER@30..32
                    0: CSS_NUMBER_LITERAL@30..32 "2" [] [Whitespace(" ")]
                  2: CSS_GENERIC_DELIMITER@32..34
                    0: SLASH@32..34 "/" [] [Whitespace(" ")]
                  3: CSS_IDENTIFIER@34..39
                    0: IDENT@34..39 "span" [] [Whitespace(" ")]
                  4: CSS_NUMBER@39..40
                    0: CSS_NUMBER_LITERAL@39..40 "2" [] []
              1: (empty)
            1: SEMICOLON@40..41 ";" [] []
          1: CSS_DECLARATION_WITH_SEMICOLON@41..63
            0: CSS_DECLARATION@41..63
              0: CSS_GENERIC_PROPERTY@41..63
                0: CSS_IDENTIFIER@41..53
                  0: IDENT@41..53 "align-self" [Newline("\n"), Whitespace("\t")] []
                1: COLON@53..55 ":" [] [Whitespace(" ")]
                2: CSS_GENERIC_COMPONENT_VALUE_LIST@55..63
                  0: CSS_IDENTIFIER@55..63
                    0: IDENT@55..63 "flex-end" [] []
              1: (empty)
            1: (empty)
        2: R_CURLY@63..65 "}" [Newline("\n")] []
    1: CSS_QUALIFIED_RULE@65..257
      0: CSS_SELECTOR_LIST@65..73
        0: CSS_COMPOUND_SELECTOR@65..73
          0: CSS_NESTED_SELECTOR_LIST@65..65
          1: (empty)
          2: CSS_SUB_SELECTOR_LIST@65..73
            0: CSS_ID_SELECTOR@65..73
              0: HASH@65..68 "#" [Newline("\n"), Newline("\n")] []
              1: CSS_CUSTOM_IDENTIFIER@68..73
                0: IDENT@68..73 "grid" [] [Whitespace(" ")]
      1: CSS_DECLARATION_OR_RULE_BLOCK@73..257
        0: L_CURLY@73..74 "{" [] []
        1: CSS_DECLARATION_OR_RULE_LIST@74..255
          0: CSS_DECLARATION_WITH_SEMICOLON@74..90
            0: CSS_DECLARATION@74..89
              0: CSS_GENERIC_PROPERTY@74..89
                0: CSS_IDENTIFIER@74..83
                  0: IDENT@74..83 "display" [Newline("\n"), Whitespace("\t")] []
                1: COLON@83..85 ":" [] [Whitespace(" ")]
                2: CSS_GENERIC_COMPONENT_VALUE_LIST@85..89
                  0: CSS_IDENTIFIER@85..89
                    0: IDENT@85..89 "grid" [] []
              1: (empty)
            1: SEMICOLON@89..90 ";" [] []
          1: CSS_DECLARATION_WITH_SEMICOLON@90..163
            0: CSS_DECLARATION@90..162
              0: CSS_GENERIC_PROPERTY@90..162
                0: CSS_IDENTIFIER@90..113
                  0: IDENT@90..113 "grid-template-columns" [Newline("\n"), Whitespace("\t")] []
                1: COLON@113..115 ":" [] [Whitespace(" ")]
                2: CSS_GENERIC_COMPONENT_VALUE_LIST@115..162
                  0: CSS_BRACKETED_VALUE@115..133
                    0: L_BRACK@115..116 "[" [] []
                    1: CSS_BRACKETED_VALUE_LIST@116..131
                      0: CSS_CUSTOM_IDENTIFIER@116..122
                        0: IDENT@116..122 "first" [] [Whitespace(" ")]
                      1: CSS_CUSTOM_IDENTIFIER@122..131
                        0: IDENT@122..131 "nav-start" [] []
                    2: R_BRACK@131..133 "]" [] [Whitespace(" ")]
                  1: CSS_REGULAR_DIMENSION@133..139
                    0: CSS_NUMBER_LITERAL@133..136 "150" [] []
                    1: IDENT@136..139 "px" [] [Whitespace(" ")]
                  2: CSS_BRACKETED_VALUE@139..152
                    0: L_BRACK@139..140 "[" [] []
                    1: CSS_BRACKETED_VALUE_LIST@140..150
                      0: CSS_CUSTOM_IDENTIFIER@140..150
                        0: IDENT@140..150 "main-start" [] []
                    2: R_BRACK@150..152 "]" [] [Whitespace(" ")]
                  3: CSS_REGULAR_DIMENSION@152..156
                    0: CSS_NUMBER_LITERAL@152..153 "1" [] []
                    1: IDENT@153..156 "fr" [] [Whitespace(" ")]
                  4: CSS_BRACKETED_VALUE@156..162
                    0: L_BRACK@156..157 "[" [] []
                    1: CSS_BRACKETED_VALUE_LIST@157..161
                      0: CSS_CUSTOM_IDENTIFIER@157..161
                        0: IDENT@157..161 "last" [] []
                    2: R_BRACK@161..162 "]" [] []
              1: (empty)
            1: SEMICOLON@162..163 ";" [] []
          2: CSS_DECLARATION_WITH_SEMICOLON@163..255
            0: CSS_DECLARATION@163..254
              0: CSS_GENERIC_PROPERTY@163..254
                0: CSS_IDENTIFIER@163..183
                  0: IDENT@163..183 "grid-template-rows" [Newline("\n"), Whitespace("\t")] []
                1: COLON@183..185 ":" [] [Whitespace(" ")]
                2: CSS_GENERIC_COMPONENT_VALUE_LIST@185..254
                  0: CSS_BRACKETED_VALUE@185..206
                    0: L_BRACK@185..186 "[" [] []
                    1: CSS_BRACKETED_VALUE_LIST@186..204
                      0: CSS_CUSTOM_IDENTIFIER@186..192
                        0: IDENT@186..192 "first" [] [Whitespace(" ")]
                      1: CSS_CUSTOM_IDENTIFIER@192..204
                        0: IDENT@192..204 "header-start" [] []
                    2: R_BRACK@204..206 "]" [] [Whitespace(" ")]
                  1: CSS_REGULAR_DIMENSION@206..211
                    0: CSS_NUMBER_LITERAL@206..208 "50" [] []
                    1: IDENT@208..211 "px" [] [Whitespace(" ")]
                  2: CSS_BRACKETED_VALUE@211..224
                    0: L_BRACK@211..212 "[" [] []
                    1: CSS_BRACKETED_VALUE_LIST@212..222
                      0: CSS_CUSTOM_IDENTIFIER@212..222
                        0: IDENT@212..222 "main-start" [] []
                    2: R_BRACK@222..224 "]" [] [Whitespace(" ")]
                  3: CSS_REGULAR_DIMENSION@224..228
                    0: CSS_NUMBER_LITERAL@224..225 "1" [] []
                    1: IDENT@225..228 "fr" [] [Whitespace(" ")]
                  4: CSS_BRACKETED_VALUE@228..243
                    0: L_BRACK@228..229 "[" [] []
                    1: CSS_BRACKETED_VALUE_LIST@229..241
                      0: CSS_CUSTOM_IDENTIFIER@229..241
                        0: IDENT@229..241 "footer-start" [] []
                    2: R_BRACK@241..243 "]" [] [Whitespace(" ")]
                  5: CSS_REGULAR_DIMENSION@243..248
                    0: CSS_NUMBER_LITERAL@243..245 "50" [] []
                    1: IDENT@245..248 "px" [] [Whitespace(" ")]
                  6: CSS_BRACKETED_VALUE@248..254
                    0: L_BRACK@248..249 "[" [] []
                    1: CSS_BRACKETED_VALUE_LIST@249..253
                      0: CSS_CUSTOM_IDENTIFIER@249..253
                        0: IDENT@249..253 "last" [] []
                    2: R_BRACK@253..254 "]" [] []
              1: (empty)
            1: SEMICOLON@254..255 ";" [] []
        2: R_CURLY@255..257 "}" [Newline("\n")] []
  2: EOF@257..258 "" [Newline("\n")] []

```