Another duration patch from Joshua (slightly modified by me)
authorRonald S. Bultje <rbultje@ronald.bitfreak.net>
Sat, 7 Jun 2003 00:34:51 +0000 (00:34 +0000)
committerRonald S. Bultje <rbultje@ronald.bitfreak.net>
Sat, 7 Jun 2003 00:34:51 +0000 (00:34 +0000)
Original commit message from CVS:
Another duration patch from Joshua (slightly modified by me)

ext/lame/gstlame.c
ext/lame/gstlame.h

index 3b296987d36c0421966944508d39cc424a971f7a..0c0ab5293206a7abeff770ee921abbf02df666a2 100644 (file)
@@ -653,6 +653,8 @@ gst_lame_chain (GstPad *pad, GstBuffer *buf)
     }
   }
   else {
+    gint64 duration;
+
     if (!lame->initialized) {
       gst_buffer_unref (buf);
       gst_element_error (GST_ELEMENT (lame), "encoder not initialized (input is not audio?)");
@@ -681,9 +683,22 @@ gst_lame_chain (GstPad *pad, GstBuffer *buf)
               "encoded %d bytes of audio to %d bytes of mp3", 
               GST_BUFFER_SIZE (buf), mp3_size);
 
+    duration = (GST_SECOND * GST_BUFFER_SIZE (buf) /
+               (2 * lame->samplerate * lame->num_channels));
+
+    if (GST_BUFFER_DURATION (buf) != GST_CLOCK_TIME_NONE &&
+       GST_BUFFER_DURATION (buf) != duration)
+      GST_DEBUG (GST_CAT_PLUGIN_INFO,
+                "mad: incoming buffer had incorrect duration %lld, "
+                "outgoing buffer will have correct duration %lld",
+                GST_BUFFER_DURATION (buf), duration);
+
     if (lame->last_ts == GST_CLOCK_TIME_NONE) {
-      lame->last_ts   = GST_BUFFER_TIMESTAMP (buf);
-      lame->last_offs = GST_BUFFER_OFFSET (buf);
+      lame->last_ts       = GST_BUFFER_TIMESTAMP (buf);
+      lame->last_offs     = GST_BUFFER_OFFSET (buf);
+      lame->last_duration = duration;
+    } else {
+      lame->last_duration += duration;
     }
 
     gst_buffer_unref (buf);
@@ -695,6 +710,7 @@ gst_lame_chain (GstPad *pad, GstBuffer *buf)
     GST_BUFFER_SIZE (outbuf)      = mp3_size;
     GST_BUFFER_TIMESTAMP (outbuf) = lame->last_ts;
     GST_BUFFER_OFFSET (outbuf)    = lame->last_offs;
+    GST_BUFFER_DURATION (outbuf)  = lame->last_duration;
 
     gst_pad_push (lame->srcpad,outbuf);
 
index 220d61b4c52bca184c2e85696c13826e25edd7e4..d1055a7a5f1257ef93d79b7ccecb1d832c3cc8c4 100644 (file)
@@ -95,7 +95,7 @@ struct _GstLame {
   lame_global_flags *lgf;
 
   /* time tracker */
-  guint64 last_ts, last_offs;
+  guint64 last_ts, last_offs, last_duration;
 };
 
 struct _GstLameClass {