#include <h/md5.h>
#include <inttypes.h>
-static char nib2b64[0x40+1] =
+static const char nib2b64[0x40+1] =
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
int
4 * [length/3] + length/57 + 2
But double the length will certainly be sufficient. */
int
-writeBase64 (unsigned char *in, size_t length, unsigned char *out)
+writeBase64 (const unsigned char *in, size_t length, unsigned char *out)
{
unsigned int n = BPERLIN;
unsigned long bits;
unsigned char *bp;
unsigned int cc;
- for (cc = 0, bp = in; length > 0 && cc < 3; ++cc, ++bp, --length)
+ for (cc = 0; length > 0 && cc < 3; ++cc, --length)
/* empty */ ;
if (cc == 0) {
*/
int
-writeBase64raw (unsigned char *in, size_t length, unsigned char *out)
+writeBase64raw (const unsigned char *in, size_t length, unsigned char *out)
{
while (1) {
unsigned long bits;
unsigned char *bp;
unsigned int cc;
- for (cc = 0, bp = in; length > 0 && cc < 3; ++cc, ++bp, --length)
+ for (cc = 0; length > 0 && cc < 3; ++cc, --length)
/* empty */ ;
if (cc == 0) {
}
-static unsigned char b642nib[0x80] = {
+static const unsigned char b642nib[0x80] = {
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
* See description of arguments with declaration in h/prototypes.h.
*/
int
-decodeBase64 (const char *encoded, const char **decoded, size_t *len, int skip_crs,
- unsigned char *digest) {
+decodeBase64 (const char *encoded, unsigned char **decoded, size_t *len,
+ int skip_crs, unsigned char *digest) {
const char *cp = encoded;
int self_delimiting = 0;
int bitno, skip;
charstring_t decoded_c = charstring_create (strlen (encoded));
MD5_CTX mdContext;
- if (digest) { MD5Init (&mdContext); }
+ if (digest)
+ MD5Init (&mdContext);
bitno = 18;
bits = 0L;
}
if (skip || (((unsigned char) *cp) & 0x80) ||
(value = b642nib[((unsigned char) *cp) & 0x7f]) > 0x3f) {
- advise (NULL, "invalid BASE64 encoding in %s", encoded);
+ advise (NULL, "invalid BASE64 encoding in %s", cp);
charstring_free (decoded_c);
*decoded = NULL;
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);
}
}
}
if (! self_delimiting && bitno != 18) {
- advise (NULL, "premature ending (bitno %d) in %s", bitno, encoded);
+ int i;
+
+ /* Show some context for the error. */
+ for (i = 0; i < 20 && cp > encoded; ++i, --cp) {}
+ advise (NULL, "premature ending (bitno %d) near %s", bitno,
+ cp ? cp : encoded);
charstring_free (decoded_c);
*decoded = NULL;
return NOTOK;
}
- *decoded = charstring_buffer_copy (decoded_c);
+ *decoded = (unsigned char *) charstring_buffer_copy (decoded_c);
*len = charstring_bytes (decoded_c);
charstring_free (decoded_c);
size_t i;
for (i = 0; i < len; ++i, ++cp) {
- if (isprint(*cp)) {
+ if (isascii(*cp) && isprint(*cp)) {
charstring_push_back (tmp, (const char) *cp);
} else {
char s[16];