diff options
author | lassulus <lass@aidsballs.de> | 2016-08-02 20:41:47 +0200 |
---|---|---|
committer | lassulus <lass@aidsballs.de> | 2016-08-02 20:41:47 +0200 |
commit | 2a263f14abf8baff0cc686b1dd11a349da87f067 (patch) | |
tree | cdc5a429dcaa92b8d5536642d58c4b1a2835e83d /lib | |
parent | 127b8c0989f1dc71313af67fb5e69c709df019f3 (diff) | |
parent | 0928cc03a6191640c66c9122159994855527faef (diff) |
Merge remote-tracking branch 'cd/master'
Diffstat (limited to 'lib')
-rw-r--r-- | lib/default.nix | 7 | ||||
-rw-r--r-- | lib/shell.nix | 21 |
2 files changed, 28 insertions, 0 deletions
diff --git a/lib/default.nix b/lib/default.nix new file mode 100644 index 000000000..6c607f13b --- /dev/null +++ b/lib/default.nix @@ -0,0 +1,7 @@ +let + lib = import <nixpkgs/lib> // builtins // { + shell = import ./shell.nix { inherit lib; }; + }; +in + +lib diff --git a/lib/shell.nix b/lib/shell.nix new file mode 100644 index 000000000..a8ff5dbe0 --- /dev/null +++ b/lib/shell.nix @@ -0,0 +1,21 @@ +{ lib, ... }: + +with lib; + +rec { + escape = + let + isSafeChar = c: match "[-+./0-9:=A-Z_a-z]" c != null; + in + stringAsChars (c: + if isSafeChar c then c + else if c == "\n" then "'\n'" + else "\\${c}"); + + # + # shell script generators + # + + # example: "${cat (toJSON { foo = "bar"; })} | jq -r .foo" + cat = s: "printf '%s' ${escape s}"; +} |