summaryrefslogtreecommitdiff
path: root/src/cairo-base85-stream.c
diff options
context:
space:
mode:
authorKristian Høgsberg <krh@redhat.com>2006-06-12 03:10:40 -0400
committerKristian Høgsberg <krh@redhat.com>2006-06-12 03:10:40 -0400
commitd43321066081eacca2e0c86258c68bae49036087 (patch)
treefc44f4d4c78816fc0a5d4bae604e8860bade2b52 /src/cairo-base85-stream.c
parent45cbe055d9cf4ac2cf2fbcd21b020c8f869a0380 (diff)
downloadcairo-d43321066081eacca2e0c86258c68bae49036087.tar.gz
Convert the word wrap stream, the base85 stream and the ps string stream.
Diffstat (limited to 'src/cairo-base85-stream.c')
-rw-r--r--src/cairo-base85-stream.c27
1 files changed, 12 insertions, 15 deletions
diff --git a/src/cairo-base85-stream.c b/src/cairo-base85-stream.c
index 2861a4233..7163d0092 100644
--- a/src/cairo-base85-stream.c
+++ b/src/cairo-base85-stream.c
@@ -38,6 +38,7 @@
#include "cairo-output-stream-private.h"
typedef struct _cairo_base85_stream {
+ cairo_output_stream_t base;
cairo_output_stream_t *output;
unsigned char four_tuple[4];
int pending;
@@ -64,11 +65,11 @@ _expand_four_tuple_to_five (unsigned char four_tuple[4],
}
static cairo_status_t
-_cairo_base85_stream_write (void *closure,
- const unsigned char *data,
- unsigned int length)
+_cairo_base85_stream_write (cairo_output_stream_t *base,
+ const unsigned char *data,
+ unsigned int length)
{
- cairo_base85_stream_t *stream = closure;
+ cairo_base85_stream_t *stream = (cairo_base85_stream_t *) base;
const unsigned char *ptr = data;
unsigned char five_tuple[5];
cairo_bool_t is_zero;
@@ -90,10 +91,9 @@ _cairo_base85_stream_write (void *closure,
}
static cairo_status_t
-_cairo_base85_stream_close (void *closure)
+_cairo_base85_stream_close (cairo_output_stream_t *base)
{
- cairo_status_t status;
- cairo_base85_stream_t *stream = closure;
+ cairo_base85_stream_t *stream = (cairo_base85_stream_t *) base;
unsigned char five_tuple[5];
if (stream->pending) {
@@ -105,11 +105,7 @@ _cairo_base85_stream_close (void *closure)
/* Mark end of base85 data */
_cairo_output_stream_printf (stream->output, "~>");
- status = _cairo_output_stream_get_status (stream->output);
-
- free (stream);
-
- return status;
+ return _cairo_output_stream_get_status (stream->output);
}
cairo_output_stream_t *
@@ -121,10 +117,11 @@ _cairo_base85_stream_create (cairo_output_stream_t *output)
if (stream == NULL)
return (cairo_output_stream_t *) &cairo_output_stream_nil;
+ _cairo_output_stream_init (&stream->base,
+ _cairo_base85_stream_write,
+ _cairo_base85_stream_close);
stream->output = output;
stream->pending = 0;
- return _cairo_output_stream_create (_cairo_base85_stream_write,
- _cairo_base85_stream_close,
- stream);
+ return &stream->base;
}