1.. _west-built-in-cmds:
2
3Built-in commands
4#################
5
6This page describes west's built-in commands, some of which were introduced in
7:ref:`west-basics`, in more detail.
8
9Some commands are related to Git commands with the same name, but operate
10on the entire workspace. For example, ``west diff`` shows local changes in
11multiple Git repositories in the workspace.
12
13Some commands take projects as arguments. These arguments can be project
14names as specified in the manifest file, or (as a fallback) paths to them
15on the local file system. Omitting project arguments to commands which
16accept them (such as ``west list``, ``west forall``, etc.) usually defaults
17to using all projects in the manifest file plus the manifest repository
18itself.
19
20For additional help, run ``west <command> -h`` (e.g. ``west init -h``).
21
22.. _west-init:
23
24west init
25*********
26
27This command creates a west workspace. It can be used in two ways:
28
291. Cloning a new manifest repository from a remote URL
302. Creating a workspace around an existing local manifest repository
31
32**Option 1**: to clone a new manifest repository from a remote URL, use:
33
34.. code-block:: none
35
36   west init [-m URL] [--mr REVISION] [--mf FILE] [directory]
37
38The new workspace is created in the given :file:`directory`, creating a new
39:file:`.west` inside this directory. You can give the manifest URL using
40the ``-m`` switch, the initial revision to check out using ``--mr``, and
41the location of the manifest file within the repository using ``--mf``.
42
43For example, running:
44
45.. code-block:: shell
46
47   west init -m https://github.com/zephyrproject-rtos/zephyr --mr v1.14.0 zp
48
49would clone the upstream official zephyr repository into :file:`zp/zephyr`,
50and check out the ``v1.14.0`` release. This command creates
51:file:`zp/.west`, and set the ``manifest.path`` :ref:`configuration option
52<west-config>` to ``zephyr`` to record the location of the manifest
53repository in the workspace. The default manifest file location is used.
54
55The ``-m`` option defaults to ``https://github.com/zephyrproject-rtos/zephyr``.
56The ``--mf`` option defaults to ``west.yml``. Since west v0.10.1, west will use
57the default branch in the manifest repository unless the ``--mr`` option
58is used to override it. (In prior versions, ``--mr`` defaulted to ``master``.)
59
60If no ``directory`` is given, the current working directory is used.
61
62**Option 2**: to create a workspace around an existing local manifest
63repository, use:
64
65.. code-block:: none
66
67   west init -l [--mf FILE] directory
68
69This creates :file:`.west` **next to** :file:`directory` in the file
70system, and sets ``manifest.path`` to ``directory``.
71
72As above, ``--mf`` defaults to ``west.yml``.
73
74**Reconfiguring the workspace**:
75
76If you change your mind later, you are free to change ``manifest.path`` and
77``manifest.file`` using :ref:`west-config-cmd` after running ``west init``.
78Just be sure to run ``west update`` afterwards to update your workspace to
79match the new manifest file.
80
81.. _west-update:
82
83west update
84***********
85
86.. code-block:: none
87
88   west update [-f {always,smart}] [-k] [-r]
89               [--group-filter FILTER] [--stats] [PROJECT ...]
90
91**Which projects are updated:**
92
93By default, this command parses the manifest file, usually
94:file:`west.yml`, and updates each project specified there.
95If your manifest uses :ref:`project groups <west-manifest-groups>`, then
96only the active projects are updated.
97
98To operate on a subset of projects only, give ``PROJECT`` argument(s). Each
99``PROJECT`` is either a project name as given in the manifest file, or a
100path that points to the project within the workspace. If you specify
101projects explicitly, they are updated regardless of whether they are active.
102
103**Project update procedure:**
104
105For each project that is updated, this command:
106
107#. Initializes a local Git repository for the project in the workspace, if
108   it does not already exist
109#. Inspects the project's ``revision`` field in the manifest, and fetches
110   it from the remote if it is not already available locally
111#. Sets the project's :ref:`manifest-rev <west-manifest-rev>` branch to the
112   commit specified by the revision in the previous step
113#. Checks out ``manifest-rev`` in the local working copy as a `detached
114   HEAD <https://git-scm.com/docs/git-checkout#_detached_head>`_
115#. If the manifest file specifies a :ref:`submodules
116   <west-manifest-submodules>` key for the project, recursively updates
117   the project's submodules as described below.
118
119To avoid unnecessary fetches, ``west update`` will not fetch project
120``revision`` values which are Git SHAs or tags that are already available
121locally. This is the behavior when the ``-f`` (``--fetch``) option has its
122default value, ``smart``. To force this command to fetch from project remotes
123even if the revisions appear to be available locally, either use ``-f always``
124or set the ``update.fetch`` :ref:`configuration option <west-config>` to
125``always``. SHAs may be given as unique prefixes as long as they are acceptable
126to Git [#fetchall]_.
127
128If the project ``revision`` is a Git ref that is neither a tag nor a SHA (i.e.
129if the project is tracking a branch), ``west update`` always fetches,
130regardless of ``-f`` and ``update.fetch``.
131
132Some branch names might look like short SHAs, like ``deadbeef``. West treats
133these like SHAs. You can disambiguate by prefixing the ``revision`` value with
134``refs/heads/``, e.g. ``revision: refs/heads/deadbeef``.
135
136For safety, ``west update`` uses ``git checkout --detach`` to check out a
137detached ``HEAD`` at the manifest revision for each updated project,
138leaving behind any branches which were already checked out. This is
139typically a safe operation that will not modify any of your local branches.
140
141However, if you had added some local commits onto a previously detached
142``HEAD`` checked out by west, then git will warn you that you've left
143behind some commits which are no longer referred to by any branch. These
144may be garbage-collected and lost at some point in the future. To avoid
145this if you have local commits in the project, make sure you have a local
146branch checked out before running ``west update``.
147
148If you would rather rebase any locally checked out branches instead, use
149the ``-r`` (``--rebase``) option.
150
151If you would like ``west update`` to keep local branches checked out as
152long as they point to commits that are descendants of the new
153``manifest-rev``, use the ``-k`` (``--keep-descendants``) option.
154
155.. note::
156
157   ``west update --rebase`` will fail in projects that have git conflicts
158   between your branch and new commits brought in by the manifest. You
159   should immediately resolve these conflicts as you usually do with
160   ``git``, or you can use ``git -C <project_path> rebase --abort`` to
161   ignore incoming changes for the moment.
162
163   With a clean working tree, a plain ``west update`` never fails
164   because it does not try to hold on to your commits and simply
165   leaves them aside.
166
167   ``west update --keep-descendants`` offers an intermediate option that
168   never fails either but does not treat all projects the same:
169
170   - in projects where your branch diverged from the incoming commits, it
171     does not even try to rebase and leaves your branches behind just like a
172     plain ``west update`` does;
173   - in all other projects where no rebase or merge is needed it keeps
174     your branches in place.
175
176**One-time project group manipulation:**
177
178The ``--group-filter`` option can be used to change which project groups
179are enabled or disabled for the duration of a single ``west update`` command.
180See :ref:`west-manifest-groups` for details on the project group feature.
181
182The ``west update`` command behaves as if the ``--group-filter`` option's
183value were appended to the ``manifest.group-filter``
184:ref:`configuration option <west-config-index>`.
185
186For example, running ``west update --group-filter=+foo,-bar`` would behave
187the same way as if you had temporarily appended the string ``"+foo,-bar"``
188to the value of ``manifest.group-filter``, run ``west update``, then restored
189``manifest.group-filter`` to its original value.
190
191Note that using the syntax ``--group-filter=VALUE`` instead of
192``--group-filter VALUE`` avoids issues parsing command line options
193if you just want to disable a single group, e.g. ``--group-filter=-bar``.
194
195**Submodule update procedure:**
196
197If a project in the manifest has a ``submodules`` key, the submodules are
198updated as follows, depending on the value of the ``submodules`` key.
199
200If the project has ``submodules: true``, west first synchronizes the project's
201submodules with:
202
203.. code-block::
204
205   git submodule sync --recursive
206
207West then runs one of the following in the project repository, depending on
208whether you run ``west update`` with the ``--rebase`` option or without it:
209
210.. code-block::
211
212   # without --rebase, e.g. "west update":
213   git submodule update --init --checkout --recursive
214
215   # with --rebase, e.g. "west update --rebase":
216   git submodule update --init --rebase --recursive
217
218Otherwise, the project has ``submodules: <list-of-submodules>``. In this
219case, west synchronizes the project's submodules with:
220
221.. code-block::
222
223   git submodule sync --recursive -- <submodule-path>
224
225Then it updates each submodule in the list as follows, depending on whether you
226run ``west update`` with the ``--rebase`` option or without it:
227
228.. code-block::
229
230   # without --rebase, e.g. "west update":
231   git submodule update --init --checkout --recursive <submodule-path>
232
233   # with --rebase, e.g. "west update --rebase":
234   git submodule update --init --rebase --recursive <submodule-path>
235
236The ``git submodule sync`` commands are skipped if the
237``update.sync-submodules`` :ref:`west-config` option is false.
238
239.. _west-built-in-misc:
240
241Other project commands
242**********************
243
244West has a few more commands for managing the projects in the
245workspace, which are summarized here. Run ``west <command> -h`` for
246detailed help.
247
248- ``west compare``: compare the state of the workspace against the manifest
249- ``west diff``: run ``git diff`` in local project repositories
250- ``west forall``: run an arbitrary command in local project repositories
251- ``west grep``: search for patterns in local project repositories
252- ``west list``: print a line of information about each project in the
253  manifest, according to a format string
254- ``west manifest``: manage the manifest file. See :ref:`west-manifest-cmd`.
255- ``west status``: run ``git status`` in local project repositories
256
257Other built-in commands
258***********************
259
260Finally, here is a summary of other built-in commands.
261
262- ``west config``: get or set :ref:`configuration options <west-config>`
263- ``west topdir``: print the top level directory of the west workspace
264- ``west help``: get help about a command, or print information about all
265  commands in the workspace, including :ref:`west-extensions`
266
267.. rubric:: Footnotes
268
269.. [#fetchall]
270
271   West may fetch all refs from the Git server when given a SHA as a revision.
272   This is because some Git servers have historically not allowed fetching
273   SHAs directly.
274