diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2008-08-17 18:01:15 +0100 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2008-08-17 20:27:02 +0100 |
commit | 5ef52cd08f586d4ca0b30ff7d47575f0dfba9172 (patch) | |
tree | 1138cc9e0e97dbb5a3cd34baa023ad92f19306e6 /src | |
parent | c745a622db7844ad0dc0da14446457eed1133eb5 (diff) |
[svg] Tweak base64_write_func().
On a wild goose chase to eliminate a valgrind warning (caused by libpng,
alas) tweak the code for a bit of simplification.
Diffstat (limited to 'src')
-rw-r--r-- | src/cairo-svg-surface.c | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/src/cairo-svg-surface.c b/src/cairo-svg-surface.c index 0b0165e6..8d17cadc 100644 --- a/src/cairo-svg-surface.c +++ b/src/cairo-svg-surface.c @@ -870,12 +870,11 @@ _cairo_svg_surface_emit_alpha_filter (cairo_svg_document_t *document) typedef struct { cairo_output_stream_t *output; unsigned int in_mem; - unsigned char src[3]; - unsigned char dst[5]; unsigned int trailing; + unsigned char src[3]; } base64_write_closure_t; -static char const *base64_table = +static char const base64_table[64] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; static cairo_status_t @@ -885,26 +884,27 @@ base64_write_func (void *closure, { base64_write_closure_t *info = (base64_write_closure_t *) closure; unsigned int i; - unsigned char *src, *dst; + unsigned char *src; - dst = info->dst; src = info->src; if (info->in_mem + length < 3) { for (i = 0; i < length; i++) { - src[i + info->in_mem] = *data; - data++; + src[i + info->in_mem] = *data++; } info->in_mem += length; return CAIRO_STATUS_SUCCESS; } - while (info->in_mem + length >= 3) { - for (i = 0; i < 3 - info->in_mem; i++) { - src[i + info->in_mem] = *data; - data++; + do { + unsigned char dst[4]; + + for (i = info->in_mem; i < 3; i++) { + src[i] = *data++; length--; } + info->in_mem = 0; + dst[0] = base64_table[src[0] >> 2]; dst[1] = base64_table[(src[0] & 0x03) << 4 | src[1] >> 4]; dst[2] = base64_table[(src[1] & 0x0f) << 2 | src[2] >> 6]; @@ -919,16 +919,14 @@ base64_write_func (void *closure, break; } _cairo_output_stream_write (info->output, dst, 4); - info->in_mem = 0; - } + } while (length >= 3); for (i = 0; i < length; i++) { - src[i] = *data; - data++; + src[i] = *data++; } info->in_mem = length; - return CAIRO_STATUS_SUCCESS; + return _cairo_output_stream_get_status (info->output); } static cairo_int_status_t @@ -942,7 +940,6 @@ _cairo_surface_base64_encode (cairo_surface_t *surface, info.output = output; info.in_mem = 0; info.trailing = 0; - memset (info.dst, '\x0', 5); _cairo_output_stream_printf (info.output, "data:image/png;base64,"); |