Version History
2.1.3
Patch Changes
-
#7057
634a667Thanks @mdevils! - Added the rulenoVueReservedKeys, which prevents the use of reserved Vue keys.It prevents the use of Vue reserved keys such as those starting with like
$el,$data,$props) and keys starting with\_in data properties, which can cause conflicts and unexpected behavior in Vue components.Invalid example
<script>export default {data: {$el: "",_foo: "bar",},};</script><script>export default {computed: {$data() {return this.someData;},},};</script>Valid examples
<script>export default {data() {return {message: "Hello Vue!",count: 0,};},};</script><script>export default {computed: {displayMessage() {return this.message;},},};</script> -
#6941
734d708Thanks @JamBalaya56562! - Added@eslint-react/no-nested-component-definitionsas a rule source fornoNestedComponentDefinitions. Now it will get picked up bybiome migrate --eslint. -
#6463
0a16d54Thanks @JamBalaya56562! - Fixed a website link for theuseComponentExportOnlyModuleslinter rule to point to the correct URL. -
#6944
e53f2feThanks @sterliakov! - Fixed #6910: Biome now ignores type casts and assertions when evaluating numbers fornoMagicNumbersrule. -
#6991
476cd55Thanks @denbezrukov! - Fixed #6973: Add support for parsing the :active-view-transition-type() pseudo-class:active-view-transition-type(first second) {} -
#6992
0b1e194Thanks @ematipico! - Added a new JSON rule callednoQuickfixBiome, which disallow the use of code actionquickfix.biomeinside code editor settings. -
#6943
249306dThanks @JamBalaya56562! - Fixed@vitest/eslint-pluginsource url. -
#6947
4c7ed0fThanks @JamBalaya56562! - Fixed ESLint migration for the ruleprefer-forfromeslint-plugin-solidto Biome’suseForComponent. -
#6976
72ebadcThanks @siketyan! - Fixed #6692: The rulesnoUnusedVariablesandnoUnusedFunctionParametersno longer cause an infinite loop when the suggested name is not applicable (e.g. the suggested name is already declared in the scope). -
#6990
333f5d0Thanks @rvanlaarhoven! - Fixed the documentation URL forlint/correctness/noUnknownPseudoClass -
#7000
4021165Thanks @harxki! - Fixed #6795:noUnassignedVariablesnow correctly recognizes variables used in JSXrefattributes. -
#7044
b091ddfThanks @ematipico! - Fixed #6622, now the ruleuseSemanticElementsworks for JSX self-closing elements too. -
#7014
c4864e8Thanks @siketyan! - Fixed #6516: Thebiome migratecommand no longer break the member list with trailing comments. -
#6979
29cb6daThanks @unvalley! - Fixed #6767:useSortedClassesnow correctly removes leading and trailing whitespace in className.Previously, trailing spaces in className were not fully removed.
// Think we have this code:<div className="text-sm font-bold " />// Before: applied fix, but a trailing space was preserved<div className="font-bold text-sm " />// After: applied fix, trailing spaces removed<div className="font-bold text-sm" /> -
#7055
ee4828dThanks @dyc3! - Added the nursery ruleuseReactFunctionComponents. This rule enforces the preference to use function components instead of class components.Valid:
function Foo() {return <div>Hello, world!</div>;}Invalid:
class Foo extends React.Component {render() {return <div>Hello, world!</div>;}} -
#6924
2d21be9Thanks @ematipico! - Fixed #113, where the Biome Language Server didn’t correctly update the diagnostics when the configuration file is modified in the editor. Now the diagnostics are correctly updated every time the configuration file is modified and saved. -
#6931
e6b2380Thanks @arendjr! - Fixed #6915:useHookAtTopLevelno longer hangs when rules call themselves recursively. -
#7012
01c0ab4Thanks @siketyan! - Fixed #5837: Invalid suppression comments such asbiome-ignore-all-startorbiome-ignore-all-endno longer causes a panic. -
#6949
48462f8Thanks @fireairforce! - Support parseimport defer(which is a stage3 proposal). The syntax look like this:import defer * as foo from "<specifier>"; -
#6938
5feb5a6Thanks @vladimir-ivanov! - Fixed #6919 and #6920:useReadonlyClassPropertiesnow does checks for mutations in async class methods.Example:
class Counter3 {private counter: number;async count() {this.counter = 1;const counterString = `${this.counter++}`;}} -
#6942
cfda528Thanks @sterliakov! - Fixed #6939. Biome now understandsthisbinding in classes outside of methods.
2.1.2
Patch Changes
-
#6865
b35bf64Thanks @denbezrukov! - Fix #6485: Handle multiple semicolons correctly in blocks (#6485)div {box-sizing: border-box;color: red;} -
#6798
3579ffaThanks @dyc3! - Fixed #6762, Biome now knows that~/.config/zed/settings.jsonand~/.config/Code/User/settings.jsonallows comments by default. -
#6839
4cd62d8Thanks @ematipico! - Fixed #6838, where the Biome File Watcher incorrectly watched and stored ignored files, causing possible memory leaks when those files were dynamically created (e.g. built files). -
#6879
0059cd9Thanks @denbezrukov! - Refactor: remove one level of indirection for CSS declarations with semicolon Previously, accessing a declaration from a list required an extra step:item.as_any_css_declaration_with_semicolon().as_css_declaration_with_semicolon()Now, it can be done directly with:
item.as_css_declaration_with_semicolon() -
#6839
4cd62d8Thanks @ematipico! - Fixed a bug where the Biome Language Server didn’t correctly ignore specific files whenvcs.useIgnoreFileis set totrue. -
#6884
5ff50f8Thanks @arendjr! - Improved the performance ofnoImportCyclesby ~30%. -
#6903
241dd9eThanks @arendjr! - Fixed #6829: Fixed a false positive reported byuseImportExtensionswhen importing a.jsfile that had a matching.d.tsfile in the same folder. -
#6846
446112eThanks @darricheng! - Fixed an issue where biome was using the wrong string quotes when the classes string has quotes, resulting in invalid code after applying the fix. -
#6823
eebc48eThanks @arendjr! - Improved #6172: Optimised the way function arguments are stored in Biome’s type inference. This led to about 10% performance improvement inRedisCommander.d.tsand about 2% on@next/fonttype definitions. -
#6878
3402976Thanks @ematipico! - Fixed a bug where the Biome Language Server would apply an unsafe fix when using the code actionquickfix.biome.Now Biome no longer applies an unsafe code fix when using the code action
quickfix.biome. -
#6794
4d5fc0eThanks @vladimir-ivanov! - Fixed #6719: ThenoInvalidUseBeforeDeclarationrule covers additional use cases.Examples:
type Bar = { [BAR]: true };const BAR = "bar";interface Bar {child: { grandChild: { [BAR]: typeof BAR; enumFoo: EnumFoo } };}const BAR = "bar";enum EnumFoo {BAR = "bar",} -
#6863
531e97eThanks @dyc3! - Biome now considers whether the linter is enabled when figuring out how the project should be scanned. Resolves #6815. -
#6832
bdbc2b1Thanks @togami2864! - Fixed #6165: Fixed false negative innoUnusedPrivateClassMembersrule when checking member usage in classes -
#6839
4cd62d8Thanks @ematipico! - Fixed a bug where the root ignore file wasn’t correctly loaded during the scanning phase, causing false positives and incorrect expectations among users.Now, when using
vcs.useIgnoreFile, the **the globs specified in the ignore file from the project root ** will have the same semantics as thefiles.includessetting of the root configuration.Refer to the relative web page to understand how they work.
-
#6898
5beb024Thanks @arendjr! - Fixed #6891: Improved type inference for array indices.Example:
const numbers: number[];numbers[42]; // This now infers to `number | undefined`. -
#6809
8192451Thanks @arendjr! - Fixed #6796: Fixed a false positive that happened innoFloatingPromiseswhen calling functions that were declared as part offor ... ofsyntax insideasyncfunctions.Instead, the variables declared inside
for ... ofloops are now correctly inferred if the expression being iterated evaluates to anArray(support for other iterables will follow later).Invalid example
const txStatements: Array<(tx) => Promise<any>> = [];db.transaction((tx: any) => {for (const stmt of txStatements) {// We correctly flag this resolves to a `Promise`:stmt(tx);}});Valid example
async function valid(db) {const txStatements: Array<(tx: any) => void> = [(tx) => tx.insert().run()];db.transaction((tx: any) => {for (const stmt of txStatements) {// We don't flag a false positive here anymore:stmt(tx);}});} -
#6757
13a0818Thanks @mdevils! - Added the rulenoVueReservedProps, resolves #6309.It prevents the use of reserved Vue prop names such as
keyandrefwhich can cause conflicts and unexpected behavior in Vue components.Invalid example
import { defineComponent } from "vue";export default defineComponent({props: ["ref", "key", "foo"],});<script setup>defineProps({ref: String,key: String,foo: String,});</script>Valid examples
import { defineComponent } from "vue";export default defineComponent({props: ["foo"],});<script setup>defineProps({ foo: String });</script> -
#6840
1a57b51Thanks @denbezrukov! - Allow multiple identifiers in ::part() pseudo-element selector.::part(first second) {} -
#6845
4fd44ecThanks @arendjr! - Fixed #6510: The scanner no longer shows diagnostics on inaccessible files unless--verboseis used. -
#6844
b7e2d4dThanks @sterliakov! - Fixed #6837: Fixed regression with multiple consecutive line suppression comments using instances (like// biome-ignore lint/correctness/useExhaustiveDependencies(depName): reason). -
#6818
5f3f5a6Thanks @siketyan! - Fixed an issue wheretextDocument/codeActionin the LSP could respond with outdated text edits after the workspace watcher observed outdated changes to the file. -
#6804
3e6ab16Thanks @arendjr! -noFloatingPromiseswill no longer suggest to addawaitkeyword inside synchronous callbacks nested insideasyncfunctions. -
#6901
c9e969aThanks @arendjr! - Fixed #6777: Fixed type inference handling ofthisto avoid infinite recursion.Thanks to @sterliakov for the thorough investigation!
-
#6855
d1581c7Thanks @vladimir-ivanov! - Fixed #6775:useReadonlyClassPropertiesnow also captures mutations inside function arguments.Example:
class Counter {private counter: number;count() {console.log(this.counter++);const counterString = `${this.counter++}`;}} -
#6839
4cd62d8Thanks @ematipico! - Fixed a bug where Biome didn’t throw any error whenvcs.useIgnoreFileis set totrue, and there wasn’t any ignore file read. Now Biome correctly throws an error if no ignore files are found. -
#6911
6d68074Thanks @arendjr! - Fixed #6838: Reduce resource consumption in the Biome Language Server by using non-recursive filesystem watchers instead of recursive ones.Watchers are responsible for notifying Biome of changes to files in the filesystem. We used to set up a single recursive watcher, but that meant that Biome would receive filesystem notifications for all files in your project, even for ignored folders such as
build/ordist/folders.With this patch, we set up non-recursive watchers only for the folders that are relevant to a project.
Related to this, we also solved an issue where incoming notifications were incorrectly filtered, causing ignored files to be processed and stored in our module graph anyway.
2.1.1
Patch Changes
-
#6781
9bbd34fThanks @siketyan! - Fixed theFileFeaturesResultinterface in the WASM API was defined as a mapped object but the actual value was aMapobject. -
#6761
cf3c2ceThanks @dyc3! - Fixed #6759, a false positive fornoFocusedTeststhat was triggered by calling any function with the namefiton any object.The following code will now pass the
noFocusedTestsrule:import foo from "foo";foo.fit();
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$symbol to organizeImports: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"; -
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.
2.0.6
Patch Changes
-
#6557
fd68458Thanks @ematipico! - Fixed a bug where Biome didn’t provide all the available code actions when requested by the editor. -
#6511
72623faThanks @Conaclos! - Fixed #6492. TheorganizeImportsassist action no longer duplicates a comment at the start of the file when:BLANK_LINE:precedes the first import group. -
#6557
fd68458Thanks @ematipico! - Fixed #6287 where Biome Language Server didn’t adhere to thesettings.requireConfigurationoption when pulling diagnostics and code actions. Note that for this configuration be correctly applied, your editor must support dynamic registration capabilities. -
#6551
0b63b1dThanks @Conaclos! - Fixed #6536.useSortedKeysno longer panics in some edge cases where object spreads are involved. -
#6503
9a8fe0fThanks @ematipico! - Fixed #6482 where nursery rules that belonged to a domain were incorrectly enabled. -
#6565
e85761cThanks @daivinhtran! - Fixed #4677: Now thenoUnusedImportsrule won’t produce diagnostics for types used in JSDoc comment of exports. -
#6166
b8cbd83Thanks @mehm8128! - Added the nursery rule noExcessiveLinesPerFunction. This rule restrict a maximum number of lines of code in a function body.The following code is now reported as invalid when the limit of maximum lines is set to 2:
function foo() {const x = 0;const y = 1;const z = 2;}The following code is now reported as valid when the limit of maximum lines is set to 3:
const bar = () => {const x = 0;const z = 2;}; -
#6553
5f42630Thanks @denbezrukov! - Fixed #6547. Now the Biome CSS parser correctly parses@starting-stylewhen it’s used inside other at-rules. The following example doesn’t raise an error anymore:@layer my-demo-layer {@starting-style {div.showing {background-color: red;}}} -
#6458
05402e3Thanks @ematipico! - Fixed an issue where the ruleuseSemanticElementsused the incorrect range when positioning suppression comments. -
#6560
6d8a6b9Thanks @siketyan! - Fixed #6559: the error message on detected a large file was outdated and referred a removed configuration optionfiles.ignore. -
#6458
05402e3Thanks @ematipico! - Fixed #6384. The ruleuseAltTextnow emits a diagnostic with a correct range, so suppression comments can work correctly. -
#6518
7a56288Thanks @wojtekmaj! - Fixed #6508, where the rulenoUselessFragmentsincorrectly flagged Fragments containing HTML entities as unnecessary. -
#6517
c5217cfThanks @arendjr! - Fixed #6515. When using theextendsfield to extend a configuration from an NPM package, we now accept the condition names"biome"and"default"for exporting the configuration in thepackage.json.This means that where previously your
package.jsonhad to contain an export declaration similar to this:{"exports": {".": "./biome.json"}}You may now use one of these as well:
{"exports": {".": {"biome": "./biome.json"}}}Or:
{"exports": {".": {"default": "./biome.json"}}} -
#6219
a3a3715Thanks @huangtiandi1999! - Added new nursery rulenoUnassignedVariables, which disallowsletorvarvariables that are read but never assigned.The following code is now reported as invalid:
let x;if (x) {console.log(1);}The following code is now reported as valid:
let x = 1;if (x) {console.log(1);} -
#6395
f62e748Thanks @mdevils! - Added the new nursery rulenoImplicitCoercion, which disallows shorthand type conversions in favor of explicit type conversion functions.Example (Invalid): Boolean conversion using double negation:
!!foo;!!(foo + bar);Example (Invalid): Number conversion using unary operators:
+foo;-(-foo);foo - 0;foo * 1;foo / 1;Example (Invalid): String conversion using concatenation:
"" + foo;foo + "";`` + foo;foo += "";Example (Invalid): Index checking using bitwise NOT:
~foo.indexOf(1);~foo.bar.indexOf(2);Example (Valid): Using explicit type conversion functions:
Boolean(foo);Number(foo);String(foo);foo.indexOf(1) !== -1; -
#6544
f28b075Thanks @daivinhtran! - Fixed #6536. Now the rulenoUselessFragmentsproduces diagnostics for a top-level useless fragment that is in a return statement. -
#6320
5705f1aThanks @mdevils! - Added the new nursery ruleuseUnifiedTypeSignature, which disallows overload signatures that can be unified into a single signature.Overload signatures that can be merged into a single signature are redundant and should be avoided. This rule helps simplify function signatures by combining overloads by making parameters optional and/or using type unions.
Example (Invalid): Overload signatures that can be unified:
function f(a: number): void;function f(a: string): void;interface I {a(): void;a(x: number): void;}Example (Valid): Unified signatures:
function f(a: number | string): void {}interface I {a(x?: number): void;}Example (Valid): Different return types cannot be merged:
interface I {f(): void;f(x: number): number;} -
#6545
2782175Thanks @ematipico! - Fixed #6529, where the Biome Language Server would emit an error when the user would open a file that isn’t part of its workspace (node_modulesor external files). Now the language server doesn’t emit any errors and it exits gracefully. -
#6524
a27b825Thanks @vladimir-ivanov! - Fixed #6500: TheuseReadonlyClassPropertiesrule now correctly marks class properties asreadonlywhen they are assigned in a constructor, setter or method, even if the assignment occurs inside an if or else block.The following code is now correctly detected by the rule:
class Price {#price: string;@Input()set some(value: string | number) {if (value === undefined ||value === null ||value === "undefined" ||value === "null" ||Number.isNaN(value)) {this.#price = "";} else {this.#price = "" + value;}}} -
#6355
e128ea9Thanks @anthonyshew! - Added a new nursery rulenoAlertthat disallows the use ofalert,confirmandprompt.The following code is deemed incorrect:
alert("here!"); -
#6548
37e9799Thanks @ematipico! - Fixed #6459, where the Biome LSP was not taking into account the correct settings when applyingsource.fixAll.biomecode action.
2.0.5
Patch Changes
-
#6461
38862e6Thanks @ematipico! - Fixed #6419, a regression where stdin mode would create a temporary new file instead of using the one provided by the user. This was an intended regression.Now Biome will use the file path passed via
--std-file-path, and apply the configuration that matches it. -
#6480
050047fThanks @Conaclos! - Fixed #6371. useNamingConvention now checks the string case of objects’ property shorthand. -
#6477
b98379dThanks @ematipico! - Fixed an issue where Biome formatter didn’t format consistently CSS value separated by commas..font-heading {font-feature-settings: var(--heading-salt), var(--heading-ss06),var(--heading-ss11), var(--heading-cv09), var(--heading-liga),var(--heading-calt);font-feature-settings:var(--heading-salt), var(--heading-ss06), var(--heading-ss11),var(--heading-cv09), var(--heading-liga), var(--heading-calt);} -
#6248
ec7126cThanks @fireairforce! - Fixed grit pattern matching for different kinds of import statements.The grit pattern
import $imports from "foo"will match the following code:import bar from "foo";import { bar } from "foo";import { bar, baz } from "foo";
2.0.4
Patch Changes
- #6450
7472d9eThanks @ematipico! - Fixed an issue where the binary wasn’t correctly mapped.
2.0.3
Patch Changes
-
#6439
7e4da4eThanks @ematipico! - Fixed an issue where the correct rights aren’t added to the binary during publishing -
#6297
cc4b8c9Thanks @vladimir-ivanov! - Added a new lintuseReadonlyClassPropertiesrule. This rule is a port of ESLint’s prefer-readonly rule.Example:
class Example {// All properties below can be marked as readonlypublic constantValue = 42;protected initializedInConstructor: string;private privateField = true;constructor(initializedInConstructor: string) {this.initializedInConstructor = initializedInConstructor;}}
2.0.2
Patch Changes
- #6436
ec7c63dThanks @ematipico! - Fixed an issue where binaries weren’t copied anymore inside the@biomejs/cli-*packages.
2.0.1
Patch Changes
-
#6425
00e97adThanks @siketyan! - Fixed #6391: the rulenoUselessFragmentsno longer reports a fragment that contains whitespaces which aren’t trimmed by the runtime. -
#6417
dd88565Thanks @ematipico! - Fixed #6360: The following pseudo classes and elements are no longer reported bynoUnknownPseudoClassornoUnknownPseudoElementrules.:open::details-content::prefix::search-text::suffix
-
#6417
dd88565Thanks @ematipico! - Fixed #6357, where the boolean values weren’t correctly merged when using theextendsfunctionality. Now Biome correctly merges the values. -
#6417
dd88565Thanks @ematipico! - Fixed #6341: Fixed an issue where Biome would throw an error for the language tagsnbandnn. -
#6385
94142ddThanks @siketyan! - Fixed #6377: The rule noSelfCompare now correctly compares two function calls with different arguments. -
#6417
dd88565Thanks @ematipico! - Fixed #6278:useExhaustiveDependenciesno longer adds duplicated dependencies into the list. -
#6417
dd88565Thanks @ematipico! - Fix #6396, wherevi.useFakeTimers()andvi.useRealTimers()incorrectly triggered React Hooks-related rules -
#6417
dd88565Thanks @ematipico! - Fixed a bug where Biome didn’t correctly discover nested configuration files when using thelintcommand and the linter is disabled in the root configuration. -
#6422
594ec50Thanks @ematipico! - Removed the experimental rename feature from Biome LSP, which caused some issues inside existing editors such as Zed. -
#6388
c6942d2Thanks @siketyan! - Fixed #6375: the formatter no longer inserts an extra empty line before a semicolon when it has leading comments.
Copyright (c) 2023-present Biome Developers and Contributors.