nix-lib documentation
default.nix
fuseAttrs
Type: [attrs] -> attrs
Fuses a list of attribute sets into a single attribute set.
fuseAttrs
usage example
x = [ { a = 1; } { b = 2; } ]
fuseAttrs x
=> { a = 1; b = 2; }
mapFuse
Type: ('a -> attrs) -> ['a] -> attrs
Applies a function to attrsList
before fusing the resulting list
of attribute sets.
f
: 'a -> attrs
attrsList
: ['a]
mapFuse
usage example
x = [ "to" "ta" "ti" ]
f = s: { ${s} = s + s; }
mapFuse f x
=> { to = "toto"; ta = "tata"; ti = "titi"; }
singleAttr
Type: str -> 'a -> attrs
Equivalent of lib.singleton but for an attribute set.
name
: Function argument
value
: Function argument
singleAttr
usage example
singleAttr "a" 1
=> { a = 1; }
mapSingleFuse
Create an attribute set from a list of values, mapping those
values through the function f
.
f
: Function argument
mapSingleFuse
usage example
mapSingleFuse (x: "val-${x}") [ "a" "b" ]
=> { a = "val-a"; b = "val-b" }
mkRel
Type: path -> str -> path
Creates a relative path as a string
path
: Function argument
file
: Function argument
mkRel
usage example
mkRel /home/test/ "file.txt"
=> "/home/test/file.txt"
recursiveFuse
Type: [attrs] -> attrs
Same as fuseAttrs but using lib.recursiveUpdate
to merge attribute
sets together.
mkConfig
Creates a confugiration by merging enabled modules,
services and extraConfig.
structured function argument
: enabledModules
: List of modules to enable with enableModules
enabledServices
: List of services to import
extraConfig
: Extra configuration, defaults to { }
root
: Path relative to which the enabled services will be imported
mkConfig
usage example
mkConfig {
enabledModules = [ "ht-defaults" ];
enabledServices = [ "toto" ];
extraConfig = { services.nginx.enable = true; };
root = ./.;
}
=>
{
imports = [ ./toto ];
ht-defaults.enable = true;
services.nginx.enable = true;
}
callFunctionWith
Call the function in the file fn
with the required
arguments automatically. The function is called with the
arguments args
, but any missing arguments are obtained from
autoArgs
.
autoArgs
: Function argument
fn
: Function argument
nixpkgs.nix
recursiveUpdateUntil
Does the same as the update operator '//' except that attributes are
merged until the given predicate is verified. The predicate should
accept 3 arguments which are the path to reach the attribute, a part of
the first attribute set and a part of the second attribute set. When
the predicate is satisfied, the value of the first attribute set is
replaced by the value of the second attribute set.
Inputs
pred
: Predicate, taking the path to the current attribute as a list of strings for attribute names, and the two values at that path from the original arguments.
lhs
: Left attribute set of the merge.
rhs
: Right attribute set of the merge.
Type
recursiveUpdateUntil :: ( [ String ] -> AttrSet -> AttrSet -> Bool ) -> AttrSet -> AttrSet -> AttrSet
Examples
:::
lib.attrsets.recursiveUpdateUntil
usage example
recursiveUpdateUntil (path: l: r: path == ["foo"]) {
# first attribute set
foo.bar = 1;
foo.baz = 2;
bar = 3;
} {
#second attribute set
foo.bar = 1;
foo.quz = 2;
baz = 4;
}
=> {
foo.bar = 1; # 'foo.*' from the second set
foo.quz = 2; #
bar = 3; # 'bar' from the first set
baz = 4; # 'baz' from the second set
}
:::
pred
: Function argument
lhs
: Function argument
rhs
: Function argument
recursiveUpdate
A recursive variant of the update operator ‘//’. The recursion
stops when one of the attribute values is not an attribute set,
in which case the right hand side value takes precedence over the
left hand side value.
Inputs
lhs
: Left attribute set of the merge.
rhs
: Right attribute set of the merge.
Type
recursiveUpdate :: AttrSet -> AttrSet -> AttrSet
Examples
:::
lib.attrsets.recursiveUpdate
usage example
recursiveUpdate {
boot.loader.grub.enable = true;
boot.loader.grub.device = "/dev/hda";
} {
boot.loader.grub.device = "";
}
returns: {
boot.loader.grub.enable = true;
boot.loader.grub.device = "";
}
:::
lhs
: Function argument
rhs
: Function argument
hasPrefix
Determine whether a string has given prefix.
Inputs
pref
: Prefix to check for
str
: Input string
Type
hasPrefix :: string -> string -> bool
Examples
:::
lib.strings.hasPrefix
usage example
hasPrefix "foo" "foobar"
=> true
hasPrefix "foo" "barfoo"
=> false
:::
pref
: Function argument
str
: Function argument
escape
Escape occurrence of the elements of list
in string
by
prefixing it with a backslash.
Inputs
list
: 1. Function argument
string
: 2. Function argument
Type
escape :: [string] -> string -> string
Examples
:::
lib.strings.escape
usage example
escape ["(" ")"] "(foo)"
=> "\\(foo\\)"
:::
list
: Function argument
stringToCharacters
Convert a string s
to a list of characters (i.e. singleton strings).
This allows you to, e.g., map a function over each character. However,
note that this will likely be horribly inefficient; Nix is not a
general purpose programming language. Complex string manipulations
should, if appropriate, be done in a derivation.
Also note that Nix treats strings as a list of bytes and thus doesn't
handle unicode.
Inputs
s
: 1. Function argument
Type
stringToCharacters :: string -> [string]
Examples
:::
lib.strings.stringToCharacters
usage example
stringToCharacters ""
=> [ ]
stringToCharacters "abc"
=> [ "a" "b" "c" ]
stringToCharacters "🦄"
=> [ "<EFBFBD>" "<EFBFBD>" "<EFBFBD>" "<EFBFBD>" ]
:::
s
: Function argument
escapeRegex
Turn a string s
into an exact regular expression
Inputs
s
: 1. Function argument
Type
escapeRegex :: string -> string
Examples
:::
lib.strings.escapeRegex
usage example
escapeRegex "[^a-z]*"
=> "\\[\\^a-z]\\*"
:::
addContextFrom
Appends string context from string like object src
to target
.
:::{.warning}
This is an implementation
detail of Nix and should be used carefully.
:::
Strings in Nix carry an invisible context
which is a list of strings
representing store paths. If the string is later used in a derivation
attribute, the derivation will properly populate the inputDrvs and
inputSrcs.
Inputs
src
: The string to take the context from. If the argument is not a string,
it will be implicitly converted to a string.
target
: The string to append the context to. If the argument is not a string,
it will be implicitly converted to a string.
Type
addContextFrom :: string -> string -> string
Examples
:::
lib.strings.addContextFrom
usage example
pkgs = import <nixpkgs> { };
addContextFrom pkgs.coreutils "bar"
=> "bar"
The context can be displayed using the toString
function:
nix-repl> builtins.getContext (lib.strings.addContextFrom pkgs.coreutils "bar")
{
"/nix/store/m1s1d2dk2dqqlw3j90jl3cjy2cykbdxz-coreutils-9.5.drv" = { ... };
}
:::
src
: Function argument
target
: Function argument
splitString
Cut a string with a separator and produces a list of strings which
were separated by this separator.
Inputs
sep
: 1. Function argument
s
: 2. Function argument
Type
splitString :: string -> string -> [string]
Examples
:::
lib.strings.splitString
usage example
splitString "." "foo.bar.baz"
=> [ "foo" "bar" "baz" ]
splitString "/" "/usr/local/bin"
=> [ "" "usr" "local" "bin" ]
:::
sep
: Function argument
s
: Function argument
unique
Remove duplicate elements from the list
. O(n^2) complexity.
Inputs
list
: Input list
Type
unique :: [a] -> [a]
Examples
:::
lib.lists.unique
usage example
unique [ 3 2 3 4 ]
=> [ 3 2 4 ]
:::
flip
Flip the order of the arguments of a binary function.
Inputs
f
: 1. Function argument
a
: 2. Function argument
b
: 3. Function argument
Type
flip :: (a -> b -> c) -> (b -> a -> c)
Examples
:::
lib.trivial.flip
usage example
flip concat [1] [2]
=> [ 2 1 ]
:::
f
: Function argument
a
: Function argument
b
: Function argument