tvl-depot/users/Profpatsch/netstring/default.nix
Profpatsch 7e888c3c7b feat(nix): add basic netstring nix generation functions
Moving to toplevel so I can use them with `runExecline`. They should
be pretty atomic, and are proven to work (tests are still in my user
dir, since they test the producers indirectly via the python parser
and I don’t want to pull it out right now).

Change-Id: Id0baa3adcb2ec646458a104c7868c2889b8c64f5
Reviewed-on: https://cl.tvl.fyi/c/depot/+/3054
Reviewed-by: Profpatsch <mail@profpatsch.de>
Tested-by: BuildkiteCI
2021-04-24 09:54:34 +00:00

51 lines
1.4 KiB
Nix

{ lib, pkgs, depot, ... }:
let
python-netstring = depot.users.Profpatsch.writers.python3Lib {
name = "netstring";
} ''
def read_netstring(bytes):
(int_length, rest) = bytes.split(sep=b':', maxsplit=1)
val = rest[:int(int_length)]
# has to end on a ,
assert(rest[len(val)] == ord(','))
return (val, rest[len(val) + 1:])
def read_netstring_key_val(bytes):
(keyvalnet, rest) = read_netstring(bytes)
(key, valnet) = read_netstring(keyvalnet)
(val, nothing) = read_netstring(valnet)
assert(nothing == b"")
return (key, val, rest)
def read_netstring_key_val_list(bytes):
rest = bytes
res = {}
while rest != b"":
(key, val, r) = read_netstring_key_val(rest)
rest = r
res[key] = val
return res
'';
rust-netstring = depot.users.Profpatsch.writers.rustSimpleLib {
name = "netstring";
} ''
pub fn to_netstring(s: &[u8]) -> Vec<u8> {
let len = s.len();
// length of the integer as ascii
let i_len = ((len as f64).log10() as usize) + 1;
let ns_len = i_len + 1 + len + 1;
let mut res = Vec::with_capacity(ns_len);
res.extend_from_slice(format!("{}:", len).as_bytes());
res.extend_from_slice(s);
res.push(b',');
res
}
'';
in depot.nix.utils.drvTargets {
inherit
python-netstring
rust-netstring
;
}