Don't update state if the peer event failed
authorWim Taymans <wim.taymans@gmail.com>
Sun, 2 Jun 2002 15:34:34 +0000 (15:34 +0000)
committerWim Taymans <wim.taymans@gmail.com>
Sun, 2 Jun 2002 15:34:34 +0000 (15:34 +0000)
Original commit message from CVS:
Don't update state if the peer event failed

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

index 9cfd9178874ed5eb08b8d776a85735dcbdc74ca2..b3331b243d61a0391ced6e74e6723f81a82a05b9 100644 (file)
@@ -523,6 +523,7 @@ static gboolean
 gst_queue_handle_src_event (GstPad *pad, GstEvent *event)
 {
   GstQueue *queue;
+  gboolean res = TRUE;
 
   queue = GST_QUEUE (GST_OBJECT_PARENT (pad));
 
@@ -534,19 +535,23 @@ gst_queue_handle_src_event (GstPad *pad, GstEvent *event)
     return FALSE;
   }
 
-  switch (GST_EVENT_TYPE (event)) {
-    case GST_EVENT_FLUSH:
-      GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "FLUSH event, flushing queue\n");
-      gst_queue_locked_flush (queue);
-      break;
-    case GST_EVENT_SEEK:
-      gst_queue_locked_flush (queue);
-    default:
-      gst_pad_event_default (pad, event); 
-      break;
+  res = gst_pad_event_default (pad, event); 
+  if (res) { 
+    switch (GST_EVENT_TYPE (event)) {
+      case GST_EVENT_FLUSH:
+        GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "FLUSH event, flushing queue\n");
+        gst_queue_locked_flush (queue);
+        break;
+      case GST_EVENT_SEEK:
+       if (GST_EVENT_SEEK_FLAGS (event) & GST_SEEK_FLAG_FLUSH)
+          gst_queue_locked_flush (queue);
+      default:
+        break;
+    }
   }
   g_mutex_unlock (queue->qlock);
-  return TRUE;
+
+  return res;
 }
 
 static gboolean
index 9cfd9178874ed5eb08b8d776a85735dcbdc74ca2..b3331b243d61a0391ced6e74e6723f81a82a05b9 100644 (file)
@@ -523,6 +523,7 @@ static gboolean
 gst_queue_handle_src_event (GstPad *pad, GstEvent *event)
 {
   GstQueue *queue;
+  gboolean res = TRUE;
 
   queue = GST_QUEUE (GST_OBJECT_PARENT (pad));
 
@@ -534,19 +535,23 @@ gst_queue_handle_src_event (GstPad *pad, GstEvent *event)
     return FALSE;
   }
 
-  switch (GST_EVENT_TYPE (event)) {
-    case GST_EVENT_FLUSH:
-      GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "FLUSH event, flushing queue\n");
-      gst_queue_locked_flush (queue);
-      break;
-    case GST_EVENT_SEEK:
-      gst_queue_locked_flush (queue);
-    default:
-      gst_pad_event_default (pad, event); 
-      break;
+  res = gst_pad_event_default (pad, event); 
+  if (res) { 
+    switch (GST_EVENT_TYPE (event)) {
+      case GST_EVENT_FLUSH:
+        GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "FLUSH event, flushing queue\n");
+        gst_queue_locked_flush (queue);
+        break;
+      case GST_EVENT_SEEK:
+       if (GST_EVENT_SEEK_FLAGS (event) & GST_SEEK_FLAG_FLUSH)
+          gst_queue_locked_flush (queue);
+      default:
+        break;
+    }
   }
   g_mutex_unlock (queue->qlock);
-  return TRUE;
+
+  return res;
 }
 
 static gboolean