diff options
author | Rob Landley <rob@landley.net> | 2016-03-02 22:05:21 -0600 |
---|---|---|
committer | Rob Landley <rob@landley.net> | 2016-03-02 22:05:21 -0600 |
commit | 0dfa601b9fec5191269702cdd037adf25814ab19 (patch) | |
tree | 0358e3c183f5a64e9954e101805a9b2118edf790 | |
parent | 336c44adca1768ada1e1e2f4d7dbbc33e994e582 (diff) | |
download | toybox-0dfa601b9fec5191269702cdd037adf25814ab19.tar.gz |
Fix base64 so == wraps properly.
-rw-r--r-- | toys/other/base64.c | 31 |
1 files changed, 20 insertions, 11 deletions
diff --git a/toys/other/base64.c b/toys/other/base64.c index 7dc61147..234ca1c3 100644 --- a/toys/other/base64.c +++ b/toys/other/base64.c @@ -24,26 +24,39 @@ config BASE64 GLOBALS( long columns; + + unsigned total; ) +static void wraputchar(int c, int *x) +{ + putchar(c); + TT.total++; + if (++*x == TT.columns) { + *x = 0; + xputc('\n'); + }; +} + static void do_base64(int fd, char *name) { int out = 0, bits = 0, x = 0, i, len; char *buf = toybuf+128; + TT.total = 0; + for (;;) { + // If no more data, flush buffer if (!(len = xread(fd, buf, sizeof(toybuf)-128))) { if (!(toys.optflags & FLAG_d)) { - if (bits) { - putchar(toybuf[out<<(6-bits)]); - x++; - } - while (x++&3) putchar('='); - if (x != 1) xputc('\n'); + if (bits) wraputchar(toybuf[out<<(6-bits)], &x); + while (TT.total&3) wraputchar('=', &x); + if (x) xputc('\n'); } return; } + for (i=0; i<len; i++) { if (toys.optflags & FLAG_d) { if (buf[i] == '=') return; @@ -66,12 +79,8 @@ static void do_base64(int fd, char *name) out = (out<<8) + buf[i]; bits += 8; while (bits >= 6) { - putchar(toybuf[out >> (bits -= 6)]); + wraputchar(toybuf[out >> (bits -= 6)], &x); out &= (1<<bits)-1; - if (TT.columns == ++x) { - xputc('\n'); - x = 0; - } } } } |