diff options
author | makefu <github@syntax-fehler.de> | 2015-07-26 18:11:09 +0200 |
---|---|---|
committer | makefu <github@syntax-fehler.de> | 2015-07-26 18:11:09 +0200 |
commit | c021118096479ed15c32d40e7f5f7fc64e81bad1 (patch) | |
tree | ca56bf04a16baa0e71c7299092b8f29fcad93b42 /4lib | |
parent | 784929d0015547f2a314651ac67f095aee16c6ca (diff) | |
parent | 9195e3101718fa255976b18d1513eeda08fee2de (diff) |
Merge remote-tracking branch 'cd/master'
Diffstat (limited to '4lib')
-rw-r--r-- | 4lib/krebs/default.nix | 18 | ||||
-rw-r--r-- | 4lib/krebs/types.nix | 3 |
2 files changed, 21 insertions, 0 deletions
diff --git a/4lib/krebs/default.nix b/4lib/krebs/default.nix index 0c59076..0c42a5d 100644 --- a/4lib/krebs/default.nix +++ b/4lib/krebs/default.nix @@ -12,4 +12,22 @@ builtins // lib // rec { types = import ./types.nix { inherit lib; }; + + # listset k v = set k [v] + + # listset-insert : k -> v -> listset k v -> listset k v + listset-insert = name: value: set: + set // { ${name} = set.${name} or [] ++ [value]; }; + + # tree k v = set k (either v (tree k v)) + + # tree-get : [k] -> tree k v -> v + tree-get = path: x: + let + y = x.${last path}; + in + if typeOf y != "set" + then y + else tree-get (init path) y; + } diff --git a/4lib/krebs/types.nix b/4lib/krebs/types.nix index ca92c69..3d3d75a 100644 --- a/4lib/krebs/types.nix +++ b/4lib/krebs/types.nix @@ -83,6 +83,9 @@ types // rec { user = submodule { options = { + mail = mkOption { + type = str; # TODO retiolum mail address + }; name = mkOption { type = str; # TODO }; |