doc/develop/west/why.rst
.. _west-history:
History and Motivation ######################
West was added to the Zephyr project to fulfill two fundamental requirements:
During the development of west, a set of :ref:west-design-constraints were
identified to avoid the common pitfalls of tools of this kind.
Requirements
Although the motivation behind splitting the Zephyr codebase into multiple repositories is outside of the scope of this page, the fundamental requirements, along with a clear justification of the choice not to use existing tools and instead develop a new one, do belong here.
The basic requirements are:
Rationale for a custom tool
Some of west's features are similar to those provided by
Git Submodules <https://git-scm.com/book/en/v2/Git-Tools-Submodules>_ and
Google's repo <https://gerrit.googlesource.com/git-repo/>_.
Existing tools were considered during west's initial design and development. None were found suitable for Zephyr's requirements. In particular, these were examined in detail:
Google repo
Git submodules
HEAD in external
repositories (R4)Multiple Git Repositories
Zephyr intends to provide all required building blocks needed to deploy complex IoT applications. This in turn means that the Zephyr project is much more than an RTOS kernel, and is instead a collection of components that work together. In this context, there are a few reasons to work with multiple Git repositories in a standardized manner within the project:
See :ref:west-basics for information on how west workspaces manage multiple
git repositories.
.. _west-design-constraints:
Design Constraints
West is:
Optional: it is always possible to drop back to "raw" command-line tools, i.e. use Zephyr without using west (although west itself might need to be installed and accessible to the build system). It may not always be convenient to do so, however. (If all of west's features were already conveniently available, there would be no reason to develop it.)
Compatible with CMake: building, flashing and debugging, and emulator support will always remain compatible with direct use of CMake.
Cross-platform: West is written in Python 3, and works on all platforms supported by Zephyr.
Usable as a Library: whenever possible, west features are
implemented as libraries that can be used standalone in other
programs, along with separate command line interfaces that wrap
them. West itself is a Python package named west; its libraries
are implemented as subpackages.
Conservative about features: no features will be accepted without strong and compelling motivation.
Clearly specified: West's behavior in cases where it wraps other commands is clearly specified and documented. This enables interoperability with third party tools, and means Zephyr developers can always find out what is happening "under the hood" when using west.
See :github:Zephyr issue #6205 <6205> and for more details and discussion.
.. _west-update-detached-heads:
west update detached HEADs
The use of detached git HEAD revisions documented in the :ref:update procedure <west-update-procedure> confuses and even frustrates some users.
Specifically, users often ask why west update doesn't leave existing local
branches checked out by default.
This section explains why west update behaves the way it does by default,
and mentions some other options you have for managing projects that you
modified locally.
Two core requirements for west update are:
#. safety: the command should not lose any of the user's work
#. determinism: two users running west update on the same manifest should
get the exact same :ref:workspace <west-basics> contents
Using detached HEADs helps preserve safety. As documented in the update
procedure, using git checkout --detach on the updated project to get a
detached HEAD is a generally safe operation that won't lose the user's
work:
if your work is all safely committed in a local git branch, that branch
will be left as-is (see the git help checkout output for details)
if you have uncommitted work, it will be safely kept in your working tree by git if that's possible
if that's not possible, the entire command will fail, and you can decide what
to do with your work before re-running west update
Detached HEADs also help ensure determinism:
Checking out exactly the project revision that's specified in your manifest
file is needed to make sure your workspace's files match what's specified in
the main manifest. If west did not check out the manifest revision by
default, your workspace could be invisibly different from what you would
expect given the contents of the manifest files in your working copy. Even
worse, the way it was different would depend on exactly what was in your
branch before you ran west update.
There is a subtle interaction with :ref:west-manifest-import. If your
project itself has one or more manifest files that are being imported by
west update, then west needs to check out those files into the working
tree so it can resolve the entire imported manifest. If west update left
a branch checked out in your project, the manifest files in your working tree
could be out of date. If west then used those out-of-date files to finish the
import, the process could fail unexpectedly or produce other nondeterministic
results.
West does not check out the :ref:manifest-rev <west-manifest-rev> branch
directly for reasons explained in the documentation for that branch.
This default behavior was chosen a long time ago and it's too late to change it
now, since users are depending on it. However, there are other ways to run
west update if this default doesn't work for you. To learn more, run west help update and read the checked out branch behavior option group text.
For example:
if you're actively writing some code in your project and you want
to keep it up to date after potential changes in the upstream manifest,
use west update --rebase
if you've got some local code you'd like to keep around as long as the
upstream revision for your project hasn't moved on to something newer, use
west update --keep-descendants
You can use :ref:west-aliases if you want to set up a shorter way to type one
of these commands in your workspace. You can also contribute new options to
this option group by sending a pull request to: