xref: /aosp_15_r20/external/pigweed/docs/get_started/install_bazel.rst (revision 61c4878ac05f98d0ceed94b57d316916de578985)
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