Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Conversation

@arendjr
Copy link
Contributor

@arendjr arendjr commented Jul 16, 2025

Summary

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/ or dist/ folders.

With this patch, we set up non-recursive watchers only for the folders that are relevant to a project.

Test Plan

Test added. Updated some existing tests.

@arendjr arendjr requested review from a team July 16, 2025 14:48
@changeset-bot
Copy link

changeset-bot bot commented Jul 16, 2025

🦋 Changeset detected

Latest commit: 1a81d6d

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 13 packages
Name Type
@biomejs/biome Patch
@biomejs/cli-win32-x64 Patch
@biomejs/cli-win32-arm64 Patch
@biomejs/cli-darwin-x64 Patch
@biomejs/cli-darwin-arm64 Patch
@biomejs/cli-linux-x64 Patch
@biomejs/cli-linux-arm64 Patch
@biomejs/cli-linux-x64-musl Patch
@biomejs/cli-linux-arm64-musl Patch
@biomejs/wasm-web Patch
@biomejs/wasm-bundler Patch
@biomejs/wasm-nodejs Patch
@biomejs/backend-jsonrpc Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@github-actions github-actions bot added A-CLI Area: CLI A-Core Area: core A-Project Area: project A-LSP Area: language server protocol labels Jul 16, 2025
scan_kind,
verbose,
watch,
};
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We move the watcher instructions into the scanner as much as we can. The scanner knows which folders should be scanned, and thus, which ones should be watched.

ignore_kind: IgnoreKind::Ancestors,
})?;
if is_ignored {
if self.is_ignored_by_scanner(project_key, scan_kind, &path, IgnoreKind::Ancestors)? {
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I remove the call to is_path_ignored() here, since it breaks the updates for files that do need watching in project mode. And I added the IgnoreKind argument to is_ignored_by_scanner, because that check was incomplete and could let nested ignored files slip by.

Copy link
Member

@ematipico ematipico left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good


/// Returns whether directories are stored and returned by
/// `Self::evaluated_paths()`.
fn store_dirs(&self) -> bool {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: should_store_dirs

}

if file_type.is_file() {
scope.spawn(move |_| {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why don't we use spawn anymore? It seems unrelated to the PR

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I just ran into it... it appears completely useless 😅

Comment on lines 30 to 32
pub scan_kind: ScanKind,
pub verbose: bool,
pub watch: bool,
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we document the usage of these options?

manifests.push(path);
} else if path.is_ignore() {
ignore_paths.push(path);
} else if path.is_dir() {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Shouldn't we use the function is_dir, which handles symbolic links too?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good point, but actually we should exclude symlinks. Fixed.

@ematipico
Copy link
Member

@arendjr did you test the solution against one of the user's reproductions?

@arendjr
Copy link
Contributor Author

arendjr commented Jul 16, 2025

Unfortunately we don't have a reproduction for #6838...

@arendjr arendjr merged commit 6d68074 into biomejs:main Jul 16, 2025
12 checks passed
@github-actions github-actions bot mentioned this pull request Jul 16, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

A-CLI Area: CLI A-Core Area: core A-LSP Area: language server protocol A-Project Area: project

Projects

None yet

Development

Successfully merging this pull request may close these issues.

🐛 OS file watchers exhausted / very high resource consumption

2 participants