about summary refs log tree commit diff
path: root/users/Profpatsch/netencode/gen.nix
blob: efc9629ca0dfd79c338c0f49a4433bea4a9b3cc3 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
{ lib }:
let

  netstring = tag: suffix: s:
    "${tag}${toString (builtins.stringLength s)}:${s}${suffix}";

  unit = "u,";

  n1 = b: if b then "n1:1," else "n1:0,";

  n = i: n: "n${toString i}:${toString n},";
  i = i: n: "i${toString i}:${toString n},";

  n3 = n 3;
  n6 = n 6;
  n7 = n 7;

  i3 = i 3;
  i6 = i 6;
  i7 = i 7;

  text = netstring "t" ",";
  binary = netstring "b" ",";

  tag = key: val: netstring "<" "|" key + val;

  concatStrings = builtins.concatStringsSep "";

  record = lokv: netstring "{" "}"
    (concatStrings (map ({ key, val }: tag key val) lokv));

  list = l: netstring "[" "]" (concatStrings l);

  dwim = val:
    let
      match = {
        "bool" = n1;
        "int" = i6;
        "string" = text;
        "set" = attrs:
          # it could be a derivation, then just return the path
          if attrs.type or "" == "derivation" then text "${attrs}"
          else
            record (lib.mapAttrsToList
              (k: v: {
                key = k;
                val = dwim v;
              })
              attrs);
        "list" = l: list (map dwim l);
      };
    in
    match.${builtins.typeOf val} val;

in
{
  inherit
    unit
    n1
    n3
    n6
    n7
    i3
    i6
    i7
    text
    binary
    tag
    record
    list
    dwim
    ;
}