First install the Nix package manager and then enable Flakes. Alternatively, check out the Determinate Systems Installer for an out of the box experience. See nix.dev for more help with Nix.
To get a shell with adamantine temporarily installed, run:
$ nix shell github:adamantine-sim/adamantine
# Adamantine now available
$ adamantine --help
To install this permanently, run:
$ nix profile install github:adamantine-sim/adamantine
To get the latest stable release, use:
$ nix shell github:adamantine-sim/adamantine#adamantine.versions.stable
To build from a working copy use nix develop
and run CMake manually:
$ nix develop
$ cmake -B build -GNinja
$ cmake --build build
To avoid unnecessary builds, you can use the cache as configured in
flake.nix
. The only requirement is that your user is a "trusted user" by the
nix dameon.
If you are not a trusted user, you may make yourself one by editing
/etc/nix/nix.conf
and add the following line:
...
trusted-users = [YOUR USERNAME HERE]
...
Then, when running a nix operation with the Adamantine flake, you should be prompted if you want to add the cache to your configuration. Say yes to all queries to enable the cache permanently.
For more info, see the docs for this option here.
This repository also supports direnv
for integration with both your shell and
tools like VSCode.
First install direnv from either your distro or via Nix:
# Via apt...
$ sudo apt install direnv
# ... or nix.
$ nix profile install direnv
Setup direnv for your shell. Tutorials for various shells can be found here. For bash:
$ echo "eval \"\$(direnv hook bash)\"" >> ~/.bashrc
Restart your shell and then allow direnv:
$ cd path/to/my/adamantine
$ direnv allow
This will automatically enter the nix development shell whenever you enter the adamantine directory.
If you use VSCode, a great extension that adds direnv support can be found here.