encoding-profile: Fail to create encoding profile from discoverer info if no streams...
authorSebastian Dröge <sebastian@centricular.com>
Thu, 28 Apr 2016 08:18:23 +0000 (11:18 +0300)
committerSebastian Dröge <sebastian@centricular.com>
Fri, 29 Apr 2016 07:12:06 +0000 (10:12 +0300)
https://bugzilla.gnome.org/show_bug.cgi?id=765708

gst-libs/gst/pbutils/encoding-profile.c

index 8898e5633d1a8a855cb8e0bb5f2c83bd3ada4bc7..06814bb758a4f51ee824fa350bdc13245c172d3f 100644 (file)
@@ -1518,6 +1518,8 @@ add_stream_to_profile (GstEncodingContainerProfile * profile,
         (GstEncodingProfile *) gst_encoding_video_profile_new (caps, NULL,
         NULL, 0);
   } else {
+    GST_WARNING ("Ignoring stream of type '%s'",
+        g_type_name (G_OBJECT_TYPE (sinfo)));
     /* subtitles or other ? ignore for now */
   }
   if (sprofile)
@@ -1547,6 +1549,7 @@ gst_encoding_profile_from_discoverer (GstDiscovererInfo * info)
   GstDiscovererStreamInfo *sinfo;
   GList *streams, *stream;
   GstCaps *caps = NULL;
+  guint n_streams = 0;
 
   if (!info || gst_discoverer_info_get_result (info) != GST_DISCOVERER_OK)
     return NULL;
@@ -1571,9 +1574,17 @@ gst_encoding_profile_from_discoverer (GstDiscovererInfo * info)
       gst_discoverer_container_info_get_streams (GST_DISCOVERER_CONTAINER_INFO
       (sinfo));
   for (stream = streams; stream; stream = stream->next) {
-    add_stream_to_profile (profile, (GstDiscovererStreamInfo *) stream->data);
+    if (add_stream_to_profile (profile,
+            (GstDiscovererStreamInfo *) stream->data))
+      n_streams++;
   }
   gst_discoverer_stream_info_list_free (streams);
 
+  if (n_streams == 0) {
+    GST_ERROR ("Failed to add any streams");
+    g_object_unref (profile);
+    return NULL;
+  }
+
   return (GstEncodingProfile *) profile;
 }