v4l: Make sure to return a subset of the filter caps in getcaps
authorSebastian Dröge <sebastian.droege@collabora.co.uk>
Mon, 16 May 2011 15:44:44 +0000 (17:44 +0200)
committerSebastian Dröge <sebastian.droege@collabora.co.uk>
Mon, 16 May 2011 15:44:44 +0000 (17:44 +0200)
sys/v4l/gstv4lsrc.c

index 0aeb25bca6320f892ffe8cf568533ac760cc63e7..b3ea563cf12db557d5fda579eb690ca2ca1807de 100644 (file)
@@ -371,12 +371,30 @@ gst_v4lsrc_get_caps (GstBaseSrc * src, GstCaps * filter)
   GList *item;
 
   if (!GST_V4L_IS_OPEN (GST_V4LELEMENT (v4lsrc))) {
-    return gst_v4lsrc_get_any_caps ();
+    GstCaps *caps, *intersection;
+
+    caps = gst_v4lsrc_get_any_caps ();
+    if (filter) {
+      intersection =
+          gst_caps_intersect_full (filter, caps, GST_CAPS_INTERSECT_FIRST);
+      gst_caps_unref (caps);
+      caps = intersection;
+    }
+    return caps;
   }
 
   if (!v4lsrc->autoprobe) {
+    GstCaps *caps, *intersection;
+
     /* FIXME: query current caps and return those, with _any appended */
-    return gst_v4lsrc_get_any_caps ();
+    caps = gst_v4lsrc_get_any_caps ();
+    if (filter) {
+      intersection =
+          gst_caps_intersect_full (filter, caps, GST_CAPS_INTERSECT_FIRST);
+      gst_caps_unref (caps);
+      caps = intersection;
+    }
+    return caps;
   }
 
   if (!v4lsrc->colorspaces) {
@@ -451,6 +469,15 @@ gst_v4lsrc_get_caps (GstBaseSrc * src, GstCaps * filter)
     gst_caps_append (list, one);
   }
 
+  if (filter) {
+    GstCaps *intersection;
+
+    intersection =
+        gst_caps_intersect_full (filter, list, GST_CAPS_INTERSECT_FIRST);
+    gst_caps_unref (list);
+    list = intersection;
+  }
+
   return list;
 }