--filter (or -F) flag selects packages in a monorepo by pattern. Patterns match package names or package paths, with full glob syntax.
bun install and bun outdated support --filter, and you can use it to run scripts in multiple packages at once.
Matching
Package Name --filter <pattern>
Name patterns select packages by the name field in package.json. For example, if you have packages pkg-a, pkg-b and other, you can match all of them with *, only pkg-a and pkg-b with pkg*, and a specific package with its full name.
Package Path --filter ./<glob>
Path patterns start with ./ and select all packages in directories matching the pattern. For example, to match all packages in subdirectories of packages, use --filter './packages/**'. To match the package in packages/foo, use --filter ./packages/foo.
bun install and bun outdated
By default, bun install installs dependencies for every package in the monorepo. To install dependencies for specific packages, use --filter.
Given a monorepo with workspaces pkg-a, pkg-b, and pkg-c under ./packages:
terminal
bun outdated displays outdated dependencies for all packages in the monorepo, and --filter restricts the command to a subset of them:
terminal
bun install and bun outdated.
Running scripts with --filter
Use the --filter flag to execute scripts in multiple packages at once:
terminal
packages/api and packages/frontend, both with a dev script that starts a local development server. Normally, you would open two terminal tabs, cd into each package directory, and run bun dev:
terminal
--filter, you can run the dev script in both packages at once:
terminal
Running scripts in workspaces
Filters respect your workspace configuration: if yourpackage.json specifies which packages are part of the workspace,
--filter only matches those packages. In a workspace, --filter can also run scripts in packages located anywhere in the workspace:
terminal
Parallel and sequential mode
Combine--filter or --workspaces with --parallel or --sequential to run scripts across workspace packages with Foreman-style prefixed output:
terminal
pkg-a:build | ...). Without --filter/--workspaces, the prefix is just the script name (build | ...). When a package’s package.json has no name field, Bun uses the relative path from the workspace root instead.
Use --if-present with --workspaces to skip packages that don’t have the requested script instead of erroring.
Dependency Order
Bun respects package dependency order when running scripts. Say you have a packagefoo that depends on another package bar in your workspace, and both have a build script. When you run bun --filter '*' build, foo only starts once bar is done.