ext/ogg/gstoggdemux.c: Handle various conditions better when we don't understand...
authorMichael Smith <msmith@xiph.org>
Fri, 25 Nov 2005 17:15:46 +0000 (17:15 +0000)
committerMichael Smith <msmith@xiph.org>
Fri, 25 Nov 2005 17:15:46 +0000 (17:15 +0000)
Original commit message from CVS:
* ext/ogg/gstoggdemux.c: (gst_ogg_pad_query_convert),
(gst_ogg_demux_chain_peer), (gst_ogg_demux_perform_seek),
(gst_ogg_demux_read_chain), (gst_ogg_demux_read_end_chain),
(gst_ogg_demux_send_event), (gst_ogg_demux_loop):
Handle various conditions better when we don't understand a stream.
Removes a heap of CRITICALs on ogg streams containing unknown data.

ChangeLog
ext/ogg/gstoggdemux.c

index 9025990c47efc455e6382730da1f8f65aa6ed058..58f52589712dd555240f7226ae60160d673987ce 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,12 @@
+2005-11-25  Michael Smith  <msmith@fluendo.com>
+
+       * ext/ogg/gstoggdemux.c: (gst_ogg_pad_query_convert),
+       (gst_ogg_demux_chain_peer), (gst_ogg_demux_perform_seek),
+       (gst_ogg_demux_read_chain), (gst_ogg_demux_read_end_chain),
+       (gst_ogg_demux_send_event), (gst_ogg_demux_loop):
+         Handle various conditions better when we don't understand a stream.
+         Removes a heap of CRITICALs on ogg streams containing unknown data.
+
 2005-11-24  Andy Wingo  <wingo@pobox.com>
 
        * gst/tcp/gstmultifdsink.c (gst_multifdsink_handle_client_write):
index 68c22ac6eb3f5ec806e05171bb9b9b2d7ce059a6..67c696ce4cd8eed27998e8b078455c026facb2ae 100644 (file)
@@ -739,7 +739,9 @@ gst_ogg_pad_query_convert (GstOggPad * ogg_pad, GstFormat from_format,
     return TRUE;
   }
 
-  g_return_val_if_fail (ogg_pad->elem_pad != NULL, FALSE);
+  /* If we don't know the stream type, we won't have an internal pad to ask */
+  if (!ogg_pad->elem_pad)
+    return FALSE;
 
   return gst_pad_query_convert (ogg_pad->elem_pad,
       from_format, from_value, to_format, to_value);
@@ -777,7 +779,7 @@ gst_ogg_demux_chain_peer (GstOggPad * pad, ogg_packet * packet)
       if (!gst_ogg_pad_query_convert (pad,
               GST_FORMAT_DEFAULT, packet->granulepos, &format,
               (gint64 *) & ogg->current_time)) {
-        g_warning ("could not convert granulepos to time");
+        GST_WARNING_OBJECT (ogg, "could not convert granulepos to time");
       } else {
         GST_DEBUG ("ogg current time %" GST_TIME_FORMAT,
             GST_TIME_ARGS (ogg->current_time));
@@ -1706,7 +1708,7 @@ gst_ogg_demux_perform_seek (GstOggDemux * ogg)
         if (!gst_ogg_pad_query_convert (pad,
                 GST_FORMAT_DEFAULT, granulepos, &format,
                 (gint64 *) & granuletime)) {
-          g_warning ("could not convert granulepos to time");
+          GST_WARNING_OBJECT (ogg, "could not convert granulepos to time");
           granuletime = target;
         } else {
           granuletime -= pad->first_time;
@@ -1755,6 +1757,15 @@ gst_ogg_demux_perform_seek (GstOggDemux * ogg)
   /* now we have a new position, prepare for streaming again */
   {
     GstEvent *event;
+    gint64 start_value = start + chain->segment_start;
+    gint64 stop_value;
+
+    if (start_value == GST_CLOCK_TIME_NONE)
+      start_value = 0;
+    if (chain->segment_start == GST_CLOCK_TIME_NONE)
+      stop_value = GST_CLOCK_TIME_NONE;
+    else
+      stop_value = stop + chain->segment_start;
 
     /* we have to send the flush to the old chain, not the new one */
     if (flush)
@@ -1762,8 +1773,7 @@ gst_ogg_demux_perform_seek (GstOggDemux * ogg)
 
     /* create the discont event we are going to send out */
     event = gst_event_new_new_segment (FALSE, 1.0,
-        GST_FORMAT_TIME,
-        start + chain->segment_start, stop + chain->segment_start, start);
+        GST_FORMAT_TIME, start_value, stop_value, start);
 
     if (chain != ogg->current_chain) {
       /* switch to different chain, send discont on new chain */
@@ -1991,7 +2001,7 @@ gst_ogg_demux_read_chain (GstOggDemux * ogg)
     if (!gst_ogg_pad_query_convert (pad,
             GST_FORMAT_DEFAULT, pad->first_granule, &target,
             (gint64 *) & pad->first_time)) {
-      g_warning ("could not convert granule to time");
+      GST_WARNING_OBJECT (ogg, "could not convert granulepos to time");
     }
 
     pad->mode = GST_OGG_PAD_MODE_STREAMING;
@@ -2055,7 +2065,7 @@ gst_ogg_demux_read_end_chain (GstOggDemux * ogg, GstOggChain * chain)
   if (last_granule == -1 || !gst_ogg_pad_query_convert (last_pad,
           GST_FORMAT_DEFAULT, last_granule, &target,
           (gint64 *) & chain->segment_stop)) {
-    g_warning ("could not convert granule to time");
+    GST_WARNING_OBJECT (ogg, "could not convert granulepos to time");
     chain->segment_stop = GST_CLOCK_TIME_NONE;
   }
 
@@ -2364,6 +2374,7 @@ gst_ogg_demux_send_event (GstOggDemux * ogg, GstEvent * event)
       GstOggPad *pad = g_array_index (chain->streams, GstOggPad *, i);
 
       gst_event_ref (event);
+      GST_DEBUG_OBJECT (ogg, "Pushing event on pad %p", pad);
       gst_pad_push_event (GST_PAD (pad), event);
     }
   }
@@ -2416,24 +2427,30 @@ gst_ogg_demux_loop (GstOggPad * pad)
     /* FIXME, need to be done somewhere else where we
      * can check against segment_stop time. */
     if (ogg->segment_flags & GST_SEEK_FLAG_SEGMENT) {
+      GST_LOG_OBJECT (ogg, "Sending segment done, at end of segment");
       gst_element_post_message (GST_ELEMENT (ogg),
           gst_message_new_segment_done (GST_OBJECT (ogg), GST_FORMAT_TIME,
               ogg->total_time));
     } else {
+      GST_LOG_OBJECT (ogg, "Sending EOS, at end of stream");
       gst_ogg_demux_send_event (ogg, gst_event_new_eos ());
     }
     goto pause;
   }
 
   ret = gst_pad_pull_range (ogg->sinkpad, ogg->offset, CHUNKSIZE, &buffer);
-  if (ret != GST_FLOW_OK)
+  if (ret != GST_FLOW_OK) {
+    GST_LOG_OBJECT (ogg, "Failed pull_range");
     goto pause;
+  }
 
   ogg->offset += GST_BUFFER_SIZE (buffer);
 
   ret = gst_ogg_demux_chain (ogg->sinkpad, buffer);
-  if (ret != GST_FLOW_OK)
+  if (ret != GST_FLOW_OK) {
+    GST_LOG_OBJECT (ogg, "Failed demux_chain");
     goto pause;
+  }
 
   return;