2019-05-09 14:32:14 +02:00
# Description
This folder contains configuration for [Nix ](https://nixos.org/ ), a purely functional package manager used by the Status app for its build process.
2019-11-13 14:12:02 +01:00
## Configuration
2019-05-09 14:32:14 +02:00
The main config file is [`nix/nix.conf` ](/nix/nix.conf ) and its main purpose is defining the [binary caches ](https://nixos.org/nix/manual/#ch-basic-package-mgmt ) which allow download of packages to avoid having to compile them yourself locally.
2020-01-13 15:28:40 +01:00
## Build arguments
2020-06-05 11:23:22 +02:00
We leverage the `config` argument of standard `nixpkgs` for our own parameterization of the builds (e.g. to pass a build number or build type).
2020-04-23 20:19:12 +02:00
Here is a sample structure of the `config` attribute set:
2020-01-13 15:28:40 +01:00
```nix
2020-06-05 11:23:22 +02:00
{
2020-01-13 15:28:40 +01:00
status-im = {
2020-06-05 11:23:22 +02:00
build-type = "pr"; # Build type (influences which .env file gets used for feature flags)
build-number = 9999; # Used for versionCode and CFBundleVersion in Android and iOS respectively
2020-04-23 20:19:12 +02:00
android = {
2020-06-05 11:23:22 +02:00
gradle-opts = ""; # Gradle options passed for Android builds
keystore-path = ""; # Path to keystore for signing the APK
abi-split = false; # If APKs should be split based on architectures
abi-include = "x86"; # Android architectures to build for
2020-01-13 15:28:40 +01:00
};
2020-04-23 20:19:12 +02:00
status-go = {
src-override = "$HOME/my/source/status-go"; # local source override
2020-01-13 15:28:40 +01:00
};
};
2020-06-05 11:23:22 +02:00
}
2020-01-13 15:28:40 +01:00
```
2020-06-03 21:47:01 +02:00
You can see the defaults in [`nix/config.nix` ](./config.nix ).
2020-01-13 15:28:40 +01:00
2019-11-13 14:12:02 +01:00
## Shell
2019-05-09 14:32:14 +02:00
In order to access an interactive Nix shell a user should run `make shell` .
2019-11-29 11:20:08 +01:00
The Nix shell is started in this repo via the [`nix/scripts/shell.sh` ](/nix/scripts/shell.sh ) script, which is a wrapper around the `nix-shell` command and is intended for use with our main [`Makefile` ](/Makefile ). This allows for an implicit use of `nix-shell` as the default shell in the `Makefile` .
2019-05-09 14:32:14 +02:00
2019-11-29 11:20:08 +01:00
Normally the shell starts without any specific target platform, if you want to change that you should export the `TARGET` env variable with appropriate value:
2019-07-16 16:34:04 -04:00
```bash
2019-11-29 11:20:08 +01:00
make shell TARGET=android
2019-07-16 16:34:04 -04:00
```
2019-11-13 14:12:02 +01:00
2019-07-16 16:34:04 -04:00
This way your shell and all other nix commands should run in a setup that is tailored towards Android development.
2019-11-29 11:20:08 +01:00
For valid values you can check the [`nix/shells.nix` ](/nix/shells.nix ) file.
2019-10-15 19:00:59 +02:00
2019-11-13 14:12:02 +01:00
## Using a local status-go repository
2020-04-23 20:19:12 +02:00
If you need to use a locally checked-out status-go repository, you can achieve that by defining the `STATUS_GO_SRC_OVERRIDE`
environment variable:
2019-11-13 14:12:02 +01:00
```sh
export STATUS_GO_SRC_OVERRIDE=$GOPATH/src/github.com/status-im/status-go
make release-android
```
2020-06-05 11:23:22 +02:00
## Resources
You can learn more about Nix by watching these presentations:
* [Nix Fundamentals ](https://www.youtube.com/watch?v=m4sv2M9jRLg ) ([PDF ](https://drive.google.com/file/d/1Tt5R7QOubudGiSuZIGxuFWB1OYgcThcL/view?usp=sharing ), [src ](https://github.com/status-im/infra-docs/tree/master/presentations/nix_basics ))
* [Nix in Status ](https://www.youtube.com/watch?v=rEQ1EvRG8Wc ) ([PDF ](https://drive.google.com/file/d/1Ti0wppMoj40icCPdHy7mJcQj__DeaYBE/view?usp=sharing ), [src ](https://github.com/status-im/infra-docs/tree/master/presentations/nix_in_status ))
And you can read [`nix/DETAILS.md` ](./DETAILS.md ) for more information.
2019-11-13 14:12:02 +01:00
## Known Issues
2019-10-15 19:00:59 +02:00
2020-04-23 20:19:12 +02:00
See [`KNOWN_ISSUES.md` ](./KNOWN_ISSUES.md ).