summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorOlivier CrĂȘte <olivier.crete@collabora.com>2012-09-12 17:34:03 -0400
committerOlivier CrĂȘte <olivier.crete@collabora.com>2012-09-12 17:34:03 -0400
commitbfb56f83804b314f00fb12b2ce3e117e1e6df9a0 (patch)
tree610e08b39a275d11cd2f702017ce752d29f0b197
parente23e3d6b6448effe216cde08aa9d57d43321b77e (diff)
downloadgstreamer-plugins-bad-bfb56f83804b314f00fb12b2ce3e117e1e6df9a0.tar.gz
freeze: Use a GPtrArray instead of a GQueue
This way, the most common function (changing buffers) becomes O(1) instead of O(n)
-rw-r--r--gst/freeze/gstfreeze.c52
-rw-r--r--gst/freeze/gstfreeze.h4
2 files changed, 18 insertions, 38 deletions
diff --git a/gst/freeze/gstfreeze.c b/gst/freeze/gstfreeze.c
index 7c2e633d9..432a0277e 100644
--- a/gst/freeze/gstfreeze.c
+++ b/gst/freeze/gstfreeze.c
@@ -73,7 +73,6 @@ static gboolean gst_freeze_sink_activate_mode (GstPad * sinkpad,
static gboolean gst_freeze_sink_event (GstPad * pad, GstObject * parent,
GstEvent * event);
static void gst_freeze_clear_buffer (GstFreeze * freeze);
-static void gst_freeze_buffer_free (gpointer data, gpointer user_data);
G_DEFINE_TYPE (GstFreeze, gst_freeze, GST_TYPE_ELEMENT);
@@ -133,9 +132,10 @@ gst_freeze_init (GstFreeze * freeze)
freeze->timestamp_offset = 0;
freeze->running_time = 0;
- freeze->current = NULL;
+ freeze->current = 0;
freeze->max_buffers = 1;
- freeze->buffers = g_queue_new ();
+ freeze->buffers = g_ptr_array_new_with_free_func (
+ (GDestroyNotify) gst_buffer_unref);
}
static void
@@ -144,8 +144,7 @@ gst_freeze_dispose (GObject * object)
GstFreeze *freeze = GST_FREEZE (object);
gst_freeze_clear_buffer (freeze);
-
- g_queue_free (freeze->buffers);
+ g_ptr_array_free (freeze->buffers, TRUE);
G_OBJECT_CLASS (gst_freeze_parent_class)->dispose (object);
}
@@ -214,39 +213,28 @@ gst_freeze_play (GstFreeze * freeze, GstBuffer * buf)
GstFlowReturn ret = GST_FLOW_OK;
GstBuffer *outbuf;
- if (freeze->current == NULL)
+ if (freeze->buffers->len == 0)
freeze->timestamp_offset = GST_BUFFER_TIMESTAMP (buf);
- if (g_queue_get_length (freeze->buffers) < freeze->max_buffers ||
- freeze->max_buffers == 0) {
- g_queue_push_tail (freeze->buffers, buf);
- GST_DEBUG_OBJECT (freeze, "accepted buffer %u",
- g_queue_get_length (freeze->buffers) - 1);
+ if (freeze->buffers->len < freeze->max_buffers || freeze->max_buffers == 0) {
+ g_ptr_array_add (freeze->buffers, buf);
+ GST_DEBUG_OBJECT (freeze, "accepted buffer %u", freeze->buffers->len - 1);
} else {
gst_buffer_unref (buf);
}
-
- if (freeze->current != NULL) {
- GST_DEBUG_OBJECT (freeze, "switching to next buffer");
- freeze->current = g_queue_peek_nth (freeze->buffers,
- g_queue_index (freeze->buffers, (gpointer) freeze->current) + 1);
- }
-
- if (freeze->current == NULL) {
- if (freeze->max_buffers > 1)
- GST_DEBUG_OBJECT (freeze, "restarting the loop");
- freeze->current = g_queue_peek_head (freeze->buffers);
- }
-
- outbuf = gst_buffer_copy (freeze->current);
+ outbuf =
+ gst_buffer_copy (g_ptr_array_index (freeze->buffers, freeze->current));
+ freeze->current++;
+ freeze->current %= freeze->buffers->len;
GST_BUFFER_TIMESTAMP (outbuf) = freeze->timestamp_offset +
freeze->running_time;
- freeze->running_time += GST_BUFFER_DURATION (freeze->current);
+ freeze->running_time += GST_BUFFER_DURATION (outbuf);
ret = gst_pad_push (freeze->srcpad, outbuf);
+
return ret;
}
@@ -313,18 +301,10 @@ gst_freeze_sink_activate_mode (GstPad * sinkpad, GstObject * parent,
}
static void
-gst_freeze_buffer_free (gpointer data, gpointer user_data)
-{
- gst_buffer_unref (GST_BUFFER (data));
-}
-
-static void
gst_freeze_clear_buffer (GstFreeze * freeze)
{
- if (freeze->buffers != NULL) {
- g_queue_foreach (freeze->buffers, gst_freeze_buffer_free, NULL);
- }
- freeze->current = NULL;
+ g_ptr_array_set_size (freeze->buffers, 0);
+ freeze->current = 0;
freeze->running_time = 0;
}
diff --git a/gst/freeze/gstfreeze.h b/gst/freeze/gstfreeze.h
index 92b186fe8..6b4969955 100644
--- a/gst/freeze/gstfreeze.h
+++ b/gst/freeze/gstfreeze.h
@@ -39,8 +39,8 @@ struct _GstFreeze
GstPad *sinkpad, *srcpad;
- GQueue *buffers;
- GstBuffer *current;
+ GPtrArray *buffers;
+ guint current;
guint max_buffers;