mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-12-01 18:16:14 +02:00
Merge pull request #8932 from fricklerhandwerk/formatting
dedent common options listing; one sentence per line
This commit is contained in:
commit
216c66ddcf
1 changed files with 161 additions and 174 deletions
|
@ -2,217 +2,204 @@
|
||||||
|
|
||||||
Most Nix commands accept the following command-line options:
|
Most Nix commands accept the following command-line options:
|
||||||
|
|
||||||
- <span id="opt-help">[`--help`](#opt-help)</span>\
|
- <span id="opt-help">[`--help`](#opt-help)</span>
|
||||||
Prints out a summary of the command syntax and exits.
|
|
||||||
|
|
||||||
- <span id="opt-version">[`--version`](#opt-version)</span>\
|
Prints out a summary of the command syntax and exits.
|
||||||
Prints out the Nix version number on standard output and exits.
|
|
||||||
|
|
||||||
- <span id="opt-verbose">[`--verbose`](#opt-verbose)</span> / `-v`\
|
- <span id="opt-version">[`--version`](#opt-version)</span>
|
||||||
Increases the level of verbosity of diagnostic messages printed on
|
|
||||||
standard error. For each Nix operation, the information printed on
|
|
||||||
standard output is well-defined; any diagnostic information is
|
|
||||||
printed on standard error, never on standard output.
|
|
||||||
|
|
||||||
This option may be specified repeatedly. Currently, the following
|
Prints out the Nix version number on standard output and exits.
|
||||||
verbosity levels exist:
|
|
||||||
|
|
||||||
- 0\
|
- <span id="opt-verbose">[`--verbose`](#opt-verbose)</span> / `-v`
|
||||||
“Errors only”: only print messages explaining why the Nix
|
|
||||||
invocation failed.
|
|
||||||
|
|
||||||
- 1\
|
Increases the level of verbosity of diagnostic messages printed on standard error.
|
||||||
“Informational”: print *useful* messages about what Nix is
|
For each Nix operation, the information printed on standard output is well-defined;
|
||||||
doing. This is the default.
|
any diagnostic information is printed on standard error, never on standard output.
|
||||||
|
|
||||||
- 2\
|
This option may be specified repeatedly.
|
||||||
“Talkative”: print more informational messages.
|
Currently, the following verbosity levels exist:
|
||||||
|
|
||||||
- 3\
|
- `0` “Errors only”
|
||||||
“Chatty”: print even more informational messages.
|
|
||||||
|
|
||||||
- 4\
|
Only print messages explaining why the Nix invocation failed.
|
||||||
“Debug”: print debug information.
|
|
||||||
|
|
||||||
- 5\
|
- `1` “Informational”
|
||||||
“Vomit”: print vast amounts of debug information.
|
|
||||||
|
|
||||||
- <span id="opt-quiet">[`--quiet`](#opt-quiet)</span>\
|
Print *useful* messages about what Nix is doing.
|
||||||
Decreases the level of verbosity of diagnostic messages printed on
|
This is the default.
|
||||||
standard error. This is the inverse option to `-v` / `--verbose`.
|
|
||||||
|
|
||||||
This option may be specified repeatedly. See the previous verbosity
|
- `2` “Talkative”
|
||||||
levels list.
|
|
||||||
|
|
||||||
- <span id="opt-log-format">[`--log-format`](#opt-log-format)</span> *format*\
|
Print more informational messages.
|
||||||
This option can be used to change the output of the log format, with
|
|
||||||
*format* being one of:
|
|
||||||
|
|
||||||
- raw\
|
- `3` “Chatty”
|
||||||
This is the raw format, as outputted by nix-build.
|
|
||||||
|
|
||||||
- internal-json\
|
Print even more informational messages.
|
||||||
Outputs the logs in a structured manner.
|
|
||||||
|
|
||||||
> **Warning**
|
- `4` “Debug”
|
||||||
>
|
|
||||||
> While the schema itself is relatively stable, the format of
|
|
||||||
> the error-messages (namely of the `msg`-field) can change
|
|
||||||
> between releases.
|
|
||||||
|
|
||||||
- bar\
|
Print debug information.
|
||||||
Only display a progress bar during the builds.
|
|
||||||
|
|
||||||
- bar-with-logs\
|
- `5` “Vomit”
|
||||||
Display the raw logs, with the progress bar at the bottom.
|
|
||||||
|
|
||||||
- <span id="opt-no-build-output">[`--no-build-output`](#opt-no-build-output)</span> / `-Q`\
|
Print vast amounts of debug information.
|
||||||
By default, output written by builders to standard output and
|
|
||||||
standard error is echoed to the Nix command's standard error. This
|
|
||||||
option suppresses this behaviour. Note that the builder's standard
|
|
||||||
output and error are always written to a log file in
|
|
||||||
`prefix/nix/var/log/nix`.
|
|
||||||
|
|
||||||
- <span id="opt-max-jobs">[`--max-jobs`](#opt-max-jobs)</span> / `-j` *number*\
|
- <span id="opt-quiet">[`--quiet`](#opt-quiet)</span>
|
||||||
Sets the maximum number of build jobs that Nix will perform in
|
|
||||||
parallel to the specified number. Specify `auto` to use the number
|
|
||||||
of CPUs in the system. The default is specified by the `max-jobs`
|
|
||||||
configuration setting, which itself defaults to `1`. A higher
|
|
||||||
value is useful on SMP systems or to exploit I/O latency.
|
|
||||||
|
|
||||||
Setting it to `0` disallows building on the local machine, which is
|
Decreases the level of verbosity of diagnostic messages printed on standard error.
|
||||||
useful when you want builds to happen only on remote builders.
|
This is the inverse option to `-v` / `--verbose`.
|
||||||
|
|
||||||
- <span id="opt-cores">[`--cores`](#opt-cores)</span>\
|
This option may be specified repeatedly.
|
||||||
Sets the value of the `NIX_BUILD_CORES` environment variable in
|
See the previous verbosity levels list.
|
||||||
the invocation of builders. Builders can use this variable at
|
|
||||||
their discretion to control the maximum amount of parallelism. For
|
|
||||||
instance, in Nixpkgs, if the derivation attribute
|
|
||||||
`enableParallelBuilding` is set to `true`, the builder passes the
|
|
||||||
`-jN` flag to GNU Make. It defaults to the value of the `cores`
|
|
||||||
configuration setting, if set, or `1` otherwise. The value `0`
|
|
||||||
means that the builder should use all available CPU cores in the
|
|
||||||
system.
|
|
||||||
|
|
||||||
- <span id="opt-max-silent-time">[`--max-silent-time`](#opt-max-silent-time)</span>\
|
- <span id="opt-log-format">[`--log-format`](#opt-log-format)</span> *format*
|
||||||
Sets the maximum number of seconds that a builder can go without
|
|
||||||
producing any data on standard output or standard error. The
|
|
||||||
default is specified by the `max-silent-time` configuration
|
|
||||||
setting. `0` means no time-out.
|
|
||||||
|
|
||||||
- <span id="opt-timeout">[`--timeout`](#opt-timeout)</span>\
|
This option can be used to change the output of the log format, with *format* being one of:
|
||||||
Sets the maximum number of seconds that a builder can run. The
|
|
||||||
default is specified by the `timeout` configuration setting. `0`
|
|
||||||
means no timeout.
|
|
||||||
|
|
||||||
- <span id="opt-keep-going">[`--keep-going`](#opt-keep-going)</span> / `-k`\
|
- `raw`
|
||||||
Keep going in case of failed builds, to the greatest extent
|
|
||||||
possible. That is, if building an input of some derivation fails,
|
|
||||||
Nix will still build the other inputs, but not the derivation
|
|
||||||
itself. Without this option, Nix stops if any build fails (except
|
|
||||||
for builds of substitutes), possibly killing builds in progress (in
|
|
||||||
case of parallel or distributed builds).
|
|
||||||
|
|
||||||
- <span id="opt-keep-failed">[`--keep-failed`](#opt-keep-failed)</span> / `-K`\
|
This is the raw format, as outputted by nix-build.
|
||||||
Specifies that in case of a build failure, the temporary directory
|
|
||||||
(usually in `/tmp`) in which the build takes place should not be
|
|
||||||
deleted. The path of the build directory is printed as an
|
|
||||||
informational message.
|
|
||||||
|
|
||||||
- <span id="opt-fallback">[`--fallback`](#opt-fallback)</span>\
|
- `internal-json`
|
||||||
Whenever Nix attempts to build a derivation for which substitutes
|
|
||||||
are known for each output path, but realising the output paths
|
|
||||||
through the substitutes fails, fall back on building the derivation.
|
|
||||||
|
|
||||||
The most common scenario in which this is useful is when we have
|
Outputs the logs in a structured manner.
|
||||||
registered substitutes in order to perform binary distribution from,
|
|
||||||
say, a network repository. If the repository is down, the
|
|
||||||
realisation of the derivation will fail. When this option is
|
|
||||||
specified, Nix will build the derivation instead. Thus, installation
|
|
||||||
from binaries falls back on installation from source. This option is
|
|
||||||
not the default since it is generally not desirable for a transient
|
|
||||||
failure in obtaining the substitutes to lead to a full build from
|
|
||||||
source (with the related consumption of resources).
|
|
||||||
|
|
||||||
- <span id="opt-readonly-mode">[`--readonly-mode`](#opt-readonly-mode)</span>\
|
> **Warning**
|
||||||
When this option is used, no attempt is made to open the Nix
|
>
|
||||||
database. Most Nix operations do need database access, so those
|
> While the schema itself is relatively stable, the format of
|
||||||
operations will fail.
|
> the error-messages (namely of the `msg`-field) can change
|
||||||
|
> between releases.
|
||||||
|
|
||||||
- <span id="opt-arg">[`--arg`](#opt-arg)</span> *name* *value*\
|
- `bar`
|
||||||
This option is accepted by `nix-env`, `nix-instantiate`,
|
|
||||||
`nix-shell` and `nix-build`. When evaluating Nix expressions, the
|
|
||||||
expression evaluator will automatically try to call functions that
|
|
||||||
it encounters. It can automatically call functions for which every
|
|
||||||
argument has a [default
|
|
||||||
value](@docroot@/language/constructs.md#functions) (e.g.,
|
|
||||||
`{ argName ? defaultValue }: ...`). With `--arg`, you can also
|
|
||||||
call functions that have arguments without a default value (or
|
|
||||||
override a default value). That is, if the evaluator encounters a
|
|
||||||
function with an argument named *name*, it will call it with value
|
|
||||||
*value*.
|
|
||||||
|
|
||||||
For instance, the top-level `default.nix` in Nixpkgs is actually a
|
Only display a progress bar during the builds.
|
||||||
function:
|
|
||||||
|
|
||||||
```nix
|
- `bar-with-logs`
|
||||||
{ # The system (e.g., `i686-linux') for which to build the packages.
|
|
||||||
system ? builtins.currentSystem
|
|
||||||
...
|
|
||||||
}: ...
|
|
||||||
```
|
|
||||||
|
|
||||||
So if you call this Nix expression (e.g., when you do `nix-env --install --attr
|
Display the raw logs, with the progress bar at the bottom.
|
||||||
pkgname`), the function will be called automatically using the
|
|
||||||
value [`builtins.currentSystem`](@docroot@/language/builtins.md) for
|
|
||||||
the `system` argument. You can override this using `--arg`, e.g.,
|
|
||||||
`nix-env --install --attr pkgname --arg system \"i686-freebsd\"`. (Note that
|
|
||||||
since the argument is a Nix string literal, you have to escape the
|
|
||||||
quotes.)
|
|
||||||
|
|
||||||
- <span id="opt-argstr">[`--argstr`](#opt-argstr)</span> *name* *value*\
|
- <span id="opt-no-build-output">[`--no-build-output`](#opt-no-build-output)</span> / `-Q`
|
||||||
This option is like `--arg`, only the value is not a Nix
|
|
||||||
expression but a string. So instead of `--arg system
|
|
||||||
\"i686-linux\"` (the outer quotes are to keep the shell happy) you
|
|
||||||
can say `--argstr system i686-linux`.
|
|
||||||
|
|
||||||
- <span id="opt-attr">[`--attr`](#opt-attr)</span> / `-A` *attrPath*\
|
By default, output written by builders to standard output and standard error is echoed to the Nix command's standard error.
|
||||||
Select an attribute from the top-level Nix expression being
|
This option suppresses this behaviour.
|
||||||
evaluated. (`nix-env`, `nix-instantiate`, `nix-build` and
|
Note that the builder's standard output and error are always written to a log file in `prefix/nix/var/log/nix`.
|
||||||
`nix-shell` only.) The *attribute path* *attrPath* is a sequence
|
|
||||||
of attribute names separated by dots. For instance, given a
|
|
||||||
top-level Nix expression *e*, the attribute path `xorg.xorgserver`
|
|
||||||
would cause the expression `e.xorg.xorgserver` to be used. See
|
|
||||||
[`nix-env --install`](@docroot@/command-ref/nix-env/install.md) for some
|
|
||||||
concrete examples.
|
|
||||||
|
|
||||||
In addition to attribute names, you can also specify array indices.
|
- <span id="opt-max-jobs">[`--max-jobs`](#opt-max-jobs)</span> / `-j` *number*
|
||||||
For instance, the attribute path `foo.3.bar` selects the `bar`
|
|
||||||
attribute of the fourth element of the array in the `foo` attribute
|
|
||||||
of the top-level expression.
|
|
||||||
|
|
||||||
- <span id="opt-expr">[`--expr`](#opt-expr)</span> / `-E`\
|
Sets the maximum number of build jobs that Nix will perform in parallel to the specified number.
|
||||||
Interpret the command line arguments as a list of Nix expressions to
|
Specify `auto` to use the number of CPUs in the system.
|
||||||
be parsed and evaluated, rather than as a list of file names of Nix
|
The default is specified by the `max-jobs` configuration setting, which itself defaults to `1`.
|
||||||
expressions. (`nix-instantiate`, `nix-build` and `nix-shell` only.)
|
A higher value is useful on SMP systems or to exploit I/O latency.
|
||||||
|
|
||||||
For `nix-shell`, this option is commonly used to give you a shell in
|
Setting it to `0` disallows building on the local machine, which is useful when you want builds to happen only on remote builders.
|
||||||
which you can build the packages returned by the expression. If you
|
|
||||||
want to get a shell which contain the *built* packages ready for
|
|
||||||
use, give your expression to the `nix-shell --packages ` convenience flag
|
|
||||||
instead.
|
|
||||||
|
|
||||||
- <span id="opt-I">[`-I`](#opt-I)</span> *path*\
|
- <span id="opt-cores">[`--cores`](#opt-cores)</span>
|
||||||
Add an entry to the [Nix expression search path](@docroot@/command-ref/conf-file.md#conf-nix-path).
|
|
||||||
This option may be given multiple times.
|
|
||||||
Paths added through `-I` take precedence over [`NIX_PATH`](@docroot@/command-ref/env-common.md#env-NIX_PATH).
|
|
||||||
|
|
||||||
- <span id="opt-option">[`--option`](#opt-option)</span> *name* *value*\
|
Sets the value of the `NIX_BUILD_CORES` environment variable in the invocation of builders.
|
||||||
Set the Nix configuration option *name* to *value*. This overrides
|
Builders can use this variable at their discretion to control the maximum amount of parallelism.
|
||||||
settings in the Nix configuration file (see nix.conf5).
|
For instance, in Nixpkgs, if the derivation attribute `enableParallelBuilding` is set to `true`, the builder passes the `-jN` flag to GNU Make.
|
||||||
|
It defaults to the value of the `cores` configuration setting, if set, or `1` otherwise.
|
||||||
|
The value `0` means that the builder should use all available CPU cores in the system.
|
||||||
|
|
||||||
- <span id="opt-repair">[`--repair`](#opt-repair)</span>\
|
- <span id="opt-max-silent-time">[`--max-silent-time`](#opt-max-silent-time)</span>
|
||||||
Fix corrupted or missing store paths by redownloading or rebuilding
|
|
||||||
them. Note that this is slow because it requires computing a
|
Sets the maximum number of seconds that a builder can go without producing any data on standard output or standard error.
|
||||||
cryptographic hash of the contents of every path in the closure of
|
The default is specified by the `max-silent-time` configuration setting.
|
||||||
the build. Also note the warning under `nix-store --repair-path`.
|
`0` means no time-out.
|
||||||
|
|
||||||
|
- <span id="opt-timeout">[`--timeout`](#opt-timeout)</span>
|
||||||
|
|
||||||
|
Sets the maximum number of seconds that a builder can run.
|
||||||
|
The default is specified by the `timeout` configuration setting.
|
||||||
|
`0` means no timeout.
|
||||||
|
|
||||||
|
- <span id="opt-keep-going">[`--keep-going`](#opt-keep-going)</span> / `-k`
|
||||||
|
|
||||||
|
Keep going in case of failed builds, to the greatest extent possible.
|
||||||
|
That is, if building an input of some derivation fails, Nix will still build the other inputs, but not the derivation itself.
|
||||||
|
Without this option, Nix stops if any build fails (except for builds of substitutes), possibly killing builds in progress (in case of parallel or distributed builds).
|
||||||
|
|
||||||
|
- <span id="opt-keep-failed">[`--keep-failed`](#opt-keep-failed)</span> / `-K`
|
||||||
|
|
||||||
|
Specifies that in case of a build failure, the temporary directory (usually in `/tmp`) in which the build takes place should not be deleted.
|
||||||
|
The path of the build directory is printed as an informational message.
|
||||||
|
|
||||||
|
- <span id="opt-fallback">[`--fallback`](#opt-fallback)</span>
|
||||||
|
|
||||||
|
Whenever Nix attempts to build a derivation for which substitutes are known for each output path, but realising the output paths through the substitutes fails, fall back on building the derivation.
|
||||||
|
|
||||||
|
The most common scenario in which this is useful is when we have registered substitutes in order to perform binary distribution from, say, a network repository.
|
||||||
|
If the repository is down, the realisation of the derivation will fail.
|
||||||
|
When this option is specified, Nix will build the derivation instead.
|
||||||
|
Thus, installation from binaries falls back on installation from source.
|
||||||
|
This option is not the default since it is generally not desirable for a transient failure in obtaining the substitutes to lead to a full build from source (with the related consumption of resources).
|
||||||
|
|
||||||
|
- <span id="opt-readonly-mode">[`--readonly-mode`](#opt-readonly-mode)</span>
|
||||||
|
|
||||||
|
When this option is used, no attempt is made to open the Nix database.
|
||||||
|
Most Nix operations do need database access, so those operations will fail.
|
||||||
|
|
||||||
|
- <span id="opt-arg">[`--arg`](#opt-arg)</span> *name* *value*
|
||||||
|
|
||||||
|
This option is accepted by `nix-env`, `nix-instantiate`, `nix-shell` and `nix-build`.
|
||||||
|
When evaluating Nix expressions, the expression evaluator will automatically try to call functions that it encounters.
|
||||||
|
It can automatically call functions for which every argument has a [default value](@docroot@/language/constructs.md#functions) (e.g., `{ argName ? defaultValue }: ...`).
|
||||||
|
|
||||||
|
With `--arg`, you can also call functions that have arguments without a default value (or override a default value).
|
||||||
|
That is, if the evaluator encounters a function with an argument named *name*, it will call it with value *value*.
|
||||||
|
|
||||||
|
For instance, the top-level `default.nix` in Nixpkgs is actually a function:
|
||||||
|
|
||||||
|
```nix
|
||||||
|
{ # The system (e.g., `i686-linux') for which to build the packages.
|
||||||
|
system ? builtins.currentSystem
|
||||||
|
...
|
||||||
|
}: ...
|
||||||
|
```
|
||||||
|
|
||||||
|
So if you call this Nix expression (e.g., when you do `nix-env --install --attr pkgname`), the function will be called automatically using the value [`builtins.currentSystem`](@docroot@/language/builtins.md) for the `system` argument.
|
||||||
|
You can override this using `--arg`, e.g., `nix-env --install --attr pkgname --arg system \"i686-freebsd\"`.
|
||||||
|
(Note that since the argument is a Nix string literal, you have to escape the quotes.)
|
||||||
|
|
||||||
|
- <span id="opt-argstr">[`--argstr`](#opt-argstr)</span> *name* *value*
|
||||||
|
|
||||||
|
This option is like `--arg`, only the value is not a Nix expression but a string.
|
||||||
|
So instead of `--arg system \"i686-linux\"` (the outer quotes are to keep the shell happy) you can say `--argstr system i686-linux`.
|
||||||
|
|
||||||
|
- <span id="opt-attr">[`--attr`](#opt-attr)</span> / `-A` *attrPath*
|
||||||
|
|
||||||
|
Select an attribute from the top-level Nix expression being evaluated.
|
||||||
|
(`nix-env`, `nix-instantiate`, `nix-build` and `nix-shell` only.)
|
||||||
|
The *attribute path* *attrPath* is a sequence of attribute names separated by dots.
|
||||||
|
For instance, given a top-level Nix expression *e*, the attribute path `xorg.xorgserver` would cause the expression `e.xorg.xorgserver` to be used.
|
||||||
|
See [`nix-env --install`](@docroot@/command-ref/nix-env/install.md) for some concrete examples.
|
||||||
|
|
||||||
|
In addition to attribute names, you can also specify array indices.
|
||||||
|
For instance, the attribute path `foo.3.bar` selects the `bar`
|
||||||
|
attribute of the fourth element of the array in the `foo` attribute
|
||||||
|
of the top-level expression.
|
||||||
|
|
||||||
|
- <span id="opt-expr">[`--expr`](#opt-expr)</span> / `-E`
|
||||||
|
|
||||||
|
Interpret the command line arguments as a list of Nix expressions to be parsed and evaluated, rather than as a list of file names of Nix expressions.
|
||||||
|
(`nix-instantiate`, `nix-build` and `nix-shell` only.)
|
||||||
|
|
||||||
|
For `nix-shell`, this option is commonly used to give you a shell in which you can build the packages returned by the expression.
|
||||||
|
If you want to get a shell which contain the *built* packages ready for use, give your expression to the `nix-shell --packages ` convenience flag instead.
|
||||||
|
|
||||||
|
- <span id="opt-I">[`-I`](#opt-I)</span> *path*
|
||||||
|
|
||||||
|
Add an entry to the [Nix expression search path](@docroot@/command-ref/conf-file.md#conf-nix-path).
|
||||||
|
This option may be given multiple times.
|
||||||
|
Paths added through `-I` take precedence over [`NIX_PATH`](@docroot@/command-ref/env-common.md#env-NIX_PATH).
|
||||||
|
|
||||||
|
- <span id="opt-option">[`--option`](#opt-option)</span> *name* *value*
|
||||||
|
|
||||||
|
Set the Nix configuration option *name* to *value*.
|
||||||
|
This overrides settings in the Nix configuration file (see nix.conf5).
|
||||||
|
|
||||||
|
- <span id="opt-repair">[`--repair`](#opt-repair)</span>
|
||||||
|
|
||||||
|
Fix corrupted or missing store paths by redownloading or rebuilding them.
|
||||||
|
Note that this is slow because it requires computing a cryptographic hash of the contents of every path in the closure of the build.
|
||||||
|
Also note the warning under `nix-store --repair-path`.
|
||||||
|
|
Loading…
Reference in a new issue