X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/30c889422a04c903350797f9c192bb6fb075f68e..665dfc96:/sbr/base64.c?ds=inline diff --git a/sbr/base64.c b/sbr/base64.c index e8ddee7a..8426fb2f 100644 --- a/sbr/base64.c +++ b/sbr/base64.c @@ -1,5 +1,4 @@ -/* - * base64.c -- routines for converting to base64 +/* base64.c -- routines for converting to base64 * * This code is Copyright (c) 2012, by the authors of nmh. See the * COPYRIGHT file in the root directory of the nmh distribution for @@ -124,17 +123,16 @@ writeBase64 (const unsigned char *in, size_t length, unsigned char *out) for (cc = 0; length > 0 && cc < 3; ++cc, --length) /* empty */ ; - if (cc == 0) { + if (cc == 0) break; - } else { - bits = (in[0] & 0xff) << 16; - if (cc > 1) { - bits |= (in[1] & 0xff) << 8; - if (cc > 2) { - bits |= in[2] & 0xff; - } - } - } + + bits = (in[0] & 0xff) << 16; + if (cc > 1) { + bits |= (in[1] & 0xff) << 8; + if (cc > 2) { + bits |= in[2] & 0xff; + } + } for (bp = out + 4; bp > out; bits >>= 6) *--bp = nib2b64[bits & 0x3f]; @@ -177,17 +175,16 @@ writeBase64raw (const unsigned char *in, size_t length, unsigned char *out) for (cc = 0; length > 0 && cc < 3; ++cc, --length) /* empty */ ; - if (cc == 0) { + if (cc == 0) break; - } else { - bits = (in[0] & 0xff) << 16; - if (cc > 1) { - bits |= (in[1] & 0xff) << 8; - if (cc > 2) { - bits |= in[2] & 0xff; - } - } - } + + bits = (in[0] & 0xff) << 16; + if (cc > 1) { + bits |= (in[1] & 0xff) << 8; + if (cc > 2) { + bits |= in[2] & 0xff; + } + } for (bp = out + 4; bp > out; bits >>= 6) *--bp = nib2b64[bits & 0x3f]; @@ -243,7 +240,8 @@ decodeBase64 (const char *encoded, unsigned char **decoded, size_t *len, charstring_t decoded_c = charstring_create (strlen (encoded)); MD5_CTX mdContext; - if (digest) { MD5Init (&mdContext); } + if (digest) + MD5Init (&mdContext); bitno = 18; bits = 0L; @@ -259,7 +257,7 @@ decodeBase64 (const char *encoded, unsigned char **decoded, size_t *len, } if (skip || (((unsigned char) *cp) & 0x80) || (value = b642nib[((unsigned char) *cp) & 0x7f]) > 0x3f) { - advise (NULL, "invalid BASE64 encoding in %s", cp); + inform("invalid BASE64 encoding in %s", cp); charstring_free (decoded_c); *decoded = NULL; @@ -274,19 +272,22 @@ test_end: if (! skip_crs || b != '\r') { charstring_push_back (decoded_c, b); } - if (digest) { MD5Update (&mdContext, (unsigned char *) &b, 1); } + if (digest) + MD5Update (&mdContext, (unsigned char *) &b, 1); if (skip < 2) { b = (bits >> 8) & 0xff; if (! skip_crs || b != '\r') { charstring_push_back (decoded_c, b); } - if (digest) { MD5Update (&mdContext, (unsigned char *) &b, 1); } + if (digest) + MD5Update (&mdContext, (unsigned char *) &b, 1); if (skip < 1) { b = bits & 0xff; if (! skip_crs || b != '\r') { charstring_push_back (decoded_c, b); } - if (digest) { MD5Update (&mdContext, (unsigned char *) &b, 1); } + if (digest) + MD5Update (&mdContext, (unsigned char *) &b, 1); } } @@ -297,12 +298,10 @@ test_end: break; case '=': - if (++skip > 3) { - self_delimiting = 1; - break; - } else { + if (++skip <= 3) goto test_end; - } + self_delimiting = 1; + break; } } @@ -311,7 +310,7 @@ test_end: /* Show some context for the error. */ for (i = 0; i < 20 && cp > encoded; ++i, --cp) {} - advise (NULL, "premature ending (bitno %d) near %s", bitno, + inform("premature ending (bitno %d) near %s", bitno, cp ? cp : encoded); charstring_free (decoded_c); *decoded = NULL; @@ -351,7 +350,7 @@ hexify (const unsigned char *input, size_t len, char **output) { const int num = snprintf(s, sizeof s, "[0x%02x]", *cp); if (num <= 0 || (unsigned int) num >= sizeof s) { - advise (NULL, "hexify failed to write nonprintable character, needed %d bytes", num + 1); + inform("hexify failed to write nonprintable character, needed %d bytes", num + 1); } else { charstring_append_cstring (tmp, s); }