The project view file (*.bazelproject) is used to import a subset of bazel targets into the IDE, configure a project, and specify how the bsp server will be started.
This is our adaptation of the project view mechanism known from Bazel Plugin for Intellij
The project view file uses a python-like format with 2 spaces indentation and # comments. You can share the *.bazelproject file between projects, use your own copy, or both.
In general, you can start with just
directories andtargets and add more sections as you want to further tweak your IDE workspace.
Note: We will be changing this mechanism in future releases.
$ cs launch org.jetbrains.bsp:bazel-bsp:<version> -M org.jetbrains.bsp.bazel.install.Install -- -p <path/to/projectview_file>
.
For more details, see --help
.
Imports another project view.
You may use multiple imports in any project view. Any list type sections (e.g. targets
) compose. Single-value
sections (e.g. bazel_binary
) override and use the last one encountered, depth-first parse order (i.e. imports are
evaluated as they are encountered).
import path/to/another/projectview.bazelproject
Try importing another project view.
Similar to import
but no errors will be thrown if the declared project view file does not exist.
try_import path/to/another/projectview.bazelproject
A list of bazel target expressions, they support /...
notation.
Targets are built during the server lifetime, so the more targets you have, the slower your IDE experience might be. You
can use negative targets to have server ignore certain targets (
e.g. -//executioncontext/projectview/src/main/kotlin/org/jetbrains/bsp/bazel/projectview/parser/...
).
targets:
//install/src/main/kotlin/org/jetbrains/bsp/bazel/install
//executioncontext/projectview/...
-//executioncontext/projectview/src/main/kotlin/org/jetbrains/bsp/bazel/projectview/parser/...
No target is included:
targets:
Path to bazel which will be used to invoke bazel from the server (e.g. to build a project, or query bazel).
bazel_binary: /usr/local/bin/bazel
The server will deduct bazel path from $PATH
A list of directories to be mapped into bazel targets.
You can use negative directories to have server ignore certain directories (
e.g. -executioncontext/projectview/src/main/kotlin/org/jetbrains/bsp/bazel/projectview/parser/...
).
directories:
install/src/main/kotlin/org/jetbrains/bsp/bazel/install
executioncontext/projectview/
-executioncontext/projectview/src/main/kotlin/org/jetbrains/bsp/bazel/projectview/parser
No directories included.
A flag specifying if targets should be derived from list of directories in directories section.
Flag is boolean value, so it can take either true or false. In the first case targets will be derived from directories, in the second they won't.
derive_targets_from_directories: true
Targets will not be derived from directories.
A numerical value that specifies how many levels of bazel targets dependencies should be imported as modules. Only the targets that are present in workspace are imported.
You can use negative value to import all transitive dependencies.
import_depth: 1
The default value is -1, meaning that all transitive dependencies will be imported.
We are working on it, you can expect support for this section in future releases.
We are working on it, you can expect support for this section in future releases.
We are working on it, you can expect support for this section in future releases.
We are working on it, you can expect support for this section in future releases.
enable shard sync, split and build targets in batches to avoid Bazel OOM.
default to true
.
Used alongside with shard_sync
. It decides the number of targets to be built in each shard.
default to 1000
Used alongside with shard_sync
. It decides the sharding strategy used to shard the list of original targets.
There are three options to use:
EXPAND_AND_SHARD
: expand wildcard targets to package targets, query single targets, and then shard to batchesQUERY_AND_SHARD
: query single targets from the given list of targets without expanding, and then shard to batchesSHARD_ONLY
: split unexpanded wildcard targets into batches
default to QUERY_AND_SHARD
We are working on it, you can expect support for this section in future releases.
A set of bazel flags added to all bazel command invocations.
build_flags:
--define=ij_product=intellij-latest
No flags.
A set of bazel flags added only to bazel calls during sync.
sync_flags:
--define=ij_product=intellij-latest
No flags.
We are working on it, you can expect support for this section in future releases.
We are working on it, you can expect support for this section in future releases.
We are working on it, you can expect support for this section in future releases.
We are working on it, you can expect support for this section in future releases.
We are working on it, you can expect support for this section in future releases.
We are working on it, you can expect support for this section in future releases.
A flag specifying if targets with manual
tag should be built.
Flag is boolean value, so it can take either true or false. In the first case targets with manual
tag will be build,
otherwise they will not.
allow_manual_targets_sync: true
allow_manual_targets_sync: false