diff --git a/CHANGELOG.md b/CHANGELOG.md index 8442cc65169a..bc478440c003 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -28,6 +28,10 @@ our [guidelines for writing a good changelog entry](https://github.com/biomejs/b ### Formatter +### Bug fixes + +- Fix [#4121](https://github.com/biomejs/biome/issues/4326), don't ident css selector when has leading comments. Contributed by @fireairforce + ### JavaScript APIs ### Linter diff --git a/crates/biome_css_formatter/src/css/lists/relative_selector_list.rs b/crates/biome_css_formatter/src/css/lists/relative_selector_list.rs index 566e6e53982a..66263b1fe3bb 100644 --- a/crates/biome_css_formatter/src/css/lists/relative_selector_list.rs +++ b/crates/biome_css_formatter/src/css/lists/relative_selector_list.rs @@ -13,19 +13,34 @@ impl FormatRule for FormatCssRelativeSelectorList { let mut joiner = f.join_with(&separator); for formatted in node.format_separated(",") { - // Each selector gets `indent` added in case it breaks over multiple - // lines. The break is added here rather than in each selector both - // for simplicity and to avoid recursively adding indents when - // selectors are nested within other rules. The group is then added - // around the indent to ensure that it tries using a flat layout - // first and only expands when the single selector can't fit the line. - // - // For example, a selector like `div span a` is structured like - // `[div, [span, [a]]]`, so `a` would end up double-indented if it - // was handled by the selector rather than here. - joiner.entry(&group(&indent(&formatted))); + let has_comments_before = formatted.node()? + .as_css_relative_selector() + .and_then(|relative_selector| relative_selector.selector()?.as_css_compound_selector()) + .and_then(|computed_selector| computed_selector.simple_selector()) + .and_then(|simple_selector| simple_selector.as_css_type_selector()) + .and_then(|type_selector| type_selector.ident()?.value_token()?.has_leading_comments()) + .unwrap_or_default(); + + if has_comments_before { + // Computed Selector which contains a leading comments should be formatted without indent. + joiner.entry(&group(&formatted)); + } else { + // Each selector gets `indent` added in case it breaks over multiple + // lines. The break is added here rather than in each selector both + // for simplicity and to avoid recursively adding indents when + // selectors are nested within other rules. The group is then added + // around the indent to ensure that it tries using a flat layout + // first and only expands when the single selector can't fit the line. + // + // For example, a selector like `div span a` is structured like + // `[div, [span, [a]]]`, so `a` would end up double-indented if it + // was handled by the selector rather than here. + joiner.entry(&group(&indent(&formatted))); + } } joiner.finish() } } + + diff --git a/crates/biome_css_formatter/tests/quick_test.rs b/crates/biome_css_formatter/tests/quick_test.rs index 8a99a5184d83..d447f4abcb66 100644 --- a/crates/biome_css_formatter/tests/quick_test.rs +++ b/crates/biome_css_formatter/tests/quick_test.rs @@ -16,7 +16,7 @@ fn quick_test() { @charset "UTF-8"; "#; let parse = parse_css(src, CssParserOptions::default()); - println!("{parse:#?}"); + // println!("{parse:#?}"); let options = CssFormatOptions::default() .with_line_width(LineWidth::try_from(80).unwrap()) diff --git a/crates/biome_css_formatter/tests/specs/css/declaration_list.css b/crates/biome_css_formatter/tests/specs/css/declaration_list.css index 2d9252e42926..780622ef405b 100644 --- a/crates/biome_css_formatter/tests/specs/css/declaration_list.css +++ b/crates/biome_css_formatter/tests/specs/css/declaration_list.css @@ -34,4 +34,20 @@ a { a { color: red;;;; +} + +.with-comments { + /* hello */ + a, + /* world */ + button { + color: blue; + } +} + +.without-comments { + a, + button { + color: blue; + } } \ No newline at end of file diff --git a/crates/biome_css_formatter/tests/specs/css/declaration_list.css.snap b/crates/biome_css_formatter/tests/specs/css/declaration_list.css.snap index e168c99e2562..9db6650632b6 100644 --- a/crates/biome_css_formatter/tests/specs/css/declaration_list.css.snap +++ b/crates/biome_css_formatter/tests/specs/css/declaration_list.css.snap @@ -42,6 +42,22 @@ a { a { color: red;;;; } + +.with-comments { + /* hello */ + a, + /* world */ + button { + color: blue; + } +} + +.without-comments { + a, + button { + color: blue; + } +} ``` @@ -103,4 +119,20 @@ a { a { color: red; } + +.with-comments { + /* hello */ + a, + /* world */ + button { + color: blue; + } +} + +.without-comments { + a, + button { + color: blue; + } +} ```