The Bazel ecosystem has a growing and evolving set of rules to support popular languages and packages. Much of Bazel's strength comes from the ability to define new rules that can be used by others.
This page describes the recommended, native, and non-native Bazel rules.
Recommended rules
Here is a selection of recommended rules:
- Android
- C / C++
- Docker/OCI
- Go
- Haskell
- Java
- JavaScript / NodeJS
- Kubernetes
- Maven dependency management
- Objective-C
- Package building
- Protocol Buffers
- Python
- Scala
- Shell
- Webtesting (Webdriver)
The repository Skylib contains additional functions that can be useful when writing new rules and new macros.
The rules above were reviewed and follow our requirements for recommended rules. Contact the respective rule set's maintainers regarding issues and feature requests.
To find more Bazel rules, use a search engine, take a look on awesomebazel.com, or search on GitHub.
Native rules that do not apply to a specific programming language
Native rules are shipped with the Bazel binary, they are always available in
BUILD files without a load
statement.
- Extra actions
- General
- Platform
- Workspace
Embedded non-native rules
Bazel also embeds additional rules written in Starlark. Those can be loaded from
the @bazel_tools
built-in external repository.
- Repository rules