fixes #18831 We update the nix derivation to build android by passing `hermesEnabled` flag which checks the environment variable and if the environment variable is not set we default `hermesEnabled` to `true`. This ensures that `hermes` is disabled for debug builds and enabled for release builds. In this commit we also - rename `nix/mobile/android/release.nix` → `nix/mobile/android/build.nix` since that nix file no longer generates release only builds. - cleanup 2 other env vars and use the `gradle` project format - replace `BUILD_NUMBER` with `verisonCode` for consistency - replace `androidGradleOpts ` with `buildUrl ` - bump `status-jenkins-lib` to v1.8.7
4.3 KiB
Description
This document describes the layout of our Nix setup.
Folders
There are four main folders in the nix
directory:
nix/scripts
- Bash scripts for easier usage of Nixnix/pkgs
- Packages we add to or modify innixpkgs
nix/deps
- Project dependencies managed by Nixnix/lib
- Our tools we merge intopkgs.lib
nix/tools
- Various tools used by our derivations and shellsnix/status-go
- Derivations for buildingstatus-go
repo
Files
There are a few main files that define the whole build environment:
nix/nix.conf
- Binary cache configurationnix/default.nix
- Entry point for both shells and targetsnix/shell.nix
- Definition of the default Nix shellnix/shells.nix
- Definitions of other Nix shells used in buildsnix/targets.nix
- Hierarchy of main build targetsnix/pkgs.nix
- Definition of a customnixpkgs
reponix/overlay.nix
- Overrides fornixpkgs
, custom packages
The default.nix
and shell.nix
files at th repo root are just a gateway into the nix
sub folder.
Scripts
There's a few scripts in nix/scripts
that make use of Nix simpler:
nix/scripts/setup.sh
- Installs Nix Package managernix/scripts/source.sh
- Sources the Nix profile or installs Nixnix/scripts/build.sh
- A wrapper aroundnix-build
with sane defaultsnix/scripts/shell.sh
- A wrapper aroundnix-shell
forMakefile
nix/scripts/clean.sh
- For cleaning Nix store after buildsnix/scripts/purge.sh
- For purging everything Nix related from system
Start
The starting point for using our Nix shells and targets is the default.nix
file.
It pulls in all the pkgs
, targets
and shells
defined in nix/default.nix
. The point is easy access to them via commands like nix-build
or nix-shell
, which you'll see next.
Shells
Normally shells are started using make shell TARGET=default
, but that is essentially the same as calling:
nix-shell -A shells.default default.nix
The nix/scripts/shell.sh
script is essentially a wrapper around that command to make it usable as shell for the Makefile
.
Building
We will use the make jsbundle
target as an example of a derivation you can build using Nix:
make jsbundle
is called by developermake
callsnix/scripts/build.sh targets.mobile.jsbundle
build.sh
callsnix-build --attr targets.mobile.jsbundle
with extra argumentsnix-build
builds the derivation fromnix/mobile/jsbundle/default.nix
The same can be done for other targets like targets.mobile.android.build
.
Except in that case extra arguments are required which is why the scripts/release-android.sh
is used in the make release-android
target.
If you run make release-android
you'll see the nix-build
command used:
nix-build \
--pure \
--fallback \
--no-out-link \
--show-trace \
--attr targets.mobile.android.build \
--argstr secrets-file '/tmp/tmp-status-mobile-559a3a441/tmp.xAnrPuNtAP' \
--option extra-sandbox-paths '/home/joe/.gradle/status-im.keystore /tmp/tmp-status-mobile-559a3a441/tmp.xAnrPuNtAP' \
default.nix
Some of those are required which is why just calling:
nix-build --attr targets.mobile.android.build
Would fail.
Garbage Collection
The make nix-gc
target calls nix-store --gc
and normally would remove almost everything, but to prevent that we place symlinks to protected derivations in .nix-gcroots
folder. Specifically:
_NIX_GCROOTS="${_NIX_GCROOTS:-${GIT_ROOT}/.nix-gcroots}
These symlinks in turn will be symlinked from /nix/var/nix/gcroots/auto
through use of nix-store --add-gcroots
.
Whenever nix/scripts/build.sh
or nix/scripts/shell.sh
are called they update symlinks named after given targets in that folder. This in combination with keep-outputs = true
set in nix/nix.conf
prevents garbage collection from removing too much.