Revert queue event forwarding, added comments what it is supposed to do.
authorWim Taymans <wim.taymans@gmail.com>
Sat, 8 Jun 2002 16:30:43 +0000 (16:30 +0000)
committerWim Taymans <wim.taymans@gmail.com>
Sat, 8 Jun 2002 16:30:43 +0000 (16:30 +0000)
Original commit message from CVS:
Revert queue event forwarding, added comments what it is supposed to do.

gst/gstqueue.c
plugins/elements/gstqueue.c

index 0799016b899e08bf247be8dd9c27622ea447d419..c0fcfb99148d863dba45ff7be0da11175ef3b3f2 100644 (file)
@@ -557,13 +557,23 @@ static gboolean
 gst_queue_handle_src_event (GstPad *pad, GstEvent *event)
 {
   GstQueue *queue;
+  gboolean res;
 
   queue = GST_QUEUE (GST_OBJECT_PARENT (pad));
 
-  /* push the event to the queue for upstream consumption */
-  g_async_queue_push(queue->events, event);
-
   g_mutex_lock (queue->qlock);
+
+  if (gst_element_get_state (GST_ELEMENT (queue)) == GST_STATE_PLAYING) {
+    /* push the event to the queue for upstream consumption */
+    g_async_queue_push(queue->events, event);
+    g_mutex_unlock (queue->qlock);
+    g_warning ("FIXME: sending event in a running queue");
+    /* FIXME wait for delivery of the event here, then return the result
+     * instead of FALSE */
+    return FALSE;
+  }
+
+  res = gst_pad_event_default (pad, event); 
   switch (GST_EVENT_TYPE (event)) {
     case GST_EVENT_FLUSH:
       GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "FLUSH event, flushing queue\n");
index 0799016b899e08bf247be8dd9c27622ea447d419..c0fcfb99148d863dba45ff7be0da11175ef3b3f2 100644 (file)
@@ -557,13 +557,23 @@ static gboolean
 gst_queue_handle_src_event (GstPad *pad, GstEvent *event)
 {
   GstQueue *queue;
+  gboolean res;
 
   queue = GST_QUEUE (GST_OBJECT_PARENT (pad));
 
-  /* push the event to the queue for upstream consumption */
-  g_async_queue_push(queue->events, event);
-
   g_mutex_lock (queue->qlock);
+
+  if (gst_element_get_state (GST_ELEMENT (queue)) == GST_STATE_PLAYING) {
+    /* push the event to the queue for upstream consumption */
+    g_async_queue_push(queue->events, event);
+    g_mutex_unlock (queue->qlock);
+    g_warning ("FIXME: sending event in a running queue");
+    /* FIXME wait for delivery of the event here, then return the result
+     * instead of FALSE */
+    return FALSE;
+  }
+
+  res = gst_pad_event_default (pad, event); 
   switch (GST_EVENT_TYPE (event)) {
     case GST_EVENT_FLUSH:
       GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "FLUSH event, flushing queue\n");