forked from lix-project/lix
Add 'nix repl' manpage
This commit is contained in:
parent
b2262be19b
commit
6ce393392b
2 changed files with 62 additions and 7 deletions
|
@ -405,6 +405,7 @@ bool NixRepl::processLine(string line)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (command == ":?" || command == ":help") {
|
if (command == ":?" || command == ":help") {
|
||||||
|
// FIXME: convert to Markdown, include in the 'nix repl' manpage.
|
||||||
std::cout
|
std::cout
|
||||||
<< "The following commands are available:\n"
|
<< "The following commands are available:\n"
|
||||||
<< "\n"
|
<< "\n"
|
||||||
|
@ -801,14 +802,11 @@ struct CmdRepl : StoreCommand, MixEvalArgs
|
||||||
return "start an interactive environment for evaluating Nix expressions";
|
return "start an interactive environment for evaluating Nix expressions";
|
||||||
}
|
}
|
||||||
|
|
||||||
Examples examples() override
|
std::string doc() override
|
||||||
{
|
{
|
||||||
return {
|
return
|
||||||
Example{
|
#include "repl.md"
|
||||||
"Display all special commands within the REPL:",
|
;
|
||||||
"nix repl\nnix-repl> :?"
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void run(ref<Store> store) override
|
void run(ref<Store> store) override
|
||||||
|
|
57
src/nix/repl.md
Normal file
57
src/nix/repl.md
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
R""(
|
||||||
|
|
||||||
|
# Examples
|
||||||
|
|
||||||
|
* Display all special commands within the REPL:
|
||||||
|
|
||||||
|
```console
|
||||||
|
# nix repl
|
||||||
|
nix-repl> :?
|
||||||
|
```
|
||||||
|
|
||||||
|
* Evaluate some simple Nix expressions:
|
||||||
|
|
||||||
|
```console
|
||||||
|
# nix repl
|
||||||
|
|
||||||
|
nix-repl> 1 + 2
|
||||||
|
3
|
||||||
|
|
||||||
|
nix-repl> map (x: x * 2) [1 2 3]
|
||||||
|
[ 2 4 6 ]
|
||||||
|
```
|
||||||
|
|
||||||
|
* Interact with Nixpkgs in the REPL:
|
||||||
|
|
||||||
|
```console
|
||||||
|
# nix repl '<nixpkgs>'
|
||||||
|
|
||||||
|
Loading '<nixpkgs>'...
|
||||||
|
Added 12428 variables.
|
||||||
|
|
||||||
|
nix-repl> emacs.name
|
||||||
|
"emacs-27.1"
|
||||||
|
|
||||||
|
nix-repl> emacs.drvPath
|
||||||
|
"/nix/store/lp0sjrhgg03y2n0l10n70rg0k7hhyz0l-emacs-27.1.drv"
|
||||||
|
|
||||||
|
nix-repl> drv = runCommand "hello" { buildInputs = [ hello ]; } "hello > $out"
|
||||||
|
|
||||||
|
nix-repl> :b x
|
||||||
|
this derivation produced the following outputs:
|
||||||
|
out -> /nix/store/0njwbgwmkwls0w5dv9mpc1pq5fj39q0l-hello
|
||||||
|
|
||||||
|
nix-repl> builtins.readFile drv
|
||||||
|
"Hello, world!\n"
|
||||||
|
```
|
||||||
|
|
||||||
|
# Description
|
||||||
|
|
||||||
|
This command provides an interactive environment for evaluating Nix
|
||||||
|
expressions. (REPL stands for 'read–eval–print loop'.)
|
||||||
|
|
||||||
|
On startup, it loads the Nix expressions named *files* and adds them
|
||||||
|
into the lexical scope. You can load addition files using the `:l
|
||||||
|
<filename>` command, or reload all files using `:r`.
|
||||||
|
|
||||||
|
)""
|
Loading…
Reference in a new issue