factorylist: Use gst_caps_can_intersect() instead of _intersect()

This is faster and results in less allocations.
This commit is contained in:
Sebastian Dröge 2009-09-24 16:05:58 +02:00
parent 999483b454
commit 24b7d2500c

View file

@ -240,7 +240,6 @@ gst_factory_list_filter (GValueArray * array, const GstCaps * caps)
/* we only care about the sink templates */ /* we only care about the sink templates */
if (templ->direction == GST_PAD_SINK) { if (templ->direction == GST_PAD_SINK) {
GstCaps *intersect;
GstCaps *tmpl_caps; GstCaps *tmpl_caps;
/* try to intersect the caps with the caps of the template */ /* try to intersect the caps with the caps of the template */
@ -248,21 +247,19 @@ gst_factory_list_filter (GValueArray * array, const GstCaps * caps)
/* FIXME, intersect is not the right method, we ideally want to check /* FIXME, intersect is not the right method, we ideally want to check
* for a subset here */ * for a subset here */
intersect = gst_caps_intersect (caps, tmpl_caps);
gst_caps_unref (tmpl_caps);
/* check if the intersection is empty */ /* check if the intersection is empty */
if (!gst_caps_is_empty (intersect)) { if (gst_caps_can_intersect (caps, tmpl_caps)) {
/* non empty intersection, we can use this element */ /* non empty intersection, we can use this element */
GValue resval = { 0, }; GValue resval = { 0, };
g_value_init (&resval, G_TYPE_OBJECT); g_value_init (&resval, G_TYPE_OBJECT);
g_value_set_object (&resval, factory); g_value_set_object (&resval, factory);
g_value_array_append (result, &resval); g_value_array_append (result, &resval);
g_value_unset (&resval); g_value_unset (&resval);
gst_caps_unref (intersect); gst_caps_unref (tmpl_caps);
break; break;
} }
gst_caps_unref (intersect); gst_caps_unref (tmpl_caps);
} }
} }
} }