encodebin: Add a audioconverter after the audio resampler.
authorEdward Hervey <edward.hervey@collabora.co.uk>
Thu, 17 Feb 2011 17:11:10 +0000 (18:11 +0100)
committerEdward Hervey <edward.hervey@collabora.co.uk>
Fri, 18 Feb 2011 15:08:55 +0000 (16:08 +0100)
This allows handling non-native-endianness conversion properly.

gst/encoding/gstencodebin.c

index ada95f8f5fecbfb61095946bda9d4afdaaa74b82..0ca3981f2023932d32558bda53187ed8c1ecb244 100644 (file)
@@ -1203,26 +1203,30 @@ _create_stream_group (GstEncodeBin * ebin, GstEncodingProfile * sprof,
     last = cspace;
 
   } else if (GST_IS_ENCODING_AUDIO_PROFILE (sprof)) {
-    GstElement *aconv, *ares, *arate;
+    GstElement *aconv, *ares, *arate, *aconv2;
 
     GST_LOG ("Adding conversion elements for audio stream");
 
     arate = gst_element_factory_make ("audiorate", NULL);
     g_object_set (arate, "tolerance", (guint64) ebin->tolerance, NULL);
     aconv = gst_element_factory_make ("audioconvert", NULL);
+    aconv2 = gst_element_factory_make ("audioconvert", NULL);
     ares = gst_element_factory_make ("audioresample", NULL);
 
-    gst_bin_add_many ((GstBin *) ebin, arate, aconv, ares, NULL);
+    gst_bin_add_many ((GstBin *) ebin, arate, aconv, ares, aconv2, NULL);
     tosync = g_list_append (tosync, arate);
     tosync = g_list_append (tosync, aconv);
     tosync = g_list_append (tosync, ares);
+    tosync = g_list_append (tosync, aconv2);
     if (!fast_element_link (arate, aconv) ||
-        !fast_element_link (aconv, ares) || !fast_element_link (ares, last))
+        !fast_element_link (aconv, ares) ||
+        !fast_element_link (ares, aconv2) || !fast_element_link (aconv2, last))
       goto converter_link_failure;
 
     sgroup->converters = g_list_prepend (sgroup->converters, arate);
     sgroup->converters = g_list_prepend (sgroup->converters, aconv);
     sgroup->converters = g_list_prepend (sgroup->converters, ares);
+    sgroup->converters = g_list_prepend (sgroup->converters, aconv2);
 
     last = arate;
   }