From 32b2ca90c2e59c31a0abc4ce9afe5e3b8d5ba77a Mon Sep 17 00:00:00 2001 From: togami2864 Date: Fri, 6 Sep 2024 22:20:00 +0900 Subject: [PATCH 1/2] chore: rename useConsistentGridAreas to noInvalidGridAreas --- .../src/analyzer/linter/rules.rs | 14 ++++---- crates/biome_css_analyze/src/lint/nursery.rs | 4 +-- ...grid_areas.rs => no_invalid_grid_areas.rs} | 6 ++-- crates/biome_css_analyze/src/options.rs | 3 +- .../invalid.css | 0 .../invalid.css.snap | 20 +++++------ .../valid.css | 0 .../valid.css.snap | 0 .../src/categories.rs | 2 +- .../@biomejs/backend-jsonrpc/src/workspace.ts | 36 +++++++++---------- .../@biomejs/biome/configuration_schema.json | 2 +- 11 files changed, 44 insertions(+), 43 deletions(-) rename crates/biome_css_analyze/src/lint/nursery/{use_consistent_grid_areas.rs => no_invalid_grid_areas.rs} (98%) rename crates/biome_css_analyze/tests/specs/nursery/{useConsistentGridAreas => noInvalidGridAreas}/invalid.css (100%) rename crates/biome_css_analyze/tests/specs/nursery/{useConsistentGridAreas => noInvalidGridAreas}/invalid.css.snap (85%) rename crates/biome_css_analyze/tests/specs/nursery/{useConsistentGridAreas => noInvalidGridAreas}/valid.css (100%) rename crates/biome_css_analyze/tests/specs/nursery/{useConsistentGridAreas => noInvalidGridAreas}/valid.css.snap (100%) diff --git a/crates/biome_configuration/src/analyzer/linter/rules.rs b/crates/biome_configuration/src/analyzer/linter/rules.rs index e383a1117fa2..925470a4e26f 100644 --- a/crates/biome_configuration/src/analyzer/linter/rules.rs +++ b/crates/biome_configuration/src/analyzer/linter/rules.rs @@ -3031,8 +3031,8 @@ pub struct Nursery { Option>, #[doc = "Disallows invalid named grid areas in CSS Grid Layouts."] #[serde(skip_serializing_if = "Option::is_none")] - pub use_consistent_grid_areas: - Option>, + pub no_invalid_grid_areas: + Option>, #[doc = "Require consistent accessibility modifiers on class properties and methods."] #[serde(skip_serializing_if = "Option::is_none")] pub use_consistent_member_accessibility: @@ -3165,7 +3165,7 @@ impl Nursery { "useAriaPropsSupportedByRole", "useConsistentBuiltinInstantiation", "useConsistentCurlyBraces", - "useConsistentGridAreas", + "noInvalidGridAreas", "useConsistentMemberAccessibility", "useDateNow", "useDefaultSwitchClause", @@ -3531,7 +3531,7 @@ impl Nursery { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[41])); } } - if let Some(rule) = self.use_consistent_grid_areas.as_ref() { + if let Some(rule) = self.no_invalid_grid_areas.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[42])); } @@ -3845,7 +3845,7 @@ impl Nursery { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[41])); } } - if let Some(rule) = self.use_consistent_grid_areas.as_ref() { + if let Some(rule) = self.no_invalid_grid_areas.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[42])); } @@ -4149,8 +4149,8 @@ impl Nursery { .use_consistent_curly_braces .as_ref() .map(|conf| (conf.level(), conf.get_options())), - "useConsistentGridAreas" => self - .use_consistent_grid_areas + "noInvalidGridAreas" => self + .no_invalid_grid_areas .as_ref() .map(|conf| (conf.level(), conf.get_options())), "useConsistentMemberAccessibility" => self diff --git a/crates/biome_css_analyze/src/lint/nursery.rs b/crates/biome_css_analyze/src/lint/nursery.rs index 9f8756a5435d..9d7fd1873d19 100644 --- a/crates/biome_css_analyze/src/lint/nursery.rs +++ b/crates/biome_css_analyze/src/lint/nursery.rs @@ -8,6 +8,7 @@ pub mod no_duplicate_selectors_keyframe_block; pub mod no_empty_block; pub mod no_important_in_keyframe; pub mod no_invalid_direction_in_linear_gradient; +pub mod no_invalid_grid_areas; pub mod no_invalid_position_at_import_rule; pub mod no_irregular_whitespace; pub mod no_shorthand_property_overrides; @@ -19,7 +20,6 @@ pub mod no_unknown_selector_pseudo_element; pub mod no_unknown_unit; pub mod no_unmatchable_anb_selector; pub mod no_value_at_rule; -pub mod use_consistent_grid_areas; pub mod use_generic_font_names; declare_lint_group! { @@ -43,7 +43,7 @@ declare_lint_group! { self :: no_unknown_unit :: NoUnknownUnit , self :: no_unmatchable_anb_selector :: NoUnmatchableAnbSelector , self :: no_value_at_rule :: NoValueAtRule , - self :: use_consistent_grid_areas :: UseConsistentGridAreas , + self :: no_invalid_grid_areas :: NoInvalidGridAreas , self :: use_generic_font_names :: UseGenericFontNames , ] } diff --git a/crates/biome_css_analyze/src/lint/nursery/use_consistent_grid_areas.rs b/crates/biome_css_analyze/src/lint/nursery/no_invalid_grid_areas.rs similarity index 98% rename from crates/biome_css_analyze/src/lint/nursery/use_consistent_grid_areas.rs rename to crates/biome_css_analyze/src/lint/nursery/no_invalid_grid_areas.rs index 4fa6131cbb1c..c4a44b0766d4 100644 --- a/crates/biome_css_analyze/src/lint/nursery/use_consistent_grid_areas.rs +++ b/crates/biome_css_analyze/src/lint/nursery/no_invalid_grid_areas.rs @@ -48,9 +48,9 @@ declare_lint_rule! { /// "a a a"; } /// ``` /// - pub UseConsistentGridAreas { + pub NoInvalidGridAreas { version: "next", - name: "useConsistentGridAreas", + name: "noInvalidGridAreas", language: "css", recommended: false, sources: &[RuleSource::Stylelint("named-grid-areas-no-invalid")], @@ -73,7 +73,7 @@ pub struct UseConsistentGridAreasState { reason: GridAreaValidationError, } -impl Rule for UseConsistentGridAreas { +impl Rule for NoInvalidGridAreas { type Query = Ast; type State = UseConsistentGridAreasState; type Signals = Option; diff --git a/crates/biome_css_analyze/src/options.rs b/crates/biome_css_analyze/src/options.rs index 5b7f7b1810e1..a607e7e59fd2 100644 --- a/crates/biome_css_analyze/src/options.rs +++ b/crates/biome_css_analyze/src/options.rs @@ -26,6 +26,7 @@ pub type NoUnknownUnit = pub type NoUnmatchableAnbSelector = < lint :: nursery :: no_unmatchable_anb_selector :: NoUnmatchableAnbSelector as biome_analyze :: Rule > :: Options ; pub type NoValueAtRule = ::Options; -pub type UseConsistentGridAreas = < lint :: nursery :: use_consistent_grid_areas :: UseConsistentGridAreas as biome_analyze :: Rule > :: Options ; +pub type NoInvalidGridAreas = + ::Options; pub type UseGenericFontNames = ::Options; diff --git a/crates/biome_css_analyze/tests/specs/nursery/useConsistentGridAreas/invalid.css b/crates/biome_css_analyze/tests/specs/nursery/noInvalidGridAreas/invalid.css similarity index 100% rename from crates/biome_css_analyze/tests/specs/nursery/useConsistentGridAreas/invalid.css rename to crates/biome_css_analyze/tests/specs/nursery/noInvalidGridAreas/invalid.css diff --git a/crates/biome_css_analyze/tests/specs/nursery/useConsistentGridAreas/invalid.css.snap b/crates/biome_css_analyze/tests/specs/nursery/noInvalidGridAreas/invalid.css.snap similarity index 85% rename from crates/biome_css_analyze/tests/specs/nursery/useConsistentGridAreas/invalid.css.snap rename to crates/biome_css_analyze/tests/specs/nursery/noInvalidGridAreas/invalid.css.snap index 16c8e4b54ce5..90975df85f82 100644 --- a/crates/biome_css_analyze/tests/specs/nursery/useConsistentGridAreas/invalid.css.snap +++ b/crates/biome_css_analyze/tests/specs/nursery/noInvalidGridAreas/invalid.css.snap @@ -37,7 +37,7 @@ a { grid-template-areas: "a a a" # Diagnostics ``` -invalid.css:1:26 lint/nursery/useConsistentGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +invalid.css:1:26 lint/nursery/noInvalidGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ! Empty grid areas are not allowed. @@ -52,7 +52,7 @@ invalid.css:1:26 lint/nursery/useConsistentGridAreas ━━━━━━━━━ ``` ``` -invalid.css:2:26 lint/nursery/useConsistentGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +invalid.css:2:26 lint/nursery/noInvalidGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ! Inconsistent cell count in grid areas are not allowed. @@ -68,7 +68,7 @@ invalid.css:2:26 lint/nursery/useConsistentGridAreas ━━━━━━━━━ ``` ``` -invalid.css:4:33 lint/nursery/useConsistentGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +invalid.css:4:33 lint/nursery/noInvalidGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ! Empty grid areas are not allowed. @@ -87,7 +87,7 @@ invalid.css:4:33 lint/nursery/useConsistentGridAreas ━━━━━━━━━ ``` ``` -invalid.css:6:33 lint/nursery/useConsistentGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +invalid.css:6:33 lint/nursery/noInvalidGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ! Duplicate filled in rectangle are not allowed. @@ -106,7 +106,7 @@ invalid.css:6:33 lint/nursery/useConsistentGridAreas ━━━━━━━━━ ``` ``` -invalid.css:11:33 lint/nursery/useConsistentGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +invalid.css:11:33 lint/nursery/noInvalidGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ! Duplicate filled in rectangle are not allowed. @@ -125,7 +125,7 @@ invalid.css:11:33 lint/nursery/useConsistentGridAreas ━━━━━━━━ ``` ``` -invalid.css:15:33 lint/nursery/useConsistentGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +invalid.css:15:33 lint/nursery/noInvalidGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ! Duplicate filled in rectangle are not allowed. @@ -144,7 +144,7 @@ invalid.css:15:33 lint/nursery/useConsistentGridAreas ━━━━━━━━ ``` ``` -invalid.css:17:35 lint/nursery/useConsistentGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +invalid.css:17:35 lint/nursery/noInvalidGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ! Duplicate filled in rectangle are not allowed. @@ -163,7 +163,7 @@ invalid.css:17:35 lint/nursery/useConsistentGridAreas ━━━━━━━━ ``` ``` -invalid.css:21:35 lint/nursery/useConsistentGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +invalid.css:21:35 lint/nursery/noInvalidGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ! Inconsistent cell count in grid areas are not allowed. @@ -182,7 +182,7 @@ invalid.css:21:35 lint/nursery/useConsistentGridAreas ━━━━━━━━ ``` ``` -invalid.css:24:33 lint/nursery/useConsistentGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +invalid.css:24:33 lint/nursery/noInvalidGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ! Duplicate filled in rectangle are not allowed. @@ -201,7 +201,7 @@ invalid.css:24:33 lint/nursery/useConsistentGridAreas ━━━━━━━━ ``` ``` -invalid.css:27:33 lint/nursery/useConsistentGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +invalid.css:27:33 lint/nursery/noInvalidGridAreas ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ ! Duplicate filled in rectangle are not allowed. diff --git a/crates/biome_css_analyze/tests/specs/nursery/useConsistentGridAreas/valid.css b/crates/biome_css_analyze/tests/specs/nursery/noInvalidGridAreas/valid.css similarity index 100% rename from crates/biome_css_analyze/tests/specs/nursery/useConsistentGridAreas/valid.css rename to crates/biome_css_analyze/tests/specs/nursery/noInvalidGridAreas/valid.css diff --git a/crates/biome_css_analyze/tests/specs/nursery/useConsistentGridAreas/valid.css.snap b/crates/biome_css_analyze/tests/specs/nursery/noInvalidGridAreas/valid.css.snap similarity index 100% rename from crates/biome_css_analyze/tests/specs/nursery/useConsistentGridAreas/valid.css.snap rename to crates/biome_css_analyze/tests/specs/nursery/noInvalidGridAreas/valid.css.snap diff --git a/crates/biome_diagnostics_categories/src/categories.rs b/crates/biome_diagnostics_categories/src/categories.rs index 32392bbdb70b..8a3f64bd526c 100644 --- a/crates/biome_diagnostics_categories/src/categories.rs +++ b/crates/biome_diagnostics_categories/src/categories.rs @@ -159,7 +159,7 @@ define_categories! { "lint/nursery/useBiomeSuppressionComment": "https://biomejs.dev/linter/rules/use-biome-suppression-comment", "lint/nursery/useConsistentBuiltinInstantiation": "https://biomejs.dev/linter/rules/use-consistent-new-builtin", "lint/nursery/useConsistentCurlyBraces": "https://biomejs.dev/linter/rules/use-consistent-curly-braces", - "lint/nursery/useConsistentGridAreas": "https://biomejs.dev/linter/rules/use-consistent-grid-areas", + "lint/nursery/noInvalidGridAreas": "https://biomejs.dev/linter/rules/use-consistent-grid-areas", "lint/nursery/useConsistentMemberAccessibility": "https://biomejs.dev/linter/rules/use-consistent-member-accessibility", "lint/nursery/useDateNow": "https://biomejs.dev/linter/rules/use-date-now", "lint/nursery/useDefaultSwitchClause": "https://biomejs.dev/linter/rules/use-default-switch-clause", diff --git a/packages/@biomejs/backend-jsonrpc/src/workspace.ts b/packages/@biomejs/backend-jsonrpc/src/workspace.ts index 7a5f8934758e..0309841a6a78 100644 --- a/packages/@biomejs/backend-jsonrpc/src/workspace.ts +++ b/packages/@biomejs/backend-jsonrpc/src/workspace.ts @@ -243,7 +243,7 @@ export interface PartialJavascriptConfiguration { /** * A list of global bindings that should be ignored by the analyzers -If defined here, they should not emit diagnostics. +If defined here, they should not emit diagnostics. */ globals?: StringSet; /** @@ -333,7 +333,7 @@ export interface PartialVcsConfiguration { /** * The folder where Biome should check for VCS files. By default, Biome will use the same folder where `biome.json` was found. -If Biome can't find the configuration, it will attempt to use the current working directory. If no current working directory can't be found, Biome won't use the VCS integration, and a diagnostic will be emitted +If Biome can't find the configuration, it will attempt to use the current working directory. If no current working directory can't be found, Biome won't use the VCS integration, and a diagnostic will be emitted */ root?: string; /** @@ -412,7 +412,7 @@ export type LineEnding = "lf" | "crlf" | "cr"; /** * Validated value for the `line_width` formatter options -The allowed range of values is 1..=320 +The allowed range of values is 1..=320 */ export type LineWidth = number; /** @@ -556,7 +556,7 @@ export interface PartialJavascriptParser { /** * It enables the experimental and unsafe parsing of parameter decorators -These decorators belong to an old proposal, and they are subject to change. +These decorators belong to an old proposal, and they are subject to change. */ unsafeParameterDecoratorsEnabled?: boolean; } @@ -1322,7 +1322,7 @@ export interface Nursery { /** * Disallows invalid named grid areas in CSS Grid Layouts. */ - useConsistentGridAreas?: RuleConfiguration_for_Null; + noInvalidGridAreas?: RuleConfiguration_for_Null; /** * Require consistent accessibility modifiers on class properties and methods. */ @@ -2375,7 +2375,7 @@ export interface NoDoubleEqualsOptions { /** * If `true`, an exception is made when comparing with `null`, as it's often relied on to check both for `null` or `undefined`. -If `false`, no such exception will be made. +If `false`, no such exception will be made. */ ignoreNull: boolean; } @@ -2383,13 +2383,13 @@ export interface Hook { /** * The "position" of the closure function, starting from zero. -For example, for React's `useEffect()` hook, the closure index is 0. +For example, for React's `useEffect()` hook, the closure index is 0. */ closureIndex?: number; /** * The "position" of the array of dependencies, starting from zero. -For example, for React's `useEffect()` hook, the dependencies index is 1. +For example, for React's `useEffect()` hook, the dependencies index is 1. */ dependenciesIndex?: number; /** @@ -2401,7 +2401,7 @@ For example, for React's `useEffect()` hook, the dependencies index is 1. Set to `true` to mark the identity of the hook's return value as stable, or use a number/an array of numbers to mark the "positions" in the return array as stable. -For example, for React's `useRef()` hook the value would be `true`, while for `useState()` it would be `[1]`. +For example, for React's `useRef()` hook the value would be `true`, while for `useState()` it would be `[1]`. */ stableResult?: StableHookResult; } @@ -2557,13 +2557,13 @@ export type LanguageVariant = "Standard" | "StandardRestricted" | "Jsx"; /** * Enum of the different ECMAScript standard versions. The versions are ordered in increasing order; The newest version comes last. -Defaults to the latest stable ECMAScript standard. +Defaults to the latest stable ECMAScript standard. */ export type LanguageVersion = "ES2022" | "ESNext"; /** * The style of CSS contained in the file. -Currently, Biome only supports plain CSS, and aims to be compatible with the latest Recommendation level standards. +Currently, Biome only supports plain CSS, and aims to be compatible with the latest Recommendation level standards. */ export type CssVariant = "Standard"; /** @@ -2784,7 +2784,7 @@ export type Category = | "lint/nursery/useBiomeSuppressionComment" | "lint/nursery/useConsistentBuiltinInstantiation" | "lint/nursery/useConsistentCurlyBraces" - | "lint/nursery/useConsistentGridAreas" + | "lint/nursery/noInvalidGridAreas" | "lint/nursery/useConsistentMemberAccessibility" | "lint/nursery/useDateNow" | "lint/nursery/useDefaultSwitchClause" @@ -2962,7 +2962,7 @@ export type DiagnosticTags = DiagnosticTag[]; /** * Serializable representation of a [Diagnostic](super::Diagnostic) advice -See the [Visitor] trait for additional documentation on all the supported advice types. +See the [Visitor] trait for additional documentation on all the supported advice types. */ export type Advice = | { log: [LogCategory, MarkupBuf] } @@ -3055,7 +3055,7 @@ export interface CodeAction { /** * The category of a code action, this type maps directly to the [CodeActionKind] type in the Language Server Protocol specification -[CodeActionKind]: https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#codeActionKind +[CodeActionKind]: https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#codeActionKind */ export type ActionCategory = | "QuickFix" @@ -3075,7 +3075,7 @@ export interface CodeSuggestion { /** * The sub-category of a refactor code action. -[Check the LSP spec](https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#codeActionKind) for more information: +[Check the LSP spec](https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#codeActionKind) for more information: */ export type RefactorKind = | "None" @@ -3185,7 +3185,7 @@ export interface Workspace { fileFeatures(params: SupportsFeatureParams): Promise; updateSettings(params: UpdateSettingsParams): Promise; registerProjectFolder( - params: RegisterProjectFolderParams, + params: RegisterProjectFolderParams ): Promise; setManifestForProject(params: SetManifestForProjectParams): Promise; openFile(params: OpenFileParams): Promise; @@ -3193,13 +3193,13 @@ export interface Workspace { closeFile(params: CloseFileParams): Promise; getSyntaxTree(params: GetSyntaxTreeParams): Promise; organizeImports( - params: OrganizeImportsParams, + params: OrganizeImportsParams ): Promise; getFileContent(params: GetFileContentParams): Promise; getControlFlowGraph(params: GetControlFlowGraphParams): Promise; getFormatterIr(params: GetFormatterIRParams): Promise; pullDiagnostics( - params: PullDiagnosticsParams, + params: PullDiagnosticsParams ): Promise; pullActions(params: PullActionsParams): Promise; formatFile(params: FormatFileParams): Promise; diff --git a/packages/@biomejs/biome/configuration_schema.json b/packages/@biomejs/biome/configuration_schema.json index 2e096a5ac1b0..0319d26d3436 100644 --- a/packages/@biomejs/biome/configuration_schema.json +++ b/packages/@biomejs/biome/configuration_schema.json @@ -2235,7 +2235,7 @@ { "type": "null" } ] }, - "useConsistentGridAreas": { + "noInvalidGridAreas": { "description": "Disallows invalid named grid areas in CSS Grid Layouts.", "anyOf": [ { "$ref": "#/definitions/RuleConfiguration" }, From be650eea11599ee1a90ed0e34c92b2277fea33a5 Mon Sep 17 00:00:00 2001 From: togami2864 Date: Fri, 6 Sep 2024 22:29:09 +0900 Subject: [PATCH 2/2] chore: just gen-lint --- .../src/analyzer/linter/rules.rs | 148 +++++++++--------- crates/biome_css_analyze/src/lint/nursery.rs | 2 +- crates/biome_css_analyze/src/options.rs | 4 +- .../@biomejs/backend-jsonrpc/src/workspace.ts | 40 ++--- .../@biomejs/biome/configuration_schema.json | 14 +- 5 files changed, 104 insertions(+), 104 deletions(-) diff --git a/crates/biome_configuration/src/analyzer/linter/rules.rs b/crates/biome_configuration/src/analyzer/linter/rules.rs index 925470a4e26f..f2fefc237332 100644 --- a/crates/biome_configuration/src/analyzer/linter/rules.rs +++ b/crates/biome_configuration/src/analyzer/linter/rules.rs @@ -2920,6 +2920,10 @@ pub struct Nursery { #[serde(skip_serializing_if = "Option::is_none")] pub no_invalid_direction_in_linear_gradient: Option>, + #[doc = "Disallows invalid named grid areas in CSS Grid Layouts."] + #[serde(skip_serializing_if = "Option::is_none")] + pub no_invalid_grid_areas: + Option>, #[doc = "Disallow the use of @import at-rules in invalid positions."] #[serde(skip_serializing_if = "Option::is_none")] pub no_invalid_position_at_import_rule: @@ -3029,10 +3033,6 @@ pub struct Nursery { #[serde(skip_serializing_if = "Option::is_none")] pub use_consistent_curly_braces: Option>, - #[doc = "Disallows invalid named grid areas in CSS Grid Layouts."] - #[serde(skip_serializing_if = "Option::is_none")] - pub no_invalid_grid_areas: - Option>, #[doc = "Require consistent accessibility modifiers on class properties and methods."] #[serde(skip_serializing_if = "Option::is_none")] pub use_consistent_member_accessibility: @@ -3137,6 +3137,7 @@ impl Nursery { "noExportedImports", "noImportantInKeyframe", "noInvalidDirectionInLinearGradient", + "noInvalidGridAreas", "noInvalidPositionAtImportRule", "noIrregularWhitespace", "noLabelWithoutControl", @@ -3165,7 +3166,6 @@ impl Nursery { "useAriaPropsSupportedByRole", "useConsistentBuiltinInstantiation", "useConsistentCurlyBraces", - "noInvalidGridAreas", "useConsistentMemberAccessibility", "useDateNow", "useDefaultSwitchClause", @@ -3224,17 +3224,17 @@ impl Nursery { RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[8]), RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[12]), RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[13]), - RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[14]), - RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[16]), - RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[21]), - RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[25]), - RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[27]), + RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[15]), + RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[17]), + RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[22]), + RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[26]), RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[28]), RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[29]), RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[30]), RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[31]), - RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[33]), - RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[39]), + RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[32]), + RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[34]), + RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[40]), RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[43]), RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[46]), RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[49]), @@ -3391,147 +3391,147 @@ impl Nursery { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[13])); } } - if let Some(rule) = self.no_invalid_position_at_import_rule.as_ref() { + if let Some(rule) = self.no_invalid_grid_areas.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[14])); } } - if let Some(rule) = self.no_irregular_whitespace.as_ref() { + if let Some(rule) = self.no_invalid_position_at_import_rule.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[15])); } } - if let Some(rule) = self.no_label_without_control.as_ref() { + if let Some(rule) = self.no_irregular_whitespace.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[16])); } } - if let Some(rule) = self.no_misplaced_assertion.as_ref() { + if let Some(rule) = self.no_label_without_control.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[17])); } } - if let Some(rule) = self.no_react_specific_props.as_ref() { + if let Some(rule) = self.no_misplaced_assertion.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[18])); } } - if let Some(rule) = self.no_restricted_imports.as_ref() { + if let Some(rule) = self.no_react_specific_props.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[19])); } } - if let Some(rule) = self.no_restricted_types.as_ref() { + if let Some(rule) = self.no_restricted_imports.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[20])); } } - if let Some(rule) = self.no_shorthand_property_overrides.as_ref() { + if let Some(rule) = self.no_restricted_types.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[21])); } } - if let Some(rule) = self.no_static_element_interactions.as_ref() { + if let Some(rule) = self.no_shorthand_property_overrides.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[22])); } } - if let Some(rule) = self.no_substr.as_ref() { + if let Some(rule) = self.no_static_element_interactions.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[23])); } } - if let Some(rule) = self.no_undeclared_dependencies.as_ref() { + if let Some(rule) = self.no_substr.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[24])); } } - if let Some(rule) = self.no_unknown_function.as_ref() { + if let Some(rule) = self.no_undeclared_dependencies.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[25])); } } - if let Some(rule) = self.no_unknown_media_feature_name.as_ref() { + if let Some(rule) = self.no_unknown_function.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[26])); } } - if let Some(rule) = self.no_unknown_property.as_ref() { + if let Some(rule) = self.no_unknown_media_feature_name.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[27])); } } - if let Some(rule) = self.no_unknown_pseudo_class_selector.as_ref() { + if let Some(rule) = self.no_unknown_property.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[28])); } } - if let Some(rule) = self.no_unknown_selector_pseudo_element.as_ref() { + if let Some(rule) = self.no_unknown_pseudo_class_selector.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[29])); } } - if let Some(rule) = self.no_unknown_unit.as_ref() { + if let Some(rule) = self.no_unknown_selector_pseudo_element.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[30])); } } - if let Some(rule) = self.no_unmatchable_anb_selector.as_ref() { + if let Some(rule) = self.no_unknown_unit.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[31])); } } - if let Some(rule) = self.no_unused_function_parameters.as_ref() { + if let Some(rule) = self.no_unmatchable_anb_selector.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[32])); } } - if let Some(rule) = self.no_useless_escape_in_regex.as_ref() { + if let Some(rule) = self.no_unused_function_parameters.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[33])); } } - if let Some(rule) = self.no_useless_string_concat.as_ref() { + if let Some(rule) = self.no_useless_escape_in_regex.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[34])); } } - if let Some(rule) = self.no_useless_undefined_initialization.as_ref() { + if let Some(rule) = self.no_useless_string_concat.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[35])); } } - if let Some(rule) = self.no_value_at_rule.as_ref() { + if let Some(rule) = self.no_useless_undefined_initialization.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[36])); } } - if let Some(rule) = self.no_yoda_expression.as_ref() { + if let Some(rule) = self.no_value_at_rule.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[37])); } } - if let Some(rule) = self.use_adjacent_overload_signatures.as_ref() { + if let Some(rule) = self.no_yoda_expression.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[38])); } } - if let Some(rule) = self.use_aria_props_supported_by_role.as_ref() { + if let Some(rule) = self.use_adjacent_overload_signatures.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[39])); } } - if let Some(rule) = self.use_consistent_builtin_instantiation.as_ref() { + if let Some(rule) = self.use_aria_props_supported_by_role.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[40])); } } - if let Some(rule) = self.use_consistent_curly_braces.as_ref() { + if let Some(rule) = self.use_consistent_builtin_instantiation.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[41])); } } - if let Some(rule) = self.no_invalid_grid_areas.as_ref() { + if let Some(rule) = self.use_consistent_curly_braces.as_ref() { if rule.is_enabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[42])); } @@ -3705,147 +3705,147 @@ impl Nursery { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[13])); } } - if let Some(rule) = self.no_invalid_position_at_import_rule.as_ref() { + if let Some(rule) = self.no_invalid_grid_areas.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[14])); } } - if let Some(rule) = self.no_irregular_whitespace.as_ref() { + if let Some(rule) = self.no_invalid_position_at_import_rule.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[15])); } } - if let Some(rule) = self.no_label_without_control.as_ref() { + if let Some(rule) = self.no_irregular_whitespace.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[16])); } } - if let Some(rule) = self.no_misplaced_assertion.as_ref() { + if let Some(rule) = self.no_label_without_control.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[17])); } } - if let Some(rule) = self.no_react_specific_props.as_ref() { + if let Some(rule) = self.no_misplaced_assertion.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[18])); } } - if let Some(rule) = self.no_restricted_imports.as_ref() { + if let Some(rule) = self.no_react_specific_props.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[19])); } } - if let Some(rule) = self.no_restricted_types.as_ref() { + if let Some(rule) = self.no_restricted_imports.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[20])); } } - if let Some(rule) = self.no_shorthand_property_overrides.as_ref() { + if let Some(rule) = self.no_restricted_types.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[21])); } } - if let Some(rule) = self.no_static_element_interactions.as_ref() { + if let Some(rule) = self.no_shorthand_property_overrides.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[22])); } } - if let Some(rule) = self.no_substr.as_ref() { + if let Some(rule) = self.no_static_element_interactions.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[23])); } } - if let Some(rule) = self.no_undeclared_dependencies.as_ref() { + if let Some(rule) = self.no_substr.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[24])); } } - if let Some(rule) = self.no_unknown_function.as_ref() { + if let Some(rule) = self.no_undeclared_dependencies.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[25])); } } - if let Some(rule) = self.no_unknown_media_feature_name.as_ref() { + if let Some(rule) = self.no_unknown_function.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[26])); } } - if let Some(rule) = self.no_unknown_property.as_ref() { + if let Some(rule) = self.no_unknown_media_feature_name.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[27])); } } - if let Some(rule) = self.no_unknown_pseudo_class_selector.as_ref() { + if let Some(rule) = self.no_unknown_property.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[28])); } } - if let Some(rule) = self.no_unknown_selector_pseudo_element.as_ref() { + if let Some(rule) = self.no_unknown_pseudo_class_selector.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[29])); } } - if let Some(rule) = self.no_unknown_unit.as_ref() { + if let Some(rule) = self.no_unknown_selector_pseudo_element.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[30])); } } - if let Some(rule) = self.no_unmatchable_anb_selector.as_ref() { + if let Some(rule) = self.no_unknown_unit.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[31])); } } - if let Some(rule) = self.no_unused_function_parameters.as_ref() { + if let Some(rule) = self.no_unmatchable_anb_selector.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[32])); } } - if let Some(rule) = self.no_useless_escape_in_regex.as_ref() { + if let Some(rule) = self.no_unused_function_parameters.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[33])); } } - if let Some(rule) = self.no_useless_string_concat.as_ref() { + if let Some(rule) = self.no_useless_escape_in_regex.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[34])); } } - if let Some(rule) = self.no_useless_undefined_initialization.as_ref() { + if let Some(rule) = self.no_useless_string_concat.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[35])); } } - if let Some(rule) = self.no_value_at_rule.as_ref() { + if let Some(rule) = self.no_useless_undefined_initialization.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[36])); } } - if let Some(rule) = self.no_yoda_expression.as_ref() { + if let Some(rule) = self.no_value_at_rule.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[37])); } } - if let Some(rule) = self.use_adjacent_overload_signatures.as_ref() { + if let Some(rule) = self.no_yoda_expression.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[38])); } } - if let Some(rule) = self.use_aria_props_supported_by_role.as_ref() { + if let Some(rule) = self.use_adjacent_overload_signatures.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[39])); } } - if let Some(rule) = self.use_consistent_builtin_instantiation.as_ref() { + if let Some(rule) = self.use_aria_props_supported_by_role.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[40])); } } - if let Some(rule) = self.use_consistent_curly_braces.as_ref() { + if let Some(rule) = self.use_consistent_builtin_instantiation.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[41])); } } - if let Some(rule) = self.no_invalid_grid_areas.as_ref() { + if let Some(rule) = self.use_consistent_curly_braces.as_ref() { if rule.is_disabled() { index_set.insert(RuleFilter::Rule(Self::GROUP_NAME, Self::GROUP_RULES[42])); } @@ -4037,6 +4037,10 @@ impl Nursery { .no_invalid_direction_in_linear_gradient .as_ref() .map(|conf| (conf.level(), conf.get_options())), + "noInvalidGridAreas" => self + .no_invalid_grid_areas + .as_ref() + .map(|conf| (conf.level(), conf.get_options())), "noInvalidPositionAtImportRule" => self .no_invalid_position_at_import_rule .as_ref() @@ -4149,10 +4153,6 @@ impl Nursery { .use_consistent_curly_braces .as_ref() .map(|conf| (conf.level(), conf.get_options())), - "noInvalidGridAreas" => self - .no_invalid_grid_areas - .as_ref() - .map(|conf| (conf.level(), conf.get_options())), "useConsistentMemberAccessibility" => self .use_consistent_member_accessibility .as_ref() diff --git a/crates/biome_css_analyze/src/lint/nursery.rs b/crates/biome_css_analyze/src/lint/nursery.rs index 9d7fd1873d19..8cb259df2a84 100644 --- a/crates/biome_css_analyze/src/lint/nursery.rs +++ b/crates/biome_css_analyze/src/lint/nursery.rs @@ -32,6 +32,7 @@ declare_lint_group! { self :: no_empty_block :: NoEmptyBlock , self :: no_important_in_keyframe :: NoImportantInKeyframe , self :: no_invalid_direction_in_linear_gradient :: NoInvalidDirectionInLinearGradient , + self :: no_invalid_grid_areas :: NoInvalidGridAreas , self :: no_invalid_position_at_import_rule :: NoInvalidPositionAtImportRule , self :: no_irregular_whitespace :: NoIrregularWhitespace , self :: no_shorthand_property_overrides :: NoShorthandPropertyOverrides , @@ -43,7 +44,6 @@ declare_lint_group! { self :: no_unknown_unit :: NoUnknownUnit , self :: no_unmatchable_anb_selector :: NoUnmatchableAnbSelector , self :: no_value_at_rule :: NoValueAtRule , - self :: no_invalid_grid_areas :: NoInvalidGridAreas , self :: use_generic_font_names :: UseGenericFontNames , ] } diff --git a/crates/biome_css_analyze/src/options.rs b/crates/biome_css_analyze/src/options.rs index a607e7e59fd2..6ae5fc95211d 100644 --- a/crates/biome_css_analyze/src/options.rs +++ b/crates/biome_css_analyze/src/options.rs @@ -10,6 +10,8 @@ pub type NoEmptyBlock = ::Options; pub type NoImportantInKeyframe = < lint :: nursery :: no_important_in_keyframe :: NoImportantInKeyframe as biome_analyze :: Rule > :: Options ; pub type NoInvalidDirectionInLinearGradient = < lint :: nursery :: no_invalid_direction_in_linear_gradient :: NoInvalidDirectionInLinearGradient as biome_analyze :: Rule > :: Options ; +pub type NoInvalidGridAreas = + ::Options; pub type NoInvalidPositionAtImportRule = < lint :: nursery :: no_invalid_position_at_import_rule :: NoInvalidPositionAtImportRule as biome_analyze :: Rule > :: Options ; pub type NoIrregularWhitespace = ::Options; @@ -26,7 +28,5 @@ pub type NoUnknownUnit = pub type NoUnmatchableAnbSelector = < lint :: nursery :: no_unmatchable_anb_selector :: NoUnmatchableAnbSelector as biome_analyze :: Rule > :: Options ; pub type NoValueAtRule = ::Options; -pub type NoInvalidGridAreas = - ::Options; pub type UseGenericFontNames = ::Options; diff --git a/packages/@biomejs/backend-jsonrpc/src/workspace.ts b/packages/@biomejs/backend-jsonrpc/src/workspace.ts index 0309841a6a78..59adadd7bc7d 100644 --- a/packages/@biomejs/backend-jsonrpc/src/workspace.ts +++ b/packages/@biomejs/backend-jsonrpc/src/workspace.ts @@ -243,7 +243,7 @@ export interface PartialJavascriptConfiguration { /** * A list of global bindings that should be ignored by the analyzers -If defined here, they should not emit diagnostics. +If defined here, they should not emit diagnostics. */ globals?: StringSet; /** @@ -333,7 +333,7 @@ export interface PartialVcsConfiguration { /** * The folder where Biome should check for VCS files. By default, Biome will use the same folder where `biome.json` was found. -If Biome can't find the configuration, it will attempt to use the current working directory. If no current working directory can't be found, Biome won't use the VCS integration, and a diagnostic will be emitted +If Biome can't find the configuration, it will attempt to use the current working directory. If no current working directory can't be found, Biome won't use the VCS integration, and a diagnostic will be emitted */ root?: string; /** @@ -412,7 +412,7 @@ export type LineEnding = "lf" | "crlf" | "cr"; /** * Validated value for the `line_width` formatter options -The allowed range of values is 1..=320 +The allowed range of values is 1..=320 */ export type LineWidth = number; /** @@ -556,7 +556,7 @@ export interface PartialJavascriptParser { /** * It enables the experimental and unsafe parsing of parameter decorators -These decorators belong to an old proposal, and they are subject to change. +These decorators belong to an old proposal, and they are subject to change. */ unsafeParameterDecoratorsEnabled?: boolean; } @@ -1203,6 +1203,10 @@ export interface Nursery { * Disallow non-standard direction values for linear gradient functions. */ noInvalidDirectionInLinearGradient?: RuleConfiguration_for_Null; + /** + * Disallows invalid named grid areas in CSS Grid Layouts. + */ + noInvalidGridAreas?: RuleConfiguration_for_Null; /** * Disallow the use of @import at-rules in invalid positions. */ @@ -1319,10 +1323,6 @@ export interface Nursery { * This rule enforces consistent use of curly braces inside JSX attributes and JSX children. */ useConsistentCurlyBraces?: RuleFixConfiguration_for_Null; - /** - * Disallows invalid named grid areas in CSS Grid Layouts. - */ - noInvalidGridAreas?: RuleConfiguration_for_Null; /** * Require consistent accessibility modifiers on class properties and methods. */ @@ -2375,7 +2375,7 @@ export interface NoDoubleEqualsOptions { /** * If `true`, an exception is made when comparing with `null`, as it's often relied on to check both for `null` or `undefined`. -If `false`, no such exception will be made. +If `false`, no such exception will be made. */ ignoreNull: boolean; } @@ -2383,13 +2383,13 @@ export interface Hook { /** * The "position" of the closure function, starting from zero. -For example, for React's `useEffect()` hook, the closure index is 0. +For example, for React's `useEffect()` hook, the closure index is 0. */ closureIndex?: number; /** * The "position" of the array of dependencies, starting from zero. -For example, for React's `useEffect()` hook, the dependencies index is 1. +For example, for React's `useEffect()` hook, the dependencies index is 1. */ dependenciesIndex?: number; /** @@ -2401,7 +2401,7 @@ For example, for React's `useEffect()` hook, the dependencies index is 1. Set to `true` to mark the identity of the hook's return value as stable, or use a number/an array of numbers to mark the "positions" in the return array as stable. -For example, for React's `useRef()` hook the value would be `true`, while for `useState()` it would be `[1]`. +For example, for React's `useRef()` hook the value would be `true`, while for `useState()` it would be `[1]`. */ stableResult?: StableHookResult; } @@ -2557,13 +2557,13 @@ export type LanguageVariant = "Standard" | "StandardRestricted" | "Jsx"; /** * Enum of the different ECMAScript standard versions. The versions are ordered in increasing order; The newest version comes last. -Defaults to the latest stable ECMAScript standard. +Defaults to the latest stable ECMAScript standard. */ export type LanguageVersion = "ES2022" | "ESNext"; /** * The style of CSS contained in the file. -Currently, Biome only supports plain CSS, and aims to be compatible with the latest Recommendation level standards. +Currently, Biome only supports plain CSS, and aims to be compatible with the latest Recommendation level standards. */ export type CssVariant = "Standard"; /** @@ -2962,7 +2962,7 @@ export type DiagnosticTags = DiagnosticTag[]; /** * Serializable representation of a [Diagnostic](super::Diagnostic) advice -See the [Visitor] trait for additional documentation on all the supported advice types. +See the [Visitor] trait for additional documentation on all the supported advice types. */ export type Advice = | { log: [LogCategory, MarkupBuf] } @@ -3055,7 +3055,7 @@ export interface CodeAction { /** * The category of a code action, this type maps directly to the [CodeActionKind] type in the Language Server Protocol specification -[CodeActionKind]: https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#codeActionKind +[CodeActionKind]: https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#codeActionKind */ export type ActionCategory = | "QuickFix" @@ -3075,7 +3075,7 @@ export interface CodeSuggestion { /** * The sub-category of a refactor code action. -[Check the LSP spec](https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#codeActionKind) for more information: +[Check the LSP spec](https://microsoft.github.io/language-server-protocol/specifications/lsp/3.17/specification/#codeActionKind) for more information: */ export type RefactorKind = | "None" @@ -3185,7 +3185,7 @@ export interface Workspace { fileFeatures(params: SupportsFeatureParams): Promise; updateSettings(params: UpdateSettingsParams): Promise; registerProjectFolder( - params: RegisterProjectFolderParams + params: RegisterProjectFolderParams, ): Promise; setManifestForProject(params: SetManifestForProjectParams): Promise; openFile(params: OpenFileParams): Promise; @@ -3193,13 +3193,13 @@ export interface Workspace { closeFile(params: CloseFileParams): Promise; getSyntaxTree(params: GetSyntaxTreeParams): Promise; organizeImports( - params: OrganizeImportsParams + params: OrganizeImportsParams, ): Promise; getFileContent(params: GetFileContentParams): Promise; getControlFlowGraph(params: GetControlFlowGraphParams): Promise; getFormatterIr(params: GetFormatterIRParams): Promise; pullDiagnostics( - params: PullDiagnosticsParams + params: PullDiagnosticsParams, ): Promise; pullActions(params: PullActionsParams): Promise; formatFile(params: FormatFileParams): Promise; diff --git a/packages/@biomejs/biome/configuration_schema.json b/packages/@biomejs/biome/configuration_schema.json index 0319d26d3436..a99dee8534d6 100644 --- a/packages/@biomejs/biome/configuration_schema.json +++ b/packages/@biomejs/biome/configuration_schema.json @@ -2035,6 +2035,13 @@ { "type": "null" } ] }, + "noInvalidGridAreas": { + "description": "Disallows invalid named grid areas in CSS Grid Layouts.", + "anyOf": [ + { "$ref": "#/definitions/RuleConfiguration" }, + { "type": "null" } + ] + }, "noInvalidPositionAtImportRule": { "description": "Disallow the use of @import at-rules in invalid positions.", "anyOf": [ @@ -2235,13 +2242,6 @@ { "type": "null" } ] }, - "noInvalidGridAreas": { - "description": "Disallows invalid named grid areas in CSS Grid Layouts.", - "anyOf": [ - { "$ref": "#/definitions/RuleConfiguration" }, - { "type": "null" } - ] - }, "useConsistentMemberAccessibility": { "description": "Require consistent accessibility modifiers on class properties and methods.", "anyOf": [