From 30aa38e29a03250192c3c0d4faa3c37a9d4d0357 Mon Sep 17 00:00:00 2001 From: Jon Bergli Heier Date: Sun, 5 Sep 2010 18:26:30 +0200 Subject: Rewrote encoder/decoder setup to use streams instead of buffers. --- encoders/encoder_lame.c | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) (limited to 'encoders/encoder_lame.c') diff --git a/encoders/encoder_lame.c b/encoders/encoder_lame.c index ec50047..b28e52e 100644 --- a/encoders/encoder_lame.c +++ b/encoders/encoder_lame.c @@ -12,13 +12,21 @@ static gboolean lame_encoder_init(gpointer *data) { return (ret >= 0 ? TRUE : FALSE); } -static gssize lame_encoder_encode(gpointer data, const guchar *inbuf, gsize inbuf_size, - guchar *outbuf, gsize outbuf_size) { +static gssize lame_encoder_encode(gpointer data, GInputStream *input, + GOutputStream *output) { lame_global_flags *gfp = data; + const inbuf_size = 0x400*8; + const outbuf_size = 0x400*8; + gchar inbuf[inbuf_size]; + gchar outbuf[inbuf_size]; - int ret = lame_encode_buffer_interleaved(gfp, (short*)inbuf, inbuf_size / 4, + int inbuf_read = g_input_stream_read(input, inbuf, inbuf_size, NULL, NULL); + + int ret = lame_encode_buffer_interleaved(gfp, (short*)inbuf, inbuf_read / 4, outbuf, outbuf_size); + g_output_stream_write(output, outbuf, ret, NULL, NULL); + return ret; } -- cgit v1.2.3