Skip to content

Development Setup

This page explains how to set up the repository for development. This is for two main groups of users:

  • Those who want to contribute to the library, either the code or the docs.
  • Those who want to work through the tutorial exercises.

Tip

If all you want to do is install the library in your project, you can simply use our installation guide.

Core development setup

These steps are common to all workflows.

Step 0: Decide whether to fork

If you’re confident that you want to contribute, you should start out by forking the repository. This gives you your own copy which you can modify, and from which you can create pull requests to share your changes with the main repository. Here are GitHub’s instructions for forking.

Everyone else can simply skip this step and work directly from the main repository. If you decide later on to make a pull request, you’ll still need to create a fork, but it’s easy to set it up after the fact. We’ll provide detailed instructions below.

Instructions for switching an existing clone to a fork

If you’re here, you probably cloned the main repository directly, and then later decided to make a pull request. For that, you’ll need to switch your origin remote to point to your fork instead of the main repository.

You can directly use the instructions below, which we adapted from this guide.

  1. Create the fork on GitHub.

    You will need to note the name of your fork, in the format user_name/repo_name. Typically, the user_name part will be replaced with your GitHub username, and the repo_name part will simply be au.

  2. Rename origin to upstream. We still want to track the main repository; we just need to give it a different name. Run this command verbatim:

    git remote rename origin upstream
    
  3. Make your fork the new origin. Your command will start with git remote add origin, and end with a URL for your repository. If your GitHub username were user_name, the full command should look like this:

    git remote add origin git@github.com:user_name/au.git
    #                                    ^^^^^^^^^
    # Example only: remember to replace user name!
    
  4. Fetch from origin. Run this command verbatim:

    git fetch origin
    
  5. Track origin from main. Run this command verbatim:

    git branch -u origin/main main
    

At this point, you should be able to create a pull request in the usual way, simply by pushing a local branch to your fork via the origin remote.

Step 1: Clone the repository

This step gets the Au source code onto your machine. The precise details depend on whether you decided to fork or not in the previous step.

Did you fork, or not?

This is for users who just want to work through the tutorials, or play around with the code.

git clone https://github.com/aurora-opensource/au.git

Follow GitHub’s cloning instructions, using the fork you created as the repository.

Whichever approach you took, you should have a folder named au/ in your current directory which contains the Au source code.

Step 2: Set up direnv

direnv is a tool that makes it easy to use the correct version of every tool we use: bazel, clang-format, buildifier, and other project-specific ones like make-single-file and au-docs-serve. It will add these tools to your $PATH, but only when you’re inside your copy of the repository.

What if you skip this step?

This step is optional, but highly recommended. If you skip this step, you’ll need to prepend tools/bin/ to every command that comes from Au’s tools directory. For example,

  • Replace bazel with tools/bin/bazel.
  • Replace clang-format with tools/bin/clang-format.

And so on.

The first step to set up direnv is to install the tool itself, using their installation instructions.

The next time you enter your Au folder, you’ll get a warning message like this:

direnv: error .envrc is blocked. Run `direnv allow` to approve its content.

Simply do what it says and run direnv allow, and you’re all set!

Testing your installation

You can test that everything’s working by running bazel --version inside your Au folder. You should get a result compatible with the current contents of the .bazelversion file. For example, at the time of writing, we’re on bazel 5.3.0, so this command produces the output:

bazel 5.3.0

Specific workflows

Now that your basic development setup is complete, here are some types of workflows you can do.

Building and testing the code

To build and test the entire repository, run bazel test //...:all.

Note

The first time you run any command such as bazel, there may be some additional overhead from downloading or configuring the tool itself. This is a one-time cost, and each subsequent run should be fast.

You can also specify any number of specific targets or target patterns, using bazel’s target syntax. For example, if you wanted to test the core library code (which lives in //au), and test the generated single-file package (whose target is //release:au_hh_test), you could write:

bazel test //au:all //release:au_hh_test

Using different toolchains

Au comes pre-packaged with support for several different compiler toolchains. To use a specific toolchain — say, X — pass it as a --config=X argument. For example, here’s how you would run all of the tests using gcc 10:

bazel test --config=gcc10 //...:all

Here are the possible values we support for --config:

--config value compiler
clang14 Clang 14 (default)
clang11 Clang 11
gcc10 gcc 10
What if your preferred compiler isn’t in this list?

Our goal is for Au to work with any standards-compliant compiler that fully supports C++14, or any later language standard. We’ve had good results with a variety of compilers already, so we recommend simply trying Au in yours!

If you do, and you find a bug, please feel free to file an issue. If the compiler is fully C++14-compatible, we’ll do our best to find a fix, or an acceptable workaround. We may also consider adding the compiler to our officially supported list, as long as we can use it via a hermetic bazel toolchain.

Building and viewing documentation

It’s easy to set up a local version of the documentation website. Simply run the included command, au-docs-serve. Here’s some example output:

INFO: Analyzed target //:update_docs (0 packages loaded, 0 targets configured).
INFO: Found 1 target...
Target //:update_docs up-to-date:
  bazel-bin/update_docs
INFO: Elapsed time: 0.309s, Critical Path: 0.06s
INFO: 1 process: 1 internal.
INFO: Build completed successfully, 1 total action
INFO: Build completed successfully, 1 total action
INFO     -  Building documentation...
INFO     -  Cleaning site directory
INFO     -  Documentation built in 0.35 seconds
INFO     -  [16:02:34] Watching paths for changes: 'docs', 'mkdocs.yml'
INFO     -  [16:02:34] Serving on http://127.0.0.1:8000/au/

The last line shows that you can view the website at the included (local) URL, http://127.0.0.1:8000/au/.

The command stays running until you interrupt it (typically via Ctrl-C, or the equivalent on your terminal). Note that as long as it stays running, it will automatically regenerate the website whenever you edit any file, and the browser will automatically reload the page!

Viewing documentation on a remote machine

Some users connect to a remote machine via ssh to do their development. In this case, au-docs-serve won’t work out of the box. The reason is that it’s running on your remote machine, but your web browser is on your local machine. When you try to open the URL http://127.0.0.1:8000/au/, which points to the local machine, it can’t find the web server, because it’s running on the remote machine.

The solution is to forward the port, 8000, when you connect to your remote machine. If you do, then local requests on that port will be forwarded along to the remote machine, where the web server is running. Here’s how you do that.

  1. Find your usual ssh command. This is whatever you run on your local machine to connect to the remote host. For example, if your username is user and your remote hostname is remote.host, this might look like the following:

    ssh user@remote.host
    
  2. Add an option for port forwarding. Expanding on the previous example, this would be:

    ssh -L 8000:localhost:8000 user@remote.host
    #  ^^^^^^^^^^^^^^^^^^^^^^^ Note: this is added
    
  3. Run au-docs-serve on the remote host. Naturally, you’ll need to be in your Au folder to do this.

At this point, as long as that command stays running on your remote host, you should be able to visit the URL in your local browser, and view the documentation website.