chore(deps): update dependency @biomejs/biome to v2.1.4 #899
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
2.1.1
->2.1.4
Release Notes
biomejs/biome (@biomejs/biome)
v2.1.4
Compare Source
Patch Changes
#7121
b9642ab
Thanks @arendjr! - Fixed #7111: Imported symbols using aliases are now correctly recognised.#7103
80515ec
Thanks @omasakun! - Fixed #6933 and #6994.When the values of private member assignment expressions, increment expressions, etc. are used, those private members are no longer marked as unused.
#6887
0cc38f5
Thanks @ptkagori! - Added thenoQwikUseVisibleTask
rule to Qwik.This rule is intended for use in Qwik applications to warn about the use of
useVisibleTask$()
functions which require careful consideration before use.Invalid:
Valid:
#7084
50ca155
Thanks @ematipico! - Added the new nursery rulenoUnnecessararyConditions
, which detects whenever some conditions don'tchange during the life cycle of the program, and truthy or false, hence deemed redundant.
For example, the following snippets will trigger the rule:
#6887
0cc38f5
Thanks @ptkagori! - Added theuseImageSize
rule to Biome.The
useImageSize
rule enforces the use of width and height attributes on<img>
elements for performance reasons. This rule is intended to prevent layout shifts and improve Core Web Vitals by ensuring images have explicit dimensions.Invalid:
Valid:
#6887
0cc38f5
Thanks @ptkagori! - Added theuseAnchorHref
rule to Biome.The
useAnchorHref
rule enforces the presence of anhref
attribute on<a>
elements in JSX. This rule is intended to ensure that anchor elements are always valid and accessible.Invalid:
Valid:
#7100
29fcb05
Thanks @Jayllyz! - Added the rulenoNonNullAssertedOptionalChain
.This rule prevents the use of non-null assertions (
!
) immediately after optional chaining expressions (?.
). Optional chaining is designed to safely handle nullable values by returningundefined
when the chain encountersnull
orundefined
. Using a non-null assertion defeats this purpose and can lead to runtime errors.#7129
9f4538a
Thanks @drwpow! - Removed option, combobox, listbox roles from useSemanticElements suggestions#7106
236deaa
Thanks @arendjr! - Fixed #6985: Inference of return types no longer mistakenly picks up return types of nested functions.#7102
d3118c6
Thanks @omasakun! - Fixed #7101:noUnusedPrivateClassMembers
now handles members declared as part of constructor arguments:private
modifier and makes it a plain method argument.noUnusedFunctionParameter
.#7104
5395297
Thanks @harxki! - Reverting to prevent regressions around ref handling#7143
1a6933a
Thanks @siketyan! - Fixed #6799: ThenoImportCycles
rule now ignores type-only imports if the newignoreTypes
option is enabled (enabled by default).#7099
6cc84cb
Thanks @arendjr! - Fixed #7062: Biome now correctly considers extended configs when determining the mode for the scanner.#6887
0cc38f5
Thanks @ptkagori! - Added theuseQwikClasslist
rule to Biome.This rule is intended for use in Qwik applications to encourage the use of the built-in
class
prop (which accepts a string, object, or array) instead of theclassnames
utility library.Invalid:
Valid:
#7019
57c15e6
Thanks @fireairforce! - Added support in the JS parser forimport source
(a stage3 proposal). The syntax looks like:#7053
655049e
Thanks @jakeleventhal! - Added theuseConsistentTypeDefinitions
rule.This rule enforces consistent usage of either
interface
ortype
for object type definitions in TypeScript.The rule accepts an option to specify the preferred style:
interface
(default): Prefer usinginterface
for object type definitionstype
: Prefer usingtype
for object type definitionsExamples:
The rule will automatically fix simple cases where conversion is straightforward.
v2.1.3
Compare Source
Patch Changes
#7057
634a667
Thanks @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
# @​biomejs/biome (like
$el,
$data,
$props) and keys starting with
_` in data properties, which can cause conflicts and unexpected behavior in Vue components.Invalid example
Valid examples
#6941
734d708
Thanks @JamBalaya56562! - Added@eslint-react/no-nested-component-definitions
as a rule source fornoNestedComponentDefinitions
. Now it will get picked up bybiome migrate --eslint
.#6463
0a16d54
Thanks @JamBalaya56562! - Fixed a website link for theuseComponentExportOnlyModules
linter rule to point to the correct URL.#6944
e53f2fe
Thanks @sterliakov! - Fixed #6910: Biome now ignores type casts and assertions when evaluating numbers fornoMagicNumbers
rule.#6991
476cd55
Thanks @denbezrukov! - Fixed #6973: Add support for parsing the :active-view-transition-type() pseudo-class#6992
0b1e194
Thanks @ematipico! - Added a new JSON rule callednoQuickfixBiome
, which disallow the use of code actionquickfix.biome
inside code editor settings.#6943
249306d
Thanks @JamBalaya56562! - Fixed@vitest/eslint-plugin
source url.#6947
4c7ed0f
Thanks @JamBalaya56562! - Fixed ESLint migration for the ruleprefer-for
fromeslint-plugin-solid
to Biome'suseForComponent
.#6976
72ebadc
Thanks @siketyan! - Fixed #6692: The rulesnoUnusedVariables
andnoUnusedFunctionParameters
no longer cause an infinite loop when the suggested name is not applicable (e.g. the suggested name is already declared in the scope).#6990
333f5d0
Thanks @rvanlaarhoven! - Fixed the documentation URL forlint/correctness/noUnknownPseudoClass
#7000
4021165
Thanks @harxki! - Fixed #6795:noUnassignedVariables
now correctly recognizes variables used in JSXref
attributes.#7044
b091ddf
Thanks @ematipico! - Fixed #6622, now the ruleuseSemanticElements
works for JSX self-closing elements too.#7014
c4864e8
Thanks @siketyan! - Fixed #6516: Thebiome migrate
command no longer break the member list with trailing comments.#6979
29cb6da
Thanks @unvalley! - Fixed #6767:useSortedClasses
now correctly removes leading and trailing whitespace in className.Previously, trailing spaces in className were not fully removed.
#7055
ee4828d
Thanks @dyc3! - Added the nursery ruleuseReactFunctionComponents
. This rule enforces the preference to use function components instead of class components.Valid:
Invalid:
#6924
2d21be9
Thanks @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
e6b2380
Thanks @arendjr! - Fixed #6915:useHookAtTopLevel
no longer hangs when rules call themselves recursively.#7012
01c0ab4
Thanks @siketyan! - Fixed #5837: Invalid suppression comments such asbiome-ignore-all-start
orbiome-ignore-all-end
no longer causes a panic.#6949
48462f8
Thanks @fireairforce! - Support parseimport defer
(which is a stage3 proposal). The syntax look like this:#6938
5feb5a6
Thanks @vladimir-ivanov! - Fixed #6919 and #6920:useReadonlyClassProperties
now does checks for mutations in async class methods.Example:
#6942
cfda528
Thanks @sterliakov! - Fixed #6939. Biome now understandsthis
binding in classes outside of methods.v2.1.2
Compare Source
Patch Changes
#6865
b35bf64
Thanks @denbezrukov! - Fix #6485: Handle multiple semicolons correctly in blocks (#6485)#6798
3579ffa
Thanks @dyc3! - Fixed #6762, Biome now knows that~/.config/zed/settings.json
and~/.config/Code/User/settings.json
allows comments by default.#6839
4cd62d8
Thanks @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
0059cd9
Thanks @denbezrukov! - Refactor: remove one level of indirection for CSS declarations with semicolonPreviously, accessing a declaration from a list required an extra step:
Now, it can be done directly with:
#6839
4cd62d8
Thanks @ematipico! - Fixed a bug where the Biome Language Server didn't correctly ignore specific files whenvcs.useIgnoreFile
is set totrue
.#6884
5ff50f8
Thanks @arendjr! - Improved the performance ofnoImportCycles
by ~30%.#6903
241dd9e
Thanks @arendjr! - Fixed #6829: Fixed a false positive reported byuseImportExtensions
when importing a.js
file that had a matching.d.ts
file in the same folder.#6846
446112e
Thanks @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
eebc48e
Thanks @arendjr! - Improved #6172: Optimised the way function arguments are stored in Biome's type inference. This led to about 10% performance improvement inRedisCommander.d.ts
and about 2% on@next/font
type definitions.#6878
3402976
Thanks @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
4d5fc0e
Thanks @vladimir-ivanov! - Fixed #6719: ThenoInvalidUseBeforeDeclaration
rule covers additional use cases.Examples:
#6863
531e97e
Thanks @dyc3! - Biome now considers whether the linter is enabled when figuring out how the project should be scanned. Resolves #6815.#6832
bdbc2b1
Thanks @togami2864! - Fixed #6165: Fixed false negative innoUnusedPrivateClassMembers
rule when checking member usage in classes#6839
4cd62d8
Thanks @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.includes
setting of the root configuration.Refer to the relative web page to understand how they work.
#6898
5beb024
Thanks @arendjr! - Fixed #6891: Improved type inference for array indices.Example:
#6809
8192451
Thanks @arendjr! - Fixed #6796: Fixed a false positive that happened innoFloatingPromises
when calling functions that were declared as part offor ... of
syntax insideasync
functions.Instead, the variables declared inside
for ... of
loops are now correctlyinferred if the expression being iterated evaluates to an
Array
(support for other iterables will follow later).Invalid example
Valid example
#6757
13a0818
Thanks @mdevils! - Added the rulenoVueReservedProps
, resolves #6309.It prevents the use of reserved Vue prop names such as
key
andref
which can cause conflicts and unexpected behavior in Vue components.Invalid example
Valid examples
#6840
1a57b51
Thanks @denbezrukov! - Allow multiple identifiers in ::part() pseudo-element selector.#6845
4fd44ec
Thanks @arendjr! - Fixed #6510: The scanner no longer shows diagnostics on inaccessible files unless--verbose
is used.#6844
b7e2d4d
Thanks @sterliakov! - Fixed #6837: Fixed regression with multiple consecutive line suppression comments using instances (like// biome-ignore lint/correctness/useExhaustiveDependencies(depName): reason
).#6818
5f3f5a6
Thanks @siketyan! - Fixed an issue wheretextDocument/codeAction
in the LSP could respond with outdated text edits after the workspace watcher observed outdated changes to the file.#6804
3e6ab16
Thanks @arendjr! -noFloatingPromises
will no longer suggest to addawait
keyword inside synchronous callbacks nested insideasync
functions.#6901
c9e969a
Thanks @arendjr! - Fixed #6777: Fixed type inference handling ofthis
to avoid infinite recursion.Thanks to @sterliakov for the thorough investigation!
#6855
d1581c7
Thanks @vladimir-ivanov! - Fixed #6775:useReadonlyClassProperties
now also captures mutations inside function arguments.Example:
#6839
4cd62d8
Thanks @ematipico! - Fixed a bug where Biome didn't throw any error whenvcs.useIgnoreFile
is set totrue
, and there wasn't any ignore file read. Now Biome correctly throws an error if no ignore files are found.#6911
6d68074
Thanks @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.
Configuration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR was generated by Mend Renovate. View the repository job log.