aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAkshay <[email protected]>2021-04-18 10:50:13 +0100
committerAkshay <[email protected]>2021-04-18 10:50:13 +0100
commit869fe69fdf947230ca4129d3d1f9749360035e64 (patch)
treed6bdbd525fa16b1b5260ab1d47aef4eda85a6931
parent7d2924015e691fa229c6b6fd96240ef47b3a9e5f (diff)
add RLE compression functions
l---------.direnv/flake-profile2
-rw-r--r--.direnv/flake-profile.rc20
-rw-r--r--src/decode.rs69
-rw-r--r--src/encode.rs44
-rw-r--r--src/lib.rs16
-rw-r--r--src/rle.rs89
-rw-r--r--tests/serde.rs22
7 files changed, 224 insertions, 38 deletions
diff --git a/.direnv/flake-profile b/.direnv/flake-profile
index 624f00f..0e6e742 120000
--- a/.direnv/flake-profile
+++ b/.direnv/flake-profile
@@ -1 +1 @@
/nix/store/hk8227smba1l2lrk4np5fqy2hkb0jaf3-nix-shell-env \ No newline at end of file /nix/store/q3bk2x9q1g2xnah8j9l9xpl2037ks0xv-nix-shell-env \ No newline at end of file
diff --git a/.direnv/flake-profile.rc b/.direnv/flake-profile.rc
index 49f03d2..3796858 100644
--- a/.direnv/flake-profile.rc
+++ b/.direnv/flake-profile.rc
@@ -32,7 +32,7 @@ NIX_CC=/nix/store/i9a3zzf2spmw67jppvkj2yavnbka62id-gcc-wrapper-10.2.0
32export NIX_CC 32export NIX_CC
33NIX_CC_WRAPPER_TARGET_HOST_x86_64_unknown_linux_gnu=1 33NIX_CC_WRAPPER_TARGET_HOST_x86_64_unknown_linux_gnu=1
34export NIX_CC_WRAPPER_TARGET_HOST_x86_64_unknown_linux_gnu 34export NIX_CC_WRAPPER_TARGET_HOST_x86_64_unknown_linux_gnu
35NIX_CFLAGS_COMPILE=' -frandom-seed=hk8227smba -isystem /nix/store/91ym2jzh08470r4jb1d5pmh22vg2bpck-openssl-1.1.1i-dev/include -isystem /nix/store/saiwalr8jq58mbyipkn824r93gjjnw5x-ncurses-6.2-dev/include -isystem /nix/store/91ym2jzh08470r4jb1d5pmh22vg2bpck-openssl-1.1.1i-dev/include -isystem /nix/store/saiwalr8jq58mbyipkn824r93gjjnw5x-ncurses-6.2-dev/include' 35NIX_CFLAGS_COMPILE=' -frandom-seed=q3bk2x9q1g'
36export NIX_CFLAGS_COMPILE 36export NIX_CFLAGS_COMPILE
37NIX_ENFORCE_NO_NATIVE=1 37NIX_ENFORCE_NO_NATIVE=1
38export NIX_ENFORCE_NO_NATIVE 38export NIX_ENFORCE_NO_NATIVE
@@ -40,7 +40,7 @@ NIX_HARDENING_ENABLE='fortify stackprotector pic strictoverflow format relro bin
40export NIX_HARDENING_ENABLE 40export NIX_HARDENING_ENABLE
41NIX_INDENT_MAKE=1 41NIX_INDENT_MAKE=1
42export NIX_INDENT_MAKE 42export NIX_INDENT_MAKE
43NIX_LDFLAGS='-rpath /home/np/code/rust/obi/outputs/out/lib64 -rpath /home/np/code/rust/obi/outputs/out/lib -L/nix/store/ni0nxz7jnd3scrfqsdr6cragl95fqmyb-rust-1.50.0-nightly-2020-12-22-bb1fbbf84/lib -L/nix/store/kchm26396krqwdn2dkx6l0hb79lwlhr1-openssl-1.1.1i/lib -L/nix/store/d3nz4c5xf1bqz8rwr8m4gbsrny9ffidk-ncurses-6.2/lib -L/nix/store/ni0nxz7jnd3scrfqsdr6cragl95fqmyb-rust-1.50.0-nightly-2020-12-22-bb1fbbf84/lib -L/nix/store/kchm26396krqwdn2dkx6l0hb79lwlhr1-openssl-1.1.1i/lib -L/nix/store/d3nz4c5xf1bqz8rwr8m4gbsrny9ffidk-ncurses-6.2/lib' 43NIX_LDFLAGS='-rpath /home/np/code/rust/obi/outputs/out/lib64 -rpath /home/np/code/rust/obi/outputs/out/lib -L/nix/store/58syiz9158g5s53gjh8f5b89bhhp1m0s-rust-1.53.0-nightly-2021-03-30-74874a690/lib -L/nix/store/58syiz9158g5s53gjh8f5b89bhhp1m0s-rust-1.53.0-nightly-2021-03-30-74874a690/lib'
44export NIX_LDFLAGS 44export NIX_LDFLAGS
45NIX_LIB64_IN_SELF_RPATH=1 45NIX_LIB64_IN_SELF_RPATH=1
46NIX_NO_SELF_RPATH=1 46NIX_NO_SELF_RPATH=1
@@ -55,7 +55,7 @@ export OBJDUMP
55OPTERR=1 55OPTERR=1
56OPTIND=1 56OPTIND=1
57OSTYPE=linux-gnu 57OSTYPE=linux-gnu
58PATH=/nix/store/ni0nxz7jnd3scrfqsdr6cragl95fqmyb-rust-1.50.0-nightly-2020-12-22-bb1fbbf84/bin:/nix/store/pj3m562kh9lr7wjk3hlyandhd1qpapgh-rust-analyzer-unstable-2021-02-22/bin:/nix/store/9p0yf4yzsc8by6xviags56c3mb3fxkkw-cargo-1.49.0/bin:/nix/store/71707dbkha4mryph7ywp48wi2r1sc0hf-openssl-1.1.1i-bin/bin:/nix/store/saiwalr8jq58mbyipkn824r93gjjnw5x-ncurses-6.2-dev/bin:/nix/store/d3nz4c5xf1bqz8rwr8m4gbsrny9ffidk-ncurses-6.2/bin:/nix/store/d7lyvmvzf1a8qqhsxhdc3r6dwbdmfcap-patchelf-0.12/bin:/nix/store/i9a3zzf2spmw67jppvkj2yavnbka62id-gcc-wrapper-10.2.0/bin:/nix/store/wxri3dc14yd1w997vjfvsnn6qml64l4r-gcc-10.2.0/bin:/nix/store/fr2k1vwmyd5ngmb3y0v090nh21nn6gqp-glibc-2.32-35-bin/bin:/nix/store/ypsd29c5hgj1x7xz5ddffanxw5d8fh7b-coreutils-8.32/bin:/nix/store/f4w8p656gg6v2k1v0whwmyk09kz3k8ic-binutils-wrapper-2.35.1/bin:/nix/store/9f8y44vmjnwdjvzlff0gm3f3g6ycyyqy-binutils-2.35.1/bin:/nix/store/fr2k1vwmyd5ngmb3y0v090nh21nn6gqp-glibc-2.32-35-bin/bin:/nix/store/ypsd29c5hgj1x7xz5ddffanxw5d8fh7b-coreutils-8.32/bin:/nix/store/ypsd29c5hgj1x7xz5ddffanxw5d8fh7b-coreutils-8.32/bin:/nix/store/nq9l23mrm8irvl9qvxgvxqqkm5sfnc9d-findutils-4.7.0/bin:/nix/store/7yq29nnglh2s576n7vdmzqryym22f8rj-diffutils-3.7/bin:/nix/store/0839nqri8w69c91amlsq9bawaqlzpmh9-gnused-4.8/bin:/nix/store/wmiyjdsaydyv024al5ddqd3liljrfvk7-gnugrep-3.6/bin:/nix/store/snmar11l5w9jrxva2s5d6143nqmdgzqb-gawk-5.1.0/bin:/nix/store/cisss0pcfh72kmnsv4qa6h41wcwb9mkv-gnutar-1.32/bin:/nix/store/prdifiyrxwgf6sp4rwmrqvfdnvf72gw2-gzip-1.10/bin:/nix/store/pp9shwhcdxxbhgp96fcaj0g8x5g54zrl-bzip2-1.0.6.0.1-bin/bin:/nix/store/fydw5vhlhpq438cxv4vwpa8pf8p8fv5s-gnumake-4.3/bin:/nix/store/yyy7wr7r9jwjjqkr1yn643g3wzv010zd-bash-4.4-p23/bin:/nix/store/qcw3qagp709qwfza259zqss5qh4wg789-patch-2.7.6/bin:/nix/store/q0jqhjabwaaak30l4sq3z0xi6jrkpnbn-xz-5.2.5-bin/bin 58PATH=/nix/store/58syiz9158g5s53gjh8f5b89bhhp1m0s-rust-1.53.0-nightly-2021-03-30-74874a690/bin:/nix/store/pj3m562kh9lr7wjk3hlyandhd1qpapgh-rust-analyzer-unstable-2021-02-22/bin:/nix/store/rfx0jz6pr3n2dcxm99finhbp99v45qx4-rustfmt-1.49.0/bin:/nix/store/9p0yf4yzsc8by6xviags56c3mb3fxkkw-cargo-1.49.0/bin:/nix/store/d7lyvmvzf1a8qqhsxhdc3r6dwbdmfcap-patchelf-0.12/bin:/nix/store/i9a3zzf2spmw67jppvkj2yavnbka62id-gcc-wrapper-10.2.0/bin:/nix/store/wxri3dc14yd1w997vjfvsnn6qml64l4r-gcc-10.2.0/bin:/nix/store/fr2k1vwmyd5ngmb3y0v090nh21nn6gqp-glibc-2.32-35-bin/bin:/nix/store/ypsd29c5hgj1x7xz5ddffanxw5d8fh7b-coreutils-8.32/bin:/nix/store/f4w8p656gg6v2k1v0whwmyk09kz3k8ic-binutils-wrapper-2.35.1/bin:/nix/store/9f8y44vmjnwdjvzlff0gm3f3g6ycyyqy-binutils-2.35.1/bin:/nix/store/fr2k1vwmyd5ngmb3y0v090nh21nn6gqp-glibc-2.32-35-bin/bin:/nix/store/ypsd29c5hgj1x7xz5ddffanxw5d8fh7b-coreutils-8.32/bin:/nix/store/ypsd29c5hgj1x7xz5ddffanxw5d8fh7b-coreutils-8.32/bin:/nix/store/nq9l23mrm8irvl9qvxgvxqqkm5sfnc9d-findutils-4.7.0/bin:/nix/store/7yq29nnglh2s576n7vdmzqryym22f8rj-diffutils-3.7/bin:/nix/store/0839nqri8w69c91amlsq9bawaqlzpmh9-gnused-4.8/bin:/nix/store/wmiyjdsaydyv024al5ddqd3liljrfvk7-gnugrep-3.6/bin:/nix/store/snmar11l5w9jrxva2s5d6143nqmdgzqb-gawk-5.1.0/bin:/nix/store/cisss0pcfh72kmnsv4qa6h41wcwb9mkv-gnutar-1.32/bin:/nix/store/prdifiyrxwgf6sp4rwmrqvfdnvf72gw2-gzip-1.10/bin:/nix/store/pp9shwhcdxxbhgp96fcaj0g8x5g54zrl-bzip2-1.0.6.0.1-bin/bin:/nix/store/fydw5vhlhpq438cxv4vwpa8pf8p8fv5s-gnumake-4.3/bin:/nix/store/yyy7wr7r9jwjjqkr1yn643g3wzv010zd-bash-4.4-p23/bin:/nix/store/qcw3qagp709qwfza259zqss5qh4wg789-patch-2.7.6/bin:/nix/store/q0jqhjabwaaak30l4sq3z0xi6jrkpnbn-xz-5.2.5-bin/bin
59export PATH 59export PATH
60PIPESTATUS=([0]="0") 60PIPESTATUS=([0]="0")
61PS4='+ ' 61PS4='+ '
@@ -63,7 +63,11 @@ RANLIB=ranlib
63export RANLIB 63export RANLIB
64READELF=readelf 64READELF=readelf
65export READELF 65export READELF
66RUST_SRC_PATH=/nix/store/ncxadjgpdacbf69yhpgwvwnqhmh5yk96-rust-lib-src 66RUST_BACKTRACE=1
67export RUST_BACKTRACE
68RUST_LOG=info
69export RUST_LOG
70RUST_SRC_PATH=/nix/store/m0k4il8v2wv0c7nniqndcxh72qmzvvg2-rust-src-1.53.0-nightly-2021-03-30-74874a690/lib/rustlib/src/rust/library
67export RUST_SRC_PATH 71export RUST_SRC_PATH
68SHELL=/nix/store/yyy7wr7r9jwjjqkr1yn643g3wzv010zd-bash-4.4-p23/bin/bash 72SHELL=/nix/store/yyy7wr7r9jwjjqkr1yn643g3wzv010zd-bash-4.4-p23/bin/bash
69export SHELL 73export SHELL
@@ -75,7 +79,7 @@ STRINGS=strings
75export STRINGS 79export STRINGS
76STRIP=strip 80STRIP=strip
77export STRIP 81export STRIP
78XDG_DATA_DIRS=/nix/store/ni0nxz7jnd3scrfqsdr6cragl95fqmyb-rust-1.50.0-nightly-2020-12-22-bb1fbbf84/share:/nix/store/9p0yf4yzsc8by6xviags56c3mb3fxkkw-cargo-1.49.0/share:/nix/store/d3nz4c5xf1bqz8rwr8m4gbsrny9ffidk-ncurses-6.2/share:/nix/store/d7lyvmvzf1a8qqhsxhdc3r6dwbdmfcap-patchelf-0.12/share 82XDG_DATA_DIRS=/nix/store/58syiz9158g5s53gjh8f5b89bhhp1m0s-rust-1.53.0-nightly-2021-03-30-74874a690/share:/nix/store/9p0yf4yzsc8by6xviags56c3mb3fxkkw-cargo-1.49.0/share:/nix/store/d7lyvmvzf1a8qqhsxhdc3r6dwbdmfcap-patchelf-0.12/share
79export XDG_DATA_DIRS 83export XDG_DATA_DIRS
80_=export 84_=export
81buildInputs= 85buildInputs=
@@ -115,7 +119,7 @@ fixupOutputHooks=([0]="if [ -z \"\${dontPatchELF-}\" ]; then patchELF \"\$prefix
115initialPath='/nix/store/ypsd29c5hgj1x7xz5ddffanxw5d8fh7b-coreutils-8.32 /nix/store/nq9l23mrm8irvl9qvxgvxqqkm5sfnc9d-findutils-4.7.0 /nix/store/7yq29nnglh2s576n7vdmzqryym22f8rj-diffutils-3.7 /nix/store/0839nqri8w69c91amlsq9bawaqlzpmh9-gnused-4.8 /nix/store/wmiyjdsaydyv024al5ddqd3liljrfvk7-gnugrep-3.6 /nix/store/snmar11l5w9jrxva2s5d6143nqmdgzqb-gawk-5.1.0 /nix/store/cisss0pcfh72kmnsv4qa6h41wcwb9mkv-gnutar-1.32 /nix/store/prdifiyrxwgf6sp4rwmrqvfdnvf72gw2-gzip-1.10 /nix/store/pp9shwhcdxxbhgp96fcaj0g8x5g54zrl-bzip2-1.0.6.0.1-bin /nix/store/fydw5vhlhpq438cxv4vwpa8pf8p8fv5s-gnumake-4.3 /nix/store/yyy7wr7r9jwjjqkr1yn643g3wzv010zd-bash-4.4-p23 /nix/store/qcw3qagp709qwfza259zqss5qh4wg789-patch-2.7.6 /nix/store/q0jqhjabwaaak30l4sq3z0xi6jrkpnbn-xz-5.2.5-bin' 119initialPath='/nix/store/ypsd29c5hgj1x7xz5ddffanxw5d8fh7b-coreutils-8.32 /nix/store/nq9l23mrm8irvl9qvxgvxqqkm5sfnc9d-findutils-4.7.0 /nix/store/7yq29nnglh2s576n7vdmzqryym22f8rj-diffutils-3.7 /nix/store/0839nqri8w69c91amlsq9bawaqlzpmh9-gnused-4.8 /nix/store/wmiyjdsaydyv024al5ddqd3liljrfvk7-gnugrep-3.6 /nix/store/snmar11l5w9jrxva2s5d6143nqmdgzqb-gawk-5.1.0 /nix/store/cisss0pcfh72kmnsv4qa6h41wcwb9mkv-gnutar-1.32 /nix/store/prdifiyrxwgf6sp4rwmrqvfdnvf72gw2-gzip-1.10 /nix/store/pp9shwhcdxxbhgp96fcaj0g8x5g54zrl-bzip2-1.0.6.0.1-bin /nix/store/fydw5vhlhpq438cxv4vwpa8pf8p8fv5s-gnumake-4.3 /nix/store/yyy7wr7r9jwjjqkr1yn643g3wzv010zd-bash-4.4-p23 /nix/store/qcw3qagp709qwfza259zqss5qh4wg789-patch-2.7.6 /nix/store/q0jqhjabwaaak30l4sq3z0xi6jrkpnbn-xz-5.2.5-bin'
116name=nix-shell 120name=nix-shell
117export name 121export name
118nativeBuildInputs='/nix/store/ni0nxz7jnd3scrfqsdr6cragl95fqmyb-rust-1.50.0-nightly-2020-12-22-bb1fbbf84 /nix/store/pgzjwsl6ilg93ifsx70ck5l2yv85fknm-rust-src-1.50.0-nightly-2020-12-22-bb1fbbf84 /nix/store/pj3m562kh9lr7wjk3hlyandhd1qpapgh-rust-analyzer-unstable-2021-02-22 /nix/store/9p0yf4yzsc8by6xviags56c3mb3fxkkw-cargo-1.49.0 /nix/store/91ym2jzh08470r4jb1d5pmh22vg2bpck-openssl-1.1.1i-dev /nix/store/saiwalr8jq58mbyipkn824r93gjjnw5x-ncurses-6.2-dev' 122nativeBuildInputs='/nix/store/58syiz9158g5s53gjh8f5b89bhhp1m0s-rust-1.53.0-nightly-2021-03-30-74874a690 /nix/store/m0k4il8v2wv0c7nniqndcxh72qmzvvg2-rust-src-1.53.0-nightly-2021-03-30-74874a690 /nix/store/pj3m562kh9lr7wjk3hlyandhd1qpapgh-rust-analyzer-unstable-2021-02-22 /nix/store/rfx0jz6pr3n2dcxm99finhbp99v45qx4-rustfmt-1.49.0 /nix/store/9p0yf4yzsc8by6xviags56c3mb3fxkkw-cargo-1.49.0'
119export nativeBuildInputs 123export nativeBuildInputs
120nobuildPhase=$'echo\necho "This derivation is not meant to be built, aborting";\necho\nexit 1\n' 124nobuildPhase=$'echo\necho "This derivation is not meant to be built, aborting";\necho\nexit 1\n'
121export nobuildPhase 125export nobuildPhase
@@ -137,7 +141,7 @@ export patches
137phases=nobuildPhase 141phases=nobuildPhase
138export phases 142export phases
139pkg=/nix/store/i9a3zzf2spmw67jppvkj2yavnbka62id-gcc-wrapper-10.2.0 143pkg=/nix/store/i9a3zzf2spmw67jppvkj2yavnbka62id-gcc-wrapper-10.2.0
140pkgsBuildHost=([0]="/nix/store/ni0nxz7jnd3scrfqsdr6cragl95fqmyb-rust-1.50.0-nightly-2020-12-22-bb1fbbf84" [1]="/nix/store/pgzjwsl6ilg93ifsx70ck5l2yv85fknm-rust-src-1.50.0-nightly-2020-12-22-bb1fbbf84" [2]="/nix/store/pj3m562kh9lr7wjk3hlyandhd1qpapgh-rust-analyzer-unstable-2021-02-22" [3]="/nix/store/9p0yf4yzsc8by6xviags56c3mb3fxkkw-cargo-1.49.0" [4]="/nix/store/91ym2jzh08470r4jb1d5pmh22vg2bpck-openssl-1.1.1i-dev" [5]="/nix/store/71707dbkha4mryph7ywp48wi2r1sc0hf-openssl-1.1.1i-bin" [6]="/nix/store/kchm26396krqwdn2dkx6l0hb79lwlhr1-openssl-1.1.1i" [7]="/nix/store/saiwalr8jq58mbyipkn824r93gjjnw5x-ncurses-6.2-dev" [8]="/nix/store/d3nz4c5xf1bqz8rwr8m4gbsrny9ffidk-ncurses-6.2" [9]="/nix/store/d7lyvmvzf1a8qqhsxhdc3r6dwbdmfcap-patchelf-0.12" [10]="/nix/store/mjjy30kxz775bhhi6j9phw81qh6dsbrf-move-docs.sh" [11]="/nix/store/kxw6q8v6isaqjm702d71n2421cxamq68-make-symlinks-relative.sh" [12]="/nix/store/cl3qd985p1yxyfkj96v0hqxiy3w69xq5-compress-man-pages.sh" [13]="/nix/store/h54dzwd7rdh2jlcv91424csl6d0ccgjy-strip.sh" [14]="/nix/store/bnj8d7mvbkg3vdb07yz74yhl3g107qq5-patch-shebangs.sh" [15]="/nix/store/cickvswrvann041nqxb0rxilc46svw1n-prune-libtool-files.sh" [16]="/nix/store/8zxndz5ag0p6s526c2xyllhk1nrn4c3i-audit-tmpdir.sh" [17]="/nix/store/c8n9kcdddp9np665xz6ri61b383nxvz8-move-systemd-user-units.sh" [18]="/nix/store/1i5y55x4b4m9qkx5dqbmr1r6bvrqbanw-multiple-outputs.sh" [19]="/nix/store/kd4xwxjpjxi71jkm6ka0np72if9rm3y0-move-sbin.sh" [20]="/nix/store/fyaryjvghbkpfnsyw97hb3lyb37s1pd6-move-lib64.sh" [21]="/nix/store/ngg1cv31c8c7bcm2n8ww4g06nq7s4zhm-set-source-date-epoch-to-latest.sh" [22]="/nix/store/pr6nzbscdpg94yvr151lrif2kg0csx7b-reproducible-builds.sh" [23]="/nix/store/i9a3zzf2spmw67jppvkj2yavnbka62id-gcc-wrapper-10.2.0" [24]="/nix/store/f4w8p656gg6v2k1v0whwmyk09kz3k8ic-binutils-wrapper-2.35.1") 144pkgsBuildHost=([0]="/nix/store/58syiz9158g5s53gjh8f5b89bhhp1m0s-rust-1.53.0-nightly-2021-03-30-74874a690" [1]="/nix/store/m0k4il8v2wv0c7nniqndcxh72qmzvvg2-rust-src-1.53.0-nightly-2021-03-30-74874a690" [2]="/nix/store/pj3m562kh9lr7wjk3hlyandhd1qpapgh-rust-analyzer-unstable-2021-02-22" [3]="/nix/store/rfx0jz6pr3n2dcxm99finhbp99v45qx4-rustfmt-1.49.0" [4]="/nix/store/9p0yf4yzsc8by6xviags56c3mb3fxkkw-cargo-1.49.0" [5]="/nix/store/d7lyvmvzf1a8qqhsxhdc3r6dwbdmfcap-patchelf-0.12" [6]="/nix/store/mjjy30kxz775bhhi6j9phw81qh6dsbrf-move-docs.sh" [7]="/nix/store/kxw6q8v6isaqjm702d71n2421cxamq68-make-symlinks-relative.sh" [8]="/nix/store/cl3qd985p1yxyfkj96v0hqxiy3w69xq5-compress-man-pages.sh" [9]="/nix/store/h54dzwd7rdh2jlcv91424csl6d0ccgjy-strip.sh" [10]="/nix/store/bnj8d7mvbkg3vdb07yz74yhl3g107qq5-patch-shebangs.sh" [11]="/nix/store/cickvswrvann041nqxb0rxilc46svw1n-prune-libtool-files.sh" [12]="/nix/store/8zxndz5ag0p6s526c2xyllhk1nrn4c3i-audit-tmpdir.sh" [13]="/nix/store/c8n9kcdddp9np665xz6ri61b383nxvz8-move-systemd-user-units.sh" [14]="/nix/store/1i5y55x4b4m9qkx5dqbmr1r6bvrqbanw-multiple-outputs.sh" [15]="/nix/store/kd4xwxjpjxi71jkm6ka0np72if9rm3y0-move-sbin.sh" [16]="/nix/store/fyaryjvghbkpfnsyw97hb3lyb37s1pd6-move-lib64.sh" [17]="/nix/store/ngg1cv31c8c7bcm2n8ww4g06nq7s4zhm-set-source-date-epoch-to-latest.sh" [18]="/nix/store/pr6nzbscdpg94yvr151lrif2kg0csx7b-reproducible-builds.sh" [19]="/nix/store/i9a3zzf2spmw67jppvkj2yavnbka62id-gcc-wrapper-10.2.0" [20]="/nix/store/f4w8p656gg6v2k1v0whwmyk09kz3k8ic-binutils-wrapper-2.35.1")
141postFixupHooks=([0]="_multioutPropagateDev") 145postFixupHooks=([0]="_multioutPropagateDev")
142postUnpackHooks=([0]="_updateSourceDateEpochFromSourceRoot") 146postUnpackHooks=([0]="_updateSourceDateEpochFromSourceRoot")
143preConfigureHooks=([0]="_multioutConfig") 147preConfigureHooks=([0]="_multioutConfig")
@@ -1496,7 +1500,7 @@ updateSourceDateEpoch ()
1496 fi 1500 fi
1497} 1501}
1498 1502
1499export NIX_BUILD_TOP="$(mktemp -d --tmpdir nix-shell.XXXXXX)" 1503export NIX_BUILD_TOP="$(mktemp -d -t nix-shell.XXXXXX)"
1500export TMP="$NIX_BUILD_TOP" 1504export TMP="$NIX_BUILD_TOP"
1501export TMPDIR="$NIX_BUILD_TOP" 1505export TMPDIR="$NIX_BUILD_TOP"
1502export TEMP="$NIX_BUILD_TOP" 1506export TEMP="$NIX_BUILD_TOP"
diff --git a/src/decode.rs b/src/decode.rs
index a9abd37..9c6a065 100644
--- a/src/decode.rs
+++ b/src/decode.rs
@@ -4,7 +4,7 @@ use bitvec::prelude::*;
4use byteorder::{LittleEndian, ReadBytesExt}; 4use byteorder::{LittleEndian, ReadBytesExt};
5 5
6use crate::error::{OBIError, OBIResult}; 6use crate::error::{OBIError, OBIResult};
7use crate::{FileHeader, Image, ImageInfoHeader}; 7use crate::{CompressionType, FileHeader, Image, ImageInfoHeader};
8 8
9pub fn decode_image(obi_data: &mut Cursor<Vec<u8>>) -> OBIResult<Image> { 9pub fn decode_image(obi_data: &mut Cursor<Vec<u8>>) -> OBIResult<Image> {
10 // file header 10 // file header
@@ -43,22 +43,59 @@ pub fn decode_image(obi_data: &mut Cursor<Vec<u8>>) -> OBIResult<Image> {
43 post_compression_size, 43 post_compression_size,
44 }; 44 };
45 45
46 // pixmap data 46 let data: Vec<bool> = match CompressionType::from_u32(compression_type) {
47 let mut data_bytes = vec![]; 47 CompressionType::RLE => {
48 obi_data 48 let mut rest = vec![];
49 .read_to_end(&mut data_bytes) 49 let mut lengths = vec![];
50 .map_err(|_| OBIError::Decode)?; 50 loop {
51 let data = data_bytes 51 let l = obi_data
52 .iter() 52 .read_u32::<LittleEndian>()
53 .map(|&b| { 53 .map_err(|_| OBIError::Encode)?;
54 BitVec::<Lsb0, u8>::from_element(b) 54 if l == 0 {
55 .into_iter() 55 break;
56 .map(|e| e as bool) 56 }
57 .collect::<Vec<bool>>() 57 lengths.push(l);
58 }) 58 }
59 .flatten() 59 obi_data
60 .collect::<Vec<_>>(); 60 .read_to_end(&mut rest)
61 .map_err(|_| OBIError::Decode)?;
62 let data_points = rest
63 .iter()
64 .map(|&b| {
65 BitVec::<Lsb0, u8>::from_element(b)
66 .into_iter()
67 .map(|e| e as bool)
68 .collect::<Vec<bool>>()
69 })
70 .flatten()
71 .collect::<Vec<bool>>();
61 72
73 let data = data_points
74 .into_iter()
75 .zip(lengths)
76 .map(|(d, l)| vec![d; l as usize])
77 .flatten()
78 .collect::<Vec<bool>>();
79 data
80 }
81 _ => {
82 let mut rest = vec![];
83 obi_data
84 .read_to_end(&mut rest)
85 .map_err(|_| OBIError::Decode)?;
86 let data_points = rest
87 .iter()
88 .map(|&b| {
89 BitVec::<Lsb0, u8>::from_element(b)
90 .into_iter()
91 .map(|e| e as bool)
92 .collect::<Vec<bool>>()
93 })
94 .flatten()
95 .collect::<Vec<_>>();
96 data_points
97 }
98 };
62 return Ok(Image { 99 return Ok(Image {
63 file_header, 100 file_header,
64 image_info_header, 101 image_info_header,
diff --git a/src/encode.rs b/src/encode.rs
index a8c58e0..30edc49 100644
--- a/src/encode.rs
+++ b/src/encode.rs
@@ -3,8 +3,11 @@ use std::borrow::Borrow;
3use bitvec::{prelude::*, vec::BitVec}; 3use bitvec::{prelude::*, vec::BitVec};
4use byteorder::{LittleEndian, WriteBytesExt}; 4use byteorder::{LittleEndian, WriteBytesExt};
5 5
6use crate::error::{OBIError, OBIResult}; 6use crate::{
7use crate::Image; 7 error::{OBIError, OBIResult},
8 rle::RLE,
9 CompressionType, Image,
10};
8 11
9pub fn encode_image<I>(obi_image: I) -> OBIResult<Vec<u8>> 12pub fn encode_image<I>(obi_image: I) -> OBIResult<Vec<u8>>
10where 13where
@@ -40,17 +43,38 @@ where
40 .write_u32::<LittleEndian>(image_info_header.post_compression_size) 43 .write_u32::<LittleEndian>(image_info_header.post_compression_size)
41 .map_err(|_| OBIError::Encode)?; 44 .map_err(|_| OBIError::Encode)?;
42 45
46 let write_pixel_data = |pixels: &Vec<bool>, obi_data: &mut Vec<u8>| -> OBIResult<()> {
47 for byte in pixels.chunks(8) {
48 let mut bv = BitVec::<Lsb0, u8>::new();
49 for &b in byte {
50 bv.push(b)
51 }
52 obi_data
53 .write_u8(bv.load::<u8>())
54 .map_err(|_| OBIError::Encode)?;
55 }
56 Ok(())
57 };
58
43 // pixmap data 59 // pixmap data
44 let pixmap = &obi_image.data; 60 let pixmap = &obi_image.data;
45 for byte in pixmap.chunks(8) { 61 match CompressionType::from_u32(obi_image.image_info_header.compression_type) {
46 let mut bv = BitVec::<Lsb0, u8>::new(); 62 CompressionType::RLE => {
47 for &b in byte { 63 let (data_points, lengths): (Vec<_>, Vec<_>) = pixmap.compress().into_iter().unzip();
48 bv.push(b); 64 for l in lengths {
65 obi_data
66 .write_u32::<LittleEndian>(l as u32)
67 .map_err(|_| OBIError::Encode)?;
68 }
69 // end length sequence with zero
70 obi_data
71 .write_u32::<LittleEndian>(0)
72 .map_err(|_| OBIError::Encode)?;
73 // begin data point sequence
74 write_pixel_data(&data_points, &mut obi_data)?;
49 } 75 }
50 obi_data 76 _ => write_pixel_data(pixmap, &mut obi_data)?,
51 .write_u8(bv.load::<u8>()) 77 };
52 .map_err(|_| OBIError::Encode)?;
53 }
54 78
55 return Ok(obi_data); 79 return Ok(obi_data);
56} 80}
diff --git a/src/lib.rs b/src/lib.rs
index f949d06..3995c16 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -7,8 +7,10 @@ use std::io;
7mod decode; 7mod decode;
8mod encode; 8mod encode;
9pub mod error; 9pub mod error;
10mod rle;
10 11
11use crate::error::{OBIError, OBIResult}; 12use error::{OBIError, OBIResult};
13use rle::RLE;
12 14
13#[non_exhaustive] 15#[non_exhaustive]
14#[derive(Copy, Clone, Debug, PartialEq)] 16#[derive(Copy, Clone, Debug, PartialEq)]
@@ -83,6 +85,14 @@ impl CompressionType {
83 _ => panic!("Invalid compression algorithm"), 85 _ => panic!("Invalid compression algorithm"),
84 } 86 }
85 } 87 }
88 pub fn to_u32(self) -> u32 {
89 match self {
90 CompressionType::None => 0,
91 CompressionType::RLE => 1,
92 CompressionType::Kosinki => 10,
93 _ => panic!("Invalid compression algorithm"),
94 }
95 }
86} 96}
87 97
88#[derive(Debug)] 98#[derive(Debug)]
@@ -111,6 +121,10 @@ impl Image {
111 } 121 }
112 } 122 }
113 123
124 pub fn use_compression(&mut self, comp: CompressionType) {
125 self.image_info_header.compression_type = comp.to_u32();
126 }
127
114 pub fn width(&self) -> u32 { 128 pub fn width(&self) -> u32 {
115 self.image_info_header.width 129 self.image_info_header.width
116 } 130 }
diff --git a/src/rle.rs b/src/rle.rs
new file mode 100644
index 0000000..f6d1e05
--- /dev/null
+++ b/src/rle.rs
@@ -0,0 +1,89 @@
1pub trait RLE {
2 type Data;
3 fn compress(&self) -> Vec<Run<Self::Data>>;
4 fn decompress(runs: Vec<Run<Self::Data>>) -> Vec<Self::Data>;
5}
6
7pub type Run<T> = (T, usize);
8
9impl<T> RLE for Vec<T>
10where
11 T: Clone + PartialEq,
12{
13 type Data = T;
14 fn compress(&self) -> Vec<Run<Self::Data>> {
15 let mut runs = vec![];
16 if self.is_empty() {
17 return runs;
18 }
19 let mut idx = 0;
20 loop {
21 let first = &self[idx];
22 let run_length = self[idx..].iter().take_while(|&item| item == first).count();
23
24 runs.push((first.clone(), run_length));
25
26 idx += run_length;
27 if idx > self.len() - 1 {
28 break;
29 }
30 }
31 runs
32 }
33 fn decompress(runs: Vec<Run<Self::Data>>) -> Vec<Self::Data> {
34 runs.into_iter()
35 .map(|(item, size)| vec![item; size])
36 .flatten()
37 .collect()
38 }
39}
40
41#[cfg(test)]
42mod tests {
43 use super::*;
44 #[test]
45 fn singleton() {
46 let data = "a".chars().collect::<Vec<_>>();
47 assert_eq!(Vec::<char>::compress(&data), vec![('a', 1),]);
48 }
49 #[test]
50 fn identity() {
51 let data = "aabbccddaabbaa".chars().collect::<Vec<_>>();
52 assert_eq!(Vec::<char>::decompress(data.compress()), data);
53 }
54 #[test]
55 fn repeated_singleton() {
56 let data = "aaaaaaaaaaaaa".chars().collect::<Vec<_>>();
57 assert_eq!(Vec::<char>::compress(&data), vec![('a', 13),]);
58 }
59 #[test]
60 fn empty_runs() {
61 let data = "".chars().collect::<Vec<_>>();
62 assert!(data.compress().is_empty());
63 }
64 #[test]
65 fn empty_decompress() {
66 assert!(Vec::<char>::decompress(vec![]).is_empty());
67 }
68 #[test]
69 fn check_runs1() {
70 let data = "aaaabbbbcccc".chars().collect::<Vec<_>>();
71 assert_eq!(data.compress(), vec![('a', 4), ('b', 4), ('c', 4)]);
72 }
73 #[test]
74 fn check_runs2() {
75 let data = "aabbccddaabbaa".chars().collect::<Vec<_>>();
76 assert_eq!(
77 data.compress(),
78 vec![
79 ('a', 2),
80 ('b', 2),
81 ('c', 2),
82 ('d', 2),
83 ('a', 2),
84 ('b', 2),
85 ('a', 2)
86 ]
87 );
88 }
89}
diff --git a/tests/serde.rs b/tests/serde.rs
index 295b8d0..3701707 100644
--- a/tests/serde.rs
+++ b/tests/serde.rs
@@ -11,13 +11,14 @@ fn size_of_image_info_header() {
11 11
12#[test] 12#[test]
13fn compression() { 13fn compression() {
14 let img = Image::new(50, 5); 14 let mut img = Image::new(50, 5);
15 img.use_compression(CompressionType::RLE);
15 let encoded = img.encode().unwrap(); 16 let encoded = img.encode().unwrap();
16 let mut cursor = Cursor::new(encoded); 17 let mut cursor = Cursor::new(encoded);
17 let decoded = Image::decode(&mut cursor).unwrap(); 18 let decoded = Image::decode(&mut cursor).unwrap();
18 assert_eq!( 19 assert_eq!(
19 CompressionType::from_u32(decoded.image_info_header.compression_type), 20 CompressionType::from_u32(decoded.image_info_header.compression_type),
20 CompressionType::None 21 CompressionType::RLE
21 ); 22 );
22} 23}
23 24
@@ -42,3 +43,20 @@ fn size_round_nearest() {
42 assert_eq!(decoded.image_info_header.width, 50); 43 assert_eq!(decoded.image_info_header.width, 50);
43 assert_eq!(decoded.image_info_header.height, 5); 44 assert_eq!(decoded.image_info_header.height, 5);
44} 45}
46
47#[test]
48fn size_compressed() {
49 let mut img = Image::new(100, 80);
50 img.use_compression(CompressionType::RLE);
51 let encoded = img.encode().unwrap();
52 // 26 - headers
53 // 4 - first and only length
54 // 4 - separator zero
55 // 1 - first and only data point
56 assert_eq!(encoded.len(), 26 + 4 + 4 + 1);
57 let mut cursor = Cursor::new(encoded);
58 let decoded = Image::decode(&mut cursor).unwrap();
59 assert_eq!(decoded.image_info_header.width, 100);
60 assert_eq!(decoded.image_info_header.height, 80);
61 assert!(decoded.data.iter().all(|x| !*x));
62}