How-to guide#
pw_watch: Embedded development file system watcher
This guide shows you how to do common pw_watch
tasks.
See Build systems for an overview of Pigweed’s approach to build systems.
Set up your Pigweed environment#
See Activate your Pigweed environment if you see an error like this:
$ pw watch
bash: pw: command not found
Ninja#
This section contains common use cases for GN users.
Set up a custom build directory#
Before running any command that uses a custom build directory, you need to
run gn gen <dir>
, where <dir>
is a placeholder for the name of your
custom build directory.
For example, before running this command:
$ pw watch -C out2
You need to run this command:
$ gn gen out2
Build the default target and use the default build directory#
$ pw watch
The default build directory is out
.
Customize the build directory#
This section assumes you have completed Set up a custom build directory.
$ pw watch -C out2
This builds the default target in out2
.
Build two targets#
$ pw watch stm32f429i python.lint
The stm32f429i
and python.lint
targets are both built in the default
build directory (out
).
Build the same target in different build directories#
This section assumes you have completed Set up a custom build directory.
$ pw watch -C out1 -C out2
This example builds the default target in both out1
and out2
.
Build different targets in different build directories#
This section assumes you have completed Set up a custom build directory.
$ pw watch stm32f429i -C out2 python.lint
The stm32f429i
target is built in the default build directory (out
).
The python.lint
target is built in the custom build directory (out2
).
Unit test integration#
Thanks to GN’s understanding of the full dependency tree, only the tests
affected by a file change are run when pw_watch
triggers a build. By
default, host builds using pw_watch
will run unit tests. To run unit tests
on a device as part of pw_watch
, refer to your device’s
target documentation.
Build-system-agnostic guides#
This section discusses general use cases that all apply to all pw watch
usage. In other words, these use cases are not affected by whether you’re
using GN, Bazel, and so on.
Ignore files#
pw watch
only rebuilds when a file that is not ignored by Git changes.
Adding exclusions to a .gitignore
causes pw watch
to ignore them, even
if the files were forcibly added to a repo. By default, only files matching
certain extensions are applied, even if they’re tracked by Git. The
--patterns
and --ignore-patterns
arguments can be used to include or
exclude specific patterns. These patterns do not override Git’s ignoring logic.
The --exclude-list
argument can be used to exclude directories from being
watched. This decreases the number of files monitored with inotify
in Linux.
Automatically reload docs#
When using --serve-docs
, by default the docs will be rebuilt when changed,
just like code files. However, you will need to manually reload the page in
your browser to see changes.
Disable automatic rebuilds#
pw watch
automatically restarts an ongoing build when files change. This
can be disabled with the --no-restart
option. While running pw watch
,
you may also press Enter to immediately restart a build.