summaryrefslogtreecommitdiffstats
path: root/ext
diff options
context:
space:
mode:
authorWim Taymans <wim.taymans@gmail.com>2003-04-16 19:22:30 +0000
committerWim Taymans <wim.taymans@gmail.com>2003-04-16 19:22:30 +0000
commit1aac3cfd1aaf074b76cc7e37c7902bcac436fec0 (patch)
tree3fb4f829c2e9428fc5933620ffaeb9bf47db898a /ext
parentbdd3e254d7ecbfdb4728d06f5d159511adbe42b2 (diff)
downloadgst-plugins-bad-1aac3cfd1aaf074b76cc7e37c7902bcac436fec0.tar.gz
gst-plugins-bad-1aac3cfd1aaf074b76cc7e37c7902bcac436fec0.tar.bz2
gst-plugins-bad-1aac3cfd1aaf074b76cc7e37c7902bcac436fec0.zip
Fix 110963
Original commit message from CVS: Fix 110963 - fix refcounting in colorspace
Diffstat (limited to 'ext')
-rw-r--r--ext/hermes/gstcolorspace.c41
1 files changed, 29 insertions, 12 deletions
diff --git a/ext/hermes/gstcolorspace.c b/ext/hermes/gstcolorspace.c
index 53b4cc8d..f99525e8 100644
--- a/ext/hermes/gstcolorspace.c
+++ b/ext/hermes/gstcolorspace.c
@@ -271,14 +271,19 @@ gst_colorspace_getcaps (GstPad *pad, GstCaps *caps)
GstColorspace *space;
GstCaps *result;
GstCaps *peercaps;
- GstCaps *ourcaps;
+ GstCaps *ourcaps, *temp;
space = GST_COLORSPACE (gst_pad_get_parent (pad));
/* we can do everything our peer can... */
- peercaps = gst_caps_copy (gst_pad_get_allowed_caps (space->srcpad));
+ temp = gst_pad_get_allowed_caps (space->srcpad);
+ peercaps = gst_caps_copy (temp);
+ gst_caps_unref (temp);
+
/* and our own template of course */
- ourcaps = gst_caps_copy (gst_pad_get_pad_template_caps (pad));
+ temp = gst_pad_get_pad_template_caps (pad);
+ ourcaps = gst_caps_copy (temp);
+ gst_caps_unref (temp);
/* merge them together, we prefer the peercaps first */
result = gst_caps_prepend (ourcaps, peercaps);
@@ -303,14 +308,17 @@ gst_colorspace_sinkconnect (GstPad *pad, GstCaps *caps)
GST_INFO (GST_CAT_PROPERTIES, "size: %dx%d", space->width, space->height);
- space->sinkcaps = caps;
+ gst_caps_replace_sink (&space->sinkcaps, caps);
peer = gst_pad_get_peer (pad);
if (peer) {
- if (gst_colorspace_srcconnect_func (pad, gst_pad_get_allowed_caps (space->srcpad), FALSE) < 1) {
+ GstCaps *allowed = gst_pad_get_allowed_caps (space->srcpad);
+ if (gst_colorspace_srcconnect_func (pad, allowed, FALSE) < 1) {
space->sinkcaps = NULL;
+ gst_caps_unref (allowed);
return GST_PAD_LINK_REFUSED;
}
+ gst_caps_unref (allowed);
}
return GST_PAD_LINK_OK;
@@ -327,7 +335,7 @@ gst_colorspace_srcconnect_func (GstPad *pad, GstCaps *caps, gboolean newcaps)
{
GstColorspace *space;
GstCaps *peercaps;
- GstCaps *ourcaps;
+ GstCaps *ourcaps, *to_intersect, *try_peercaps;
space = GST_COLORSPACE (gst_pad_get_parent (pad));
@@ -348,20 +356,27 @@ gst_colorspace_srcconnect_func (GstPad *pad, GstCaps *caps, gboolean newcaps)
if (gst_pad_try_set_caps (space->srcpad, peercaps) > 0) {
space->type = GST_COLORSPACE_NONE;
space->disabled = FALSE;
+ gst_caps_unref (peercaps);
return GST_PAD_LINK_DONE;
}
+ gst_caps_unref (peercaps);
}
- /* then see what the peer has that matches the size */
- peercaps = gst_caps_intersect (caps,
- GST_CAPS_NEW (
+
+ to_intersect = GST_CAPS_NEW (
"colorspace_filter",
"video/raw",
"width", GST_PROPS_INT (space->width),
"height", GST_PROPS_INT (space->height)
- ));
+ );
+
+ /* then see what the peer has that matches the size */
+ peercaps = gst_caps_intersect (caps, to_intersect);
+ gst_caps_unref (to_intersect);
/* we are looping over the caps, so we have to get rid of the lists */
- peercaps = gst_caps_normalize (peercaps);
+ try_peercaps = gst_caps_normalize (peercaps);
+ gst_caps_unref (peercaps);
+ peercaps = try_peercaps;
/* loop over all possibilities and select the first one we can convert and
* is accepted by the peer */
@@ -369,11 +384,13 @@ gst_colorspace_srcconnect_func (GstPad *pad, GstCaps *caps, gboolean newcaps)
if (colorspace_setup_converter (space, ourcaps, peercaps)) {
if (gst_pad_try_set_caps (space->srcpad, peercaps) > 0) {
space->disabled = FALSE;
+ gst_caps_unref (try_peercaps);
return GST_PAD_LINK_DONE;
}
}
peercaps = peercaps->next;
}
+ gst_caps_unref (try_peercaps);
/* we disable ourself here */
space->disabled = TRUE;
@@ -549,7 +566,7 @@ gst_colorspace_change_state (GstElement *element)
space->converter = NULL;
space->disabled = TRUE;
space->type = GST_COLORSPACE_NONE;
- space->sinkcaps = NULL;
+ gst_caps_replace (&space->sinkcaps, NULL);
break;
}