From cc3f54a0eedb579c2ffd76f0505af0ccf940f9ff Mon Sep 17 00:00:00 2001 From: Profpatsch Date: Sat, 23 Jan 2021 16:17:01 +0100 Subject: feat(users/Profpatsch/netstring): add rust to_netstring Change-Id: I539472fc9ebc3ebe6c34e01fde9c08d3e2e3558c Reviewed-on: https://cl.tvl.fyi/c/depot/+/2431 Reviewed-by: Profpatsch Tested-by: BuildkiteCI --- users/Profpatsch/netstring/default.nix | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'users/Profpatsch/netstring/default.nix') diff --git a/users/Profpatsch/netstring/default.nix b/users/Profpatsch/netstring/default.nix index 35345978a318..3cf882d5a279 100644 --- a/users/Profpatsch/netstring/default.nix +++ b/users/Profpatsch/netstring/default.nix @@ -36,12 +36,29 @@ let return res ''; + rust-netstring = depot.users.Profpatsch.writers.rustSimpleLib { + name = "netstring"; + } '' + pub fn to_netstring(s: &[u8]) -> Vec { + 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 + } + ''; + tests = import ./tests.nix { inherit depot pkgs lib python-netstring + rust-netstring toNetstring toNetstringKeyVal ; @@ -52,6 +69,7 @@ in { toNetstring toNetstringKeyVal python-netstring + rust-netstring tests ; -- cgit 1.4.1