Skip to content

Commit

Permalink
Re #6269 Improve nix: enable: defaults documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
mpilgrem committed Oct 3, 2023
1 parent dfb4489 commit 73c7f45
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 21 deletions.
32 changes: 16 additions & 16 deletions doc/nix_integration.md
Original file line number Diff line number Diff line change
Expand Up @@ -70,12 +70,13 @@ information about how Stack itself can configure `NIX_PATH`, see further

### Enable Nix integration

To enable Nix integration, add the following section to your Stack YAML
configuration file (`stack.yaml` or `config.yaml`):
On NixOS, Nix integration is enabled by default; on other operating systems it
is disabled. To enable Nix integration, add the following section to your Stack
YAML configuration file (`stack.yaml` or `config.yaml`):

~~~yaml
nix:
enable: true # false by default
enable: true # false by default, except on NixOS
~~~

The equivalent command line flag (which will prevail) is `--[no-]nix`. Passing
Expand Down Expand Up @@ -366,34 +367,32 @@ branch, or edit the Nix descriptions of some packages.
The Tweag example [repository][tweag-example] shows how you can pin a package
set.

## Configuration options
## Non-project specific configuration

Below is a summary of the Stack YAML configuration file settings, identifying
default values:
Below is a summary of the non-project specific configuration options and their
default values. The options can be set in Stack's project-level configuration
file (`stack.yaml`) or its global configuration file (`config.yaml`).

~~~yaml
nix:

# false by default. Must be present and set to `true` to enable Nix, except on
# NixOS where it is enabled by default (see #3938). You can set it in
# your `$HOME/.stack/config.yaml` to enable Nix for all your projects without
# having to repeat it
# false by default, except on NixOS. Is Nix integration enabled?
enable: true

# true by default. Tells Nix whether to run in a pure shell or not.
# true by default. Should Nix run in a pure shell?
pure: true

# Empty by default. The list of packages you want to be
# available in the nix-shell at build time (with `stack
# build`) and run time (with `stack exec`).
# Empty by default. The list of packages you want to be available in the
# nix-shell at build time (with `stack build`) and run time (with
# `stack exec`).
packages: []

# Unset by default. You cannot set this option if `packages:`
# is already present and not empty.
shell-file: shell.nix

# A list of strings, empty by default. Additional options that
# will be passed verbatim to the `nix-shell` command.
# A list of strings, empty by default. Additional options that will be passed
# verbatim to the `nix-shell` command.
nix-shell-options: []

# A list of strings, empty by default, such as
Expand All @@ -405,6 +404,7 @@ nix:
# collection roots. This way, calling nix-collect-garbage will not remove
# those packages from the Nix store, saving you some time when running
# stack build again with Nix support activated.
#
# This creates a `nix-gc-symlinks` directory in the project `.stack-work`.
# To revert that, just delete this `nix-gc-symlinks` directory.
add-gc-roots: false
Expand Down
10 changes: 5 additions & 5 deletions doc/yaml_configuration.md
Original file line number Diff line number Diff line change
Expand Up @@ -1116,13 +1116,13 @@ Default:

~~~yaml
nix:
add-gc-roots: false
enable: false
nix-shell-options: []
packages: []
path: []
enable: false # Except on NixOS, where `enable: true`
pure: true
packages: []
shell-file:
nix-shell-options: []
path: []
add-gc-roots: false
~~~

Command line equivalents: `--nix-*` flags and options (see `stack --nix-help`
Expand Down

0 comments on commit 73c7f45

Please sign in to comment.