1*61c4878aSAndroid Build Coastguard Worker.. _docs-install-bazel: 2*61c4878aSAndroid Build Coastguard Worker 3*61c4878aSAndroid Build Coastguard Worker============= 4*61c4878aSAndroid Build Coastguard WorkerInstall Bazel 5*61c4878aSAndroid Build Coastguard Worker============= 6*61c4878aSAndroid Build Coastguard WorkerThis page provides recommendations on how to install Bazel 7*61c4878aSAndroid Build Coastguard Workerfor Bazel-based Pigweed projects. 8*61c4878aSAndroid Build Coastguard Worker 9*61c4878aSAndroid Build Coastguard Worker.. _docs-install-bazel-bazelisk: 10*61c4878aSAndroid Build Coastguard Worker 11*61c4878aSAndroid Build Coastguard Worker----------------------------------- 12*61c4878aSAndroid Build Coastguard WorkerCLI commands: bazelisk versus bazel 13*61c4878aSAndroid Build Coastguard Worker----------------------------------- 14*61c4878aSAndroid Build Coastguard WorkerPigweed recommends always running ``bazelisk`` rather than ``bazel`` because 15*61c4878aSAndroid Build Coastguard Worker``bazelisk`` ensures that you always run the correct Bazel version defined in 16*61c4878aSAndroid Build Coastguard Workeryour project's ``.bazelversion`` file. 17*61c4878aSAndroid Build Coastguard Worker 18*61c4878aSAndroid Build Coastguard Worker----------------- 19*61c4878aSAndroid Build Coastguard WorkerRecommended setup 20*61c4878aSAndroid Build Coastguard Worker----------------- 21*61c4878aSAndroid Build Coastguard WorkerIf you use Visual Studio (VS) Code, Pigweed's VS Code extension can manage 22*61c4878aSAndroid Build Coastguard WorkerBazel for you: 23*61c4878aSAndroid Build Coastguard Worker 24*61c4878aSAndroid Build Coastguard Worker.. _Pigweed extension: https://marketplace.visualstudio.com/items?itemName=pigweed.pigweed-vscode 25*61c4878aSAndroid Build Coastguard Worker 26*61c4878aSAndroid Build Coastguard Worker#. Get `VS Code <https://code.visualstudio.com/download>`_. 27*61c4878aSAndroid Build Coastguard Worker#. Install the `Pigweed extension`_ for VS Code. 28*61c4878aSAndroid Build Coastguard Worker 29*61c4878aSAndroid Build Coastguard Worker------------------ 30*61c4878aSAndroid Build Coastguard WorkerAlternative setups 31*61c4878aSAndroid Build Coastguard Worker------------------ 32*61c4878aSAndroid Build Coastguard Worker 33*61c4878aSAndroid Build Coastguard Worker.. _Bazelisk release: https://github.com/bazelbuild/bazelisk/releases 34*61c4878aSAndroid Build Coastguard Worker 35*61c4878aSAndroid Build Coastguard Worker.. _Bazelisk repo: https://github.com/bazelbuild/bazelisk 36*61c4878aSAndroid Build Coastguard Worker 37*61c4878aSAndroid Build Coastguard Worker.. tab-set:: 38*61c4878aSAndroid Build Coastguard Worker 39*61c4878aSAndroid Build Coastguard Worker .. tab-item:: Linux 40*61c4878aSAndroid Build Coastguard Worker :sync: linux 41*61c4878aSAndroid Build Coastguard Worker 42*61c4878aSAndroid Build Coastguard Worker .. caution:: 43*61c4878aSAndroid Build Coastguard Worker 44*61c4878aSAndroid Build Coastguard Worker Most Linux distributions don't have a recent version of Bazelisk 45*61c4878aSAndroid Build Coastguard Worker in their software repositories, or they don't have it at all. 46*61c4878aSAndroid Build Coastguard Worker 47*61c4878aSAndroid Build Coastguard Worker Install from a binary release: 48*61c4878aSAndroid Build Coastguard Worker 49*61c4878aSAndroid Build Coastguard Worker #. Get the latest `Bazelisk release`_. 50*61c4878aSAndroid Build Coastguard Worker 51*61c4878aSAndroid Build Coastguard Worker #. Add the binary to your ``PATH``. 52*61c4878aSAndroid Build Coastguard Worker 53*61c4878aSAndroid Build Coastguard Worker Install from source: 54*61c4878aSAndroid Build Coastguard Worker 55*61c4878aSAndroid Build Coastguard Worker #. Install `Go <https://go.dev/doc/install>`_. 56*61c4878aSAndroid Build Coastguard Worker 57*61c4878aSAndroid Build Coastguard Worker #. Clone the source: 58*61c4878aSAndroid Build Coastguard Worker 59*61c4878aSAndroid Build Coastguard Worker .. code-block:: 60*61c4878aSAndroid Build Coastguard Worker 61*61c4878aSAndroid Build Coastguard Worker go install github.com/bazelbuild/bazelisk@latest 62*61c4878aSAndroid Build Coastguard Worker 63*61c4878aSAndroid Build Coastguard Worker #. Add the Go binaries to your ``PATH``: 64*61c4878aSAndroid Build Coastguard Worker 65*61c4878aSAndroid Build Coastguard Worker .. code-block:: 66*61c4878aSAndroid Build Coastguard Worker 67*61c4878aSAndroid Build Coastguard Worker export PATH=$PATH:$(go env GOPATH)/bin 68*61c4878aSAndroid Build Coastguard Worker 69*61c4878aSAndroid Build Coastguard Worker .. tab-item:: macOS 70*61c4878aSAndroid Build Coastguard Worker :sync: macos 71*61c4878aSAndroid Build Coastguard Worker 72*61c4878aSAndroid Build Coastguard Worker (Recommended) `Homebrew <https://brew.sh/>`_: 73*61c4878aSAndroid Build Coastguard Worker 74*61c4878aSAndroid Build Coastguard Worker .. code-block:: 75*61c4878aSAndroid Build Coastguard Worker 76*61c4878aSAndroid Build Coastguard Worker brew install bazelisk 77*61c4878aSAndroid Build Coastguard Worker 78*61c4878aSAndroid Build Coastguard Worker `MacPorts <https://www.macports.org/install.php>`_: 79*61c4878aSAndroid Build Coastguard Worker 80*61c4878aSAndroid Build Coastguard Worker .. code-block:: 81*61c4878aSAndroid Build Coastguard Worker 82*61c4878aSAndroid Build Coastguard Worker sudo port install bazelisk 83*61c4878aSAndroid Build Coastguard Worker 84*61c4878aSAndroid Build Coastguard Worker .. tab-item:: Windows 85*61c4878aSAndroid Build Coastguard Worker :sync: windows 86*61c4878aSAndroid Build Coastguard Worker 87*61c4878aSAndroid Build Coastguard Worker (Recommended) `winget <https://learn.microsoft.com/en-us/windows/package-manager/winget/>`_: 88*61c4878aSAndroid Build Coastguard Worker 89*61c4878aSAndroid Build Coastguard Worker .. code-block:: 90*61c4878aSAndroid Build Coastguard Worker 91*61c4878aSAndroid Build Coastguard Worker winget install --id=Bazel.Bazelisk -e 92*61c4878aSAndroid Build Coastguard Worker 93*61c4878aSAndroid Build Coastguard Worker `Chocolatey <https://chocolatey.org/install>`_: 94*61c4878aSAndroid Build Coastguard Worker 95*61c4878aSAndroid Build Coastguard Worker .. code-block:: 96*61c4878aSAndroid Build Coastguard Worker 97*61c4878aSAndroid Build Coastguard Worker choco install bazelisk 98