Skip to content
The SiFive wake build tool
C C++ JavaScript Python Emacs Lisp Makefile Other
Branch: master
Clone or download
terpstra Merge pull request #243 from sifive/env-package-documentation
Add documentation for runners and environment packages
Latest commit 9da5602 Aug 16, 2019
Type Name Latest commit message Commit time
Failed to load latest commit information.
.circleci circleci: use dpkg instead of apt on wheezy Aug 15, 2019
bin digraph: move to a new scripts folder Jun 10, 2019
common re2c: update to 1.2.1 Aug 14, 2019
debian dash: required by package files too Aug 15, 2019
fuse fuse: adjust timeouts for better restart (#248) Aug 15, 2019
gopt Path: include a 'BadJob' case which acts like an exception May 12, 2019
lib/wake wake: move files around so relative paths to installed files will work Sep 27, 2018
preload preload: don't fail in runner when conflicting outputs races (#216) Jul 11, 2019
re2c re2c: confirm successful job completion Aug 14, 2019
scripts sphinx: remove CRs from files Aug 2, 2019
share Merge pull request #243 from sifive/env-package-documentation Aug 16, 2019
shim Path: include a 'BadJob' case which acts like an exception May 12, 2019
src re2c: update to 1.2.1 Aug 14, 2019
utf8proc Path: include a 'BadJob' case which acts like an exception May 12, 2019
.dockerignore Add CircleCI build rules for several OSes. May 18, 2019
LICENSE find_execpath: move to common/ May 19, 2019
LICENSE.Apache2 LICENSE: include all the relevant license files May 2, 2019
LICENSE.CC0 LICENSE: include all the relevant license files May 2, 2019
LICENSE.MIT LICENSE: include all the relevant license files May 2, 2019
LICENSE.TFL LICENSE: include all the relevant license files May 2, 2019
LICENSE.UNICODE LICENSE: include all the relevant license files May 2, 2019
LICENSE.WTFPLv2 LICENSE: include all the relevant license files May 2, 2019
Makefile make: don't use -flto in bootstrap compilation Aug 5, 2019
build.wake build: use a shellJob instead of helper script Aug 3, 2019 wake.spec: it turns out wake doesn't own /usr/{bin,lib} Aug 15, 2019

What is this?

Wake is a build orchestration tool and language. If you have a build whose steps cannot be adequately expressed in make/tup/bazel/etc, you probably need wake. If you don't want to waste time rebuilding things that don't need it, or that your colleagues already built, you might appreciate wake.

Wake features:

  • dependent job execution

    Which jobs to run next can depend on the results of previous jobs. For example, when you run configure in a traditional automake system, this typically affects what will be built by make. Similarly cmake. These two-stage build systems are necessary because make job selection cannot depend on the result of a prior build step. In complicated builds, two-stages are sometimes not enough. In wake, all jobs may be dependent.

  • dependency analysis

    In classic build systems, you must specify all the inputs and outputs of a job you want to run. If you under-specify the inputs, the build is not reproducible; it might fail to compile files that need recompilation and the job might fail non-deterministically on systems which run more jobs simultaneously. If you over-specify the inputs, the build performs unnecessary recompilation when those inputs change. In wake, if you under-specify the inputs, the build fails every time. If you over-specify the inputs, wake automatically prunes the unused dependencies so the job will not be re-run unless it must. You almost never need to tell wake what files a job builds; it knows.

  • build introspection

    When you have a built workspace, it is helpful to be able to trace the provenance of build artefacts. Wake keeps a database to record what it did. You can query that database at any time to find out exactly how a file in your workspace got there.

  • intrinsically-parallel language

    While your build orchestration files describe a sequence of compilation steps, the wake language automatically extracts parallelism. Everything runs at once. Only true data dependencies cause wake to sequence jobs. Wake handles parallelism for you, so you don't need to think about it.

  • shared build caching

    You just checked-out the master branch and started a build. However, your system runs the same software as your colleague who authored that commit. If wake can prove it's safe, it will just copy the prebuilt files and save you time. This can also translate into pull requests whose regression tests pass immediately, increasing productivity.

Installing dependencies

On Debian/Ubuntu (wheezy or later):

sudo apt-get install makedev fuse libfuse-dev libsqlite3-dev libgmp-dev libncurses5-dev pkg-config git g++ gcc libre2-dev dash

On Redhat (6.6 or later):

sudo yum install epel-release epel-release centos-release-scl
# On RHEL6: sudo yum install devtoolset-6-gcc devtoolset-6-gcc-c++
sudo yum install makedev fuse fuse-devel sqlite-devel gmp-devel ncurses-devel pkgconfig git gcc gcc-c++ re2-devel dash

On FreeBSD (12 or later):

pkg install gmake pkgconf gmp re2 sqlite3 fusefs-libs dash
echo 'fuse_load="YES"' >> /boot/loader.conf
echo 'vfs.usermount=1' >> /etc/sysctl.conf
pw groupmod operator -m YOUR-NON-ROOT-USER

On Mac OS with Mac Ports installed:

sudo port install osxfuse sqlite3 gmp re2 ncurses pkgconfig dash

On Mac OS with Home Brew installed:

brew install gmp re2 pkgconfig dash

Fuse is slightly more complicated, it requires permissions.

brew tap homebrew/cask
brew cask install osxfuse

You should see something like the following, and MacOS may ask for your password.

You must reboot for the installation of osxfuse to take effect.

System Extension Blocked
"The system extension required for mounting FUSE volumes could not be loaded.
Please open the Security & Privacy System Preferences pane, go to the General preferences and allow loading system software from developer "Benjamin Fleischer".

Then try mounting the volume again."

Give FUSE permission to run as stated in the instructions and you should be good to go.

Building wake

git clone
cd wake
git tag                 # See what versions exist
#git checkout master    # Use development branch (e.g. recent bug fix)
#git checkout v0.9      # Check out a specific version, like v0.9
./bin/wake 'install "'$HOME'/stuff"' # or wherever

External dependencies:

Optional dependencies:

Internal dependencies:


Documentation for wake can be found in share/doc/wake.

You can’t perform that action at this time.