@biomejs/biome 2.1.0
2.1.0
Minor Changes
-
#6512
0c0bf82Thanks @arendjr! - The rulenoFloatingPromisescan now detect floating arrays ofPromises.Invalid examples
// This gets flagged because the Promises are not handled. [1, 2, 3].map(async (x) => x + 1);Valid examples
await Promise.all([1, 2, 3].map(async (x) => x + 1)); -
#6637
6918085Thanks @arendjr! - Type inference is now able to handle the sequence operator (,), as well as post- and pre-update operators:++.Example
let x = 5; // We now infer that `x++` resolves to a number, while the expression as a whole // becomes a Promise: x++, new Promise((resolve) => resolve("comma")); -
#6752
c9eaca4Thanks @arendjr! - Fixed #6646:.gitignorefiles are now picked up even when running Biome from a nested directory, or when the ignore file itself is ignored throughfiles.includes. -
#6746
90aeeadThanks @arendjr! -biome migrateno longer enables style rules that were recommended in v1, because that would be undesirable for users upgrading from 2.0.Users who are upgrading from Biome 1.x are therefore advised to first upgrade to Biome 2.0, and run the migration, before continuing to Biome 2.1 or later.
-
#6583
d415a3fThanks @arendjr! - Added the nursery rulenoMisusedPromises.It signals
Promises in places where conditionals or iterables are expected.Invalid examples
const promise = Promise.resolve("value"); // Using a `Promise` as conditional is always truthy: if (promise) { /* ... */ } // Spreading a `Promise` has no effect: console.log({ foo: 42, ...promise }); // This does not `await` the `Promise`s from the callbacks, // so it does not behave as you may expect: [1, 2, 3].forEach(async (value) => { await fetch(`/${value}`); });Valid examples
const promise = Promise.resolve("value"); if (await promise) { /* ... */ } console.log({ foo: 42, ...(await promise) }); -
#6405
cd4a9bbThanks @vladimir-ivanov! - Added theignoreRestSiblingsoption to thenoUnusedFunctionParametersrule.This option is used to ignore unused function parameters that are siblings of the rest parameter.
The default is
false, which means that unused function parameters that are siblings of the rest parameter will be reported.Example
{ "rules": { "noUnusedFunctionParameters": ["error", { "ignoreRestSiblings": true }] } } -
#6614
0840021Thanks @arendjr! - We have implemented a more targeted version of the scanner, which ensures that if you provide file paths to handle on the CLI, the scanner will exclude directories that are not relevant to those paths.Note that for many commands, such as
biome checkandbiome format, the file paths to handle are implicitly set to the current working directory if you do not provide any path explicitly. The targeted scanner also works with such implicit paths, which means that if you run Biome from a subfolder, other folders that are part of the project are automatically exempted.Use cases where you invoke Biome from the root of the project without providing a path, as well as those where project rules are enabled, are not expected to see performance benefits from this.
-
#6488
c5ee385Thanks @ianzone! -nx.jsonandproject.jsonhave been added to the list of well-known files. -
#6720
52e36aeThanks @minht11! - Added# @biomejs/biome symbol to [organizeImports](https://biomejs.dev/assist/actions/organize-imports):ALIAS:` group.import { action } from '$lib'will be treated as alias import.
Patch Changes
-
#6712
2649ac6Thanks @sterliakov! - Fixed #6595: Biome now supports// biome-ignore-allfile-level suppressions in files that start with a shebang (#!). -
#6758
28dc49eThanks @arendjr! - Fixed #6573: Grit plugins can now match bare imports.Example
The following snippet:
`import $source`will now match:
import "main.css"; -
#6550
b424f46Thanks @arendjr! - Type inference is now able to handle logical expressions:&&,||, and??.Examples
// We can now infer that because `true` is truthy, the entire expression // evaluates to a `Promise`. true && Promise.reject("logical operator bypass"); // And we know that this doesn't: false && Promise.reject("logical operator bypass"); // Truthiness, falsiness, and non-nullishness can all be determined on more // complex expressions as well. So the following also works: type Nullish = null | undefined; type Params = { booleanOption: boolean | Nullish; falsyOption: false | Nullish; }; function foo({ booleanOption, falsyOption }: Params) { // This may be a Promise: booleanOption ?? Promise.reject("logical operator bypass"); // But this never is: falsyOption && Promise.reject("logical operator bypass"); } -
#6413
4aa0e50Thanks @wojtekmaj! - Improved error message inuseDateNowrule. -
#6673
341e062Thanks @dyc3! - Fixed a case where the HTML formatter would mangle embedded language tags ifwhitespaceSensitivitywas set tostrict -
#6642
a991229Thanks @unvalley! - Fixed #4494: ThenoSecretsrule now correctly uses theentropyThresholdoption to detect secret like strings. -
#6520
0c43545Thanks @arendjr! - Type inference is now able to handle ternary conditions in type aliases.Note that we don't attempt to evaluate the condition itself. The resulting type is simply a union of both conditional outcomes.
Example
type MaybeResult<T> = T extends Function ? Promise<string> : undefined; // We can now detect this function _might_ return a `Promise`: function doStuff<T>(input: T): MaybeResult<T> { /* ... */ } -
#6711
1937691Thanks @sterliakov! - Fixed #6654: Fixed range highlighting of<explanation>placeholder in inline suppression block comments. -
#6756
d12b26fThanks @dyc3! - Fixed #6669: Added an exception tonoUnusedImportsto allow type augmentation imports.import type {} from "@mui/lab/themeAugmentation"; -
#6643
df15ad6Thanks @skewb1k! - Fixed #4994: LSP server registered some capabilities even when the client did not support dynamic registration. -
#6599
5e611faThanks @vladimir-ivanov! - Fixed #6380: ThenoFocusedTestsrule now correctly displays the function name in the diagnostic message when a test is focused.Every instance of a focused test function (like
fdescribe,fit,ftestandonly) had the word 'only' hardcoded. This has been updated to use the actual function name, so the message is now more accurate and specific.Example for
fdescribe:i The 'fdescribe' method is often used for debugging or during implementation. i Consider removing 'f' prefix from 'fdescribe' to ensure all tests are executed. -
#6671
0c9ab43Thanks @vladimir-ivanov! - Fixed #6634: TheuseReadonlyClassPropertiesrule now correctly flags mutations in class getters and in arrow functions within class properties.Examples:
class GetterWithMutationValue { #value: string; get value() { if (!this.#value) { this.#value = "defaultValue"; } return this.#value; } }class ClassPropertyArrowFunctionWithMutation { private bar: string | null = null; readonly action = () => { this.bar = "init"; }; } -
#6682
ca04ceaThanks @ematipico! - Fixed #6668: Biome Assist is now enabled by default for CSS files. -
#6525
66b089cThanks @arendjr! - Type inference can now infer the return types of functions and methods without annotations.Examples
const sneakyObject = { doSomething() { return Promise.resolve("This is a floating promise!"); }, }; // We can now detect that `doSomething()` returns a `Promise`. sneakyObject.doSomething(); -
#6531
c06df79Thanks @arendjr! - Biome's type inference now detects the type of properties with getters.Examples
const sneakyObject2 = { get something() { return new Promise((_, reject) => reject("This is a floating promise!")); }, }; // We now detect this is a Promise: sneakyObject2.something; -
#6587
a330fccThanks @Conaclos! -organizeImportsis now able to sort named specifiers and import attributes with bogus nodes. -
#6618
6174869Thanks @Shinyaigeek! - Fixed #6610: JSON import attributes are now correctly detected when they contain extra whitespace. -
#6753
fce5d2cThanks @dyc3! - Improved the error messages when Biome is provided incompatible arguments on the CLI. -
#6587
a330fccThanks @Conaclos! - Fixed #6491: The action ofuseSortedKeysremoved comments or wrongly transferred them to distinct nodes. -
#6696
92964a7Thanks @unvalley! - Fixed #6633: ThenoImplicitCoercionrule no longer reports diagnostics for1 / valueexpressions.1 / value; // no error -
#6683
43d871eThanks @ematipico! - Fixed #6537: Biome no longer removes the trailing comma from JSON files whenformatter.json.trailingCommasis explicitly set to"all". -
#6693
bfdce0bThanks @dyc3! - Fixed #6691: The HTML parser will now consider.to be a valid character for tag names. -
#6716
ead03d1Thanks @siketyan! - The Biome LSP server no longer responds with an error for atextDocument/codeActionsrequest when Biome doesn't support a feature for the file (e.g. Code actions aren't supported in GritQL files). -
#6679
7bf9a60Thanks @marko-hologram! - Fixed #6638: JavaScript formatteroverridesoptions now correctly overrideexpandoption. JSON formatteroverridesoptions now correctly overridebracketSpacingandexpandoptions. -
#6717
7f5b541Thanks @siketyan! - Fixed #6688: thenoUselessFragmentsno longer reports<Fragment />elements that includes HTML character entities. -
#6600
853e1b5Thanks @daivinhtran! - Fixed #4677: ThenoUnusedImportsrule won't produce diagnostics for types used in comments of static members anymore. -
#6662
3afc804Thanks @arendjr! - If a nested configuration file is ignored by the root configuration, it will now actually be ignored.Biome has an exception in place for configuration files so they cannot be ignored, because the configuration files are vital to Biome itself. But this exception was incorrectly applied to nested configurations as well. Now only the root configuration is exempt from being ignored.
-
#6596
c0718caThanks @ematipico! - Fixed #6566: Biome no longer errors when using the option--files-ignore-unknown=trueinstdinmode.Biome has also become less strict when using
--stdin-file-pathinstdinmode. It will no longer error if the file path doesn't contain an extension, but instead it will return the original content. -
#6562
153eda7Thanks @vladimir-ivanov! - Added the nursery rule noMagicNumbers. The rule detects and reports the use of "magic numbers" — numeric literals that are used directly in code without being assigned to a named constant.Example
let total = price * 1.23; // Magic number for tax rate will highlight 1.23 as magic number -
#6663
af78d6dThanks @ematipico! - Fixed #6656: Biome now correctly formats HTML void elements such as<meta>when they contain a self-closing slash.- <meta foo="bar" /> + <meta foo="bar"> -
#6732
31e4396Thanks @vladimir-ivanov! - Resolved #6281: Improved performance of handlingpackage.jsonfiles in the scanner. -
#6625
19cb475Thanks @arendjr! - Fixed #6616: Fixed an issue with extending configurations that contained an explicitrootfield while the configuration in the project did not. -
#6650
19aab18Thanks @sterliakov! - Fixed #6621: Improved handling of multiple adjacent line suppressions. Biome now handles such suppressions separately, tracking whether each one is used. -
#6700
cdd6e17Thanks @denbezrukov! - Fixed #6680: Biome incorrectly formatted container-style queries by inserting misplaced spaces.- @container style (--responsive: true) {} + @container style(--responsive: true) {} -
#6709
ecf3954Thanks @dyc3! - Fixed #6038: Fixed a false positive innoShadowwhere a function parameter in a type definition was erroneously flagged as a violation. -
#6593
a4acbb7Thanks @arendjr! - Type inference is now able to handle ternary conditions in expressions.Examples
const condition = Math.random() > -1; // Always true, but dynamic to linter // We now detect that this may return a `Promise`. condition ? Promise.reject("ternary bypass") : null; // On the other hand, we know the following is never a `Promise`: const alwaysFalsy = 0; alwaysFalsy ? Promise.reject("ternary bypass") : null; -
#6428
4b501d3Thanks @siketyan! - AddedMemoryFileSystemto the WASM API.You can now insert a file from your JS code:
import { MemoryFileSystem, Workspace } from "@biomejs/wasm-web"; const fs = new MemoryFileSystem(); const workspace = Workspace.withFileSystem(fs); fs.insert("/index.js", new TextEncoder().encode("let foo = 1;")); fs.remove("/index.js"); -
#6594
626d4a1Thanks @ematipico! - Fixed #6528: Biome didn't return the correct output when applyingsource.fixAll.biomeinside Astro/Vue/Svelte files that contained safe fixed.
What's Changed
- feat(core): support import namespaces by @arendjr in https://github.com/biomejs/biome/pull/6303
- feat(core): support
export *syntax by @arendjr in https://github.com/biomejs/biome/pull/6311 - fix(linter): prevent false positives in
noMisusedPromisesby @arendjr in https://github.com/biomejs/biome/pull/6315 - perf: use
TypeStorein global resolver by @arendjr in https://github.com/biomejs/biome/pull/6318 - perf: resolve and map types in single pass by @arendjr in https://github.com/biomejs/biome/pull/6319
- perf: deduplicate types by @arendjr in https://github.com/biomejs/biome/pull/6324
- chore: add
swrfixtures by @arendjr in https://github.com/biomejs/biome/pull/6339 - fix(resolver): resolve type definitions for JavaScript files by @arendjr in https://github.com/biomejs/biome/pull/6343
- feat(core): flatten intersections + call signatures by @arendjr in https://github.com/biomejs/biome/pull/6404
- perf: preallocate type store by @arendjr in https://github.com/biomejs/biome/pull/6421
- perf: store types behind
Arcs by @arendjr in https://github.com/biomejs/biome/pull/6442 - feat: add nx.json project.json to Well-known files by @ianzone in https://github.com/biomejs/biome/pull/6488
- feat(linter): handle arrays of Promises in
noFloatingPromisesby @arendjr in https://github.com/biomejs/biome/pull/6512 - fix(core): handle ternary in type alias by @arendjr in https://github.com/biomejs/biome/pull/6520
- fix(core): infer method return types by @arendjr in https://github.com/biomejs/biome/pull/6525
- fix(core): infer types of properties with getters by @arendjr in https://github.com/biomejs/biome/pull/6531
- chore: add test case by @arendjr in https://github.com/biomejs/biome/pull/6532
- feat(core): handle logical operators by @arendjr in https://github.com/biomejs/biome/pull/6550
- ci: fix JSON payload release dispatch by @ematipico in https://github.com/biomejs/biome/pull/6580
- chore: remove disclaimer on
noFloatingPromisesby @arendjr in https://github.com/biomejs/biome/pull/6579 - chore: update
nextby @arendjr in https://github.com/biomejs/biome/pull/6581 - feat(biome_js_analyse): added new rule noMagicNumbers by @vladimir-ivanov in https://github.com/biomejs/biome/pull/6562
- chore(justfile): adjust indentation and remove extra blank lines in
justfileby @paulo9mv in https://github.com/biomejs/biome/pull/6568 - refactor(useSortedKeys): transfer trailing separator upon sorting by @Conaclos in https://github.com/biomejs/biome/pull/6587
- fix(lsp): fix all should check for embedded languages by @ematipico in https://github.com/biomejs/biome/pull/6594
- feat(core): implement conditional handling by @arendjr in https://github.com/biomejs/biome/pull/6593
- chore: update contribution guide to include vladimir ivanov as a maintainer by @vladimir-ivanov in https://github.com/biomejs/biome/pull/6564
- fix(biome_js_analyze): fix JsDocTypeCollectorVisitior to also walk on JsStaticMemberAssignment by @daivinhtran in https://github.com/biomejs/biome/pull/6600
- docs: add mdevils to maintainers by @mdevils in https://github.com/biomejs/biome/pull/6612
- chore(lint): fix document of the
noMagicNumbersrule that produces invalid MDX by @siketyan in https://github.com/biomejs/biome/pull/6598 - refactor: extract out a
biome_line_indexcrate by @DavisVaughan in https://github.com/biomejs/biome/pull/6222 - fix(biome-js-analyze): fixed the diagnostic message for noFocusedTests to display the offending fn name by @vladimir-ivanov in https://github.com/biomejs/biome/pull/6599
- chore: add
syntaxparser directive to Dockerfile by @JamBalaya56562 in https://github.com/biomejs/biome/pull/6619 - feat(core): port SyntaxNodePtr and AstPtr from rowan by @rmehri01 in https://github.com/biomejs/biome/pull/6534
- fix(biome-js-analyze): detect json import attribute with trimmed text value instead of plain text value by @Shinyaigeek in https://github.com/biomejs/biome/pull/6618
- feat(core): targeted file scanner by @arendjr in https://github.com/biomejs/biome/pull/6614
- fix(core): fix extending configs with root field by @arendjr in https://github.com/biomejs/biome/pull/6625
- chore(deps): pin docker/dockerfile docker tag to 9857836 by @renovate in https://github.com/biomejs/biome/pull/6626
- chore(deps): update dependency @types/node to v22.15.34 by @renovate in https://github.com/biomejs/biome/pull/6627
- fix(deps): update @biomejs packages by @renovate in https://github.com/biomejs/biome/pull/6632
- chore(deps): update rust crate papaya to 0.2.3 by @renovate in https://github.com/biomejs/biome/pull/6630
- chore(deps): update rust crate ureq to 3.0.12 by @renovate in https://github.com/biomejs/biome/pull/6631
- fix(cli): lax stdin strictness by @ematipico in https://github.com/biomejs/biome/pull/6596
- feat(core): infer sequence operator and update operators by @arendjr in https://github.com/biomejs/biome/pull/6637
- feat(yaml): overhauling YAML lexer by @vohoanglong0107 in https://github.com/biomejs/biome/pull/6481
- feat(wasm): expose MemoryFileSystem via WASM API by @siketyan in https://github.com/biomejs/biome/pull/6428
- fix(core): fix inference for boolean that must be truthy by @arendjr in https://github.com/biomejs/biome/pull/6641
- fix(biome-js-analyze): update changes by @vladimir-ivanov in https://github.com/biomejs/biome/pull/6636
- fix(lsp): add missing checks for capability dynamic registration support by @skewb1k in https://github.com/biomejs/biome/pull/6643
- fix(js-api): don't use types of others modules by @regseb in https://github.com/biomejs/biome/pull/6535
- refactor: share lint rule options by @ematipico in https://github.com/biomejs/biome/pull/5543
- perf: optimise ignore checking by @arendjr in https://github.com/biomejs/biome/pull/6659
- chore: merge
nextintomainby @arendjr in https://github.com/biomejs/biome/pull/6583 - feat(core): offset parsing by @ematipico in https://github.com/biomejs/biome/pull/6652
- fix(formatter): void elements with slash by @ematipico in https://github.com/biomejs/biome/pull/6663
- fix(lint/noSecrets): calculate entropy with
entropyThresholdoption by @unvalley in https://github.com/biomejs/biome/pull/6642 - fix(biome-js-analyze): move no_secrets options inside biome-rules-opt… by @vladimir-ivanov in https://github.com/biomejs/biome/pull/6672
- fix(core): css assist by @ematipico in https://github.com/biomejs/biome/pull/6682
- fix(format/html): fix mangling of embedded language tags if
whitespaceSensitivityisstrictby @dyc3 in https://github.com/biomejs/biome/pull/6673 - feat(parser): parse Astro frontmatter by @ematipico in https://github.com/biomejs/biome/pull/6689
- chore(core): add resource to diagnostic by @ematipico in https://github.com/biomejs/biome/pull/6685
- fix(parse/html): make
.a valid char in tag names by @dyc3 in https://github.com/biomejs/biome/pull/6693 - fix(formatter): trailing commas in json files by @ematipico in https://github.com/biomejs/biome/pull/6683
- feat: make enum can be transform in scope by @cqh963852 in https://github.com/biomejs/biome/pull/6678
- fix(biome-js-analyze): useReadonlyClassProperties check class getters… by @vladimir-ivanov in https://github.com/biomejs/biome/pull/6671
- feat(biome_js_analyse): added new option to rule to ignore unused function parameters by @vladimir-ivanov in https://github.com/biomejs/biome/pull/6405
- fix(core): ignore nested configs by @arendjr in https://github.com/biomejs/biome/pull/6662
- fix(lint/noImplicitCoercion): false positive for
1 / valueby @unvalley in https://github.com/biomejs/biome/pull/6696 - fix(css_formatter): correct spacing in container style queries by @denbezrukov in https://github.com/biomejs/biome/pull/6700
- fix(biome_analyze): stop squashing multiple line suppression comments. by @sterliakov in https://github.com/biomejs/biome/pull/6650
- fix(noShadow): fix a false positive related to function parameters inside type definitions by @dyc3 in https://github.com/biomejs/biome/pull/6709
- fix(biome_js_analyze): correct text range of suppression reason by @sterliakov in https://github.com/biomejs/biome/pull/6711
- fix(service): biome/file_features still should return a map instead of an array by @siketyan in https://github.com/biomejs/biome/pull/6718
- fix(lint/complexity/useDateNow): improve error message by @wojtekmaj in https://github.com/biomejs/biome/pull/6413
- docs: fix typos in CHANGELOG & CONTRIBUTING by @noritaka1166 in https://github.com/biomejs/biome/pull/6721
- docs: update analyzer contribution guide by @ematipico in https://github.com/biomejs/biome/pull/6651
- fix(lsp): do not response error on pulling actions from GritQL files by @siketyan in https://github.com/biomejs/biome/pull/6716
- feat(linter): add $ to organize imports :ALIAS: group by @minht11 in https://github.com/biomejs/biome/pull/6720
- fix(biome-service): override all formatter options with user configured overrides by @marko-hologram in https://github.com/biomejs/biome/pull/6679
- chore(deps): update dependency dprint to v0.50.1 by @renovate in https://github.com/biomejs/biome/pull/6734
- chore(deps): update dependency @types/node to v22.16.0 by @renovate in https://github.com/biomejs/biome/pull/6735
- chore(deps): update dependency eslint to v9.30.1 by @renovate in https://github.com/biomejs/biome/pull/6738
- chore(deps): update dependency @types/node to v22.16.0 by @renovate in https://github.com/biomejs/biome/pull/6737
- chore(deps): update github-actions by @renovate in https://github.com/biomejs/biome/pull/6741
- chore(deps): update dependency rust to v1.88.0 by @renovate in https://github.com/biomejs/biome/pull/6740
- chore(deps): update rust crate indexmap to 2.10.0 by @renovate in https://github.com/biomejs/biome/pull/6742
- chore(deps): update rust crate rust-lapper to 1.2.0 by @renovate in https://github.com/biomejs/biome/pull/6743
- chore: update contribution and changesets by @ematipico in https://github.com/biomejs/biome/pull/6748
- chore: remove style rule migration by @arendjr in https://github.com/biomejs/biome/pull/6746
- feat(biome_analyzer): support shebang together with
// biome-ignore-allfile-level suppressions by @sterliakov in https://github.com/biomejs/biome/pull/6712 - perf(biome_package): improve performance of biome_package by @vladimir-ivanov in https://github.com/biomejs/biome/pull/6732
- fix(core): .gitignore is discovered in more scenarios by @arendjr in https://github.com/biomejs/biome/pull/6752
- fix(lint/noUselessFragments): apply the same logic for shorthand fragments and Fragment elements by @siketyan in https://github.com/biomejs/biome/pull/6717
- chore: reduce
PackageJsonsize by @arendjr in https://github.com/biomejs/biome/pull/6754 - fix(grit): match bare imports by @arendjr in https://github.com/biomejs/biome/pull/6758
- fix(cli): improve error messages when given incompatible arguments by @dyc3 in https://github.com/biomejs/biome/pull/6753
- fix(noUnusedImports): formally make an exception for type augmentation imports by @dyc3 in https://github.com/biomejs/biome/pull/6756
- perf(biome_package): updated incorrect generic passed to deserialize_… by @vladimir-ivanov in https://github.com/biomejs/biome/pull/6760
- chore: clean up changesets by @arendjr in https://github.com/biomejs/biome/pull/6768
- chore: set versions for new rules by @arendjr in https://github.com/biomejs/biome/pull/6769
- chore: don't break up paragraphs in changesets by @arendjr in https://github.com/biomejs/biome/pull/6770
- ci: release by @github-actions in https://github.com/biomejs/biome/pull/6582
New Contributors
- @paulo9mv made their first contribution in https://github.com/biomejs/biome/pull/6568
- @DavisVaughan made their first contribution in https://github.com/biomejs/biome/pull/6222
- @Shinyaigeek made their first contribution in https://github.com/biomejs/biome/pull/6618
- @skewb1k made their first contribution in https://github.com/biomejs/biome/pull/6643
- @cqh963852 made their first contribution in https://github.com/biomejs/biome/pull/6678
- @marko-hologram made their first contribution in https://github.com/biomejs/biome/pull/6679
Full Changelog: https://github.com/biomejs/biome/compare/@biomejs/biome@2.0.6...@biomejs/biome@2.1.0