diff options
author | Johan Herland <johan@herland.net> | 2022-10-19 11:50:58 +0200 |
---|---|---|
committer | Johan Herland <johan@herland.net> | 2022-10-19 11:50:58 +0200 |
commit | 1ec8810687859e0af96d844da67ab6c6d6e69f9d (patch) | |
tree | 1aff181c070e74883beaa622e1adc6c10e7094ca /doc | |
parent | 95331cb9c99151cbd790ceb6ddaf49fc1c0da4b3 (diff) |
Explain how Nix handles antiquotation of paths
Specifically, explain why Nix does not _re_evaluate paths during a
`nix repl` session. This is a thing that bit me while playing around
with paths and antiquotation in `nix repl` while reading the Nix
language tutorial at https://nix.dev/tutorials/nix-language.
Co-authored-by: Valentin Gagarin <valentin.gagarin@tweag.io>
Diffstat (limited to 'doc')
-rw-r--r-- | doc/manual/src/language/values.md | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/doc/manual/src/language/values.md b/doc/manual/src/language/values.md index f09400d02..6fc8c0369 100644 --- a/doc/manual/src/language/values.md +++ b/doc/manual/src/language/values.md @@ -150,6 +150,20 @@ recognized as a path. `a.${foo}/b.${bar}` is a syntactically valid division operation. `./a.${foo}/b.${bar}` is a path. + When a path appears in an antiquotation, and is thus coerced into a string, + the path is first copied into the Nix store and the resulting string is + the Nix store path. For instance `"${./foo.txt}" will cause `foo.txt` in + the current directory to be copied into the Nix store and result in the + string `"/nix/store/<HASH>-foo.txt"`. + + Note that the Nix language assumes that all input files will remain + _unchanged_ during the course of the Nix expression evaluation. + If you for example antiquote a file path during a `nix repl` session, and + then later in the same session, after having changed the file contents, + evaluate the antiquotation with the file path again, then Nix will still + return the first store path. It will _not_ reread the file contents to + produce a different Nix store path. + - <a id="type-boolean" href="#type-boolean">Boolean</a> *Booleans* with values `true` and `false`. |