/* GStreamer * Copyright (C) 1999,2000 Erik Walthinsen * 2000 Wim Taymans * * gstbytestreams.c: Utility functions: gtk_get_property stuff, etc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ #include #include #include #include "gstbytestream.h" /** * gst_bytestream_new: * @pad: the pad to attach the bytstream to * * creates a bytestream from the given pad * * Returns: a new #GstByteStream object */ GstByteStream * gst_bytestream_new (GstPad * pad) { GstByteStream *bs = g_new (GstByteStream, 1); bs->pad = pad; bs->data = NULL; bs->size = 0; bs->index = 0; bs->pos = 0; return bs; } void gst_bytestream_destroy (GstByteStream *bs) { if (bs->data) { g_free (bs->data); } g_free (bs); } static guint64 gst_bytestream_bytes_fill (GstByteStream *bs, guint64 len) { size_t oldlen; GstBuffer *buf; while ((bs->index + len) > bs->size) { buf = gst_pad_pull (bs->pad); oldlen = bs->size - bs->index; memmove (bs->data, bs->data + bs->index, oldlen); bs->size = oldlen + GST_BUFFER_SIZE (buf); bs->index = 0; bs->data = realloc (bs->data, bs->size); if (!bs->data) { fprintf (stderr, "realloc failed: d:%p s:%llu\n", bs->data, bs->size); } memcpy (bs->data + oldlen, GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf)); } g_assert ((bs->index + len) <= bs->size); return len; } gint gst_bytestream_bytes_peek (GstByteStream *bs, guint8 **buf, guint64 len) { g_return_val_if_fail (len > 0, 0); g_return_val_if_fail (buf, 0); gst_bytestream_bytes_fill (bs, len); *buf = bs->data + bs->index; return len; } gint gst_bytestream_bytes_read (GstByteStream *bs, guint8 **buf, guint64 len) { len = gst_bytestream_bytes_peek (bs, buf, len); bs->index += len; bs->pos += len; return len; } gboolean gst_bytestream_bytes_seek (GstByteStream *bs, guint64 offset) { return FALSE; } gint gst_bytestream_bytes_flush (GstByteStream *bs, guint64 len) { guint8 *buf; if (len == 0) return len; len = gst_bytestream_bytes_read (bs, &buf, len); return len; }