summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--gst/videodrop/gstvideodrop.c50
2 files changed, 54 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 316ae160..2b311ec1 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2004-01-08 David Schleef <ds@schleef.org>
+
+ * gst/videodrop/gstvideodrop.c: (gst_videodrop_getcaps),
+ (gst_videodrop_link), (gst_videodrop_init): Fix negotiation.
+
2004-01-08 Julien MOUTTE,,, <julien@moutte.net>
* sys/ximage/ximagesink.c: (gst_ximagesink_handle_xevents): A
diff --git a/gst/videodrop/gstvideodrop.c b/gst/videodrop/gstvideodrop.c
index 05c23220..e3dd45a7 100644
--- a/gst/videodrop/gstvideodrop.c
+++ b/gst/videodrop/gstvideodrop.c
@@ -146,21 +146,67 @@ gst_videodrop_class_init (GstVideodropClass *klass)
name), \
min, max)
+static GstCaps *
+gst_videodrop_getcaps (GstPad *pad)
+{
+ GstVideodrop *videodrop;
+ GstPad *otherpad;
+ GstCaps *caps;
+ int i;
+ GstStructure *structure;
+
+ videodrop = GST_VIDEODROP (gst_pad_get_parent (pad));
+
+ otherpad = (pad == videodrop->srcpad) ? videodrop->sinkpad :
+ videodrop->srcpad;
+
+ caps = gst_pad_get_allowed_caps (otherpad);
+ for (i=0;i<gst_caps_get_size(caps);i++) {
+ structure = gst_caps_get_structure (caps, i);
+
+ gst_structure_set (structure,
+ "framerate", GST_TYPE_DOUBLE_RANGE, 0.0, G_MAXDOUBLE, NULL);
+ }
+
+ return caps;
+}
+
static GstPadLinkReturn
gst_videodrop_link (GstPad *pad, const GstCaps *caps)
{
GstVideodrop *videodrop;
GstStructure *structure;
+ GstPadLinkReturn link_ret;
gboolean ret;
double fps;
+ double otherfps;
+ GstPad *otherpad;
+ GstCaps *othercaps;
videodrop = GST_VIDEODROP (gst_pad_get_parent (pad));
+ otherpad = (pad == videodrop->srcpad) ? videodrop->sinkpad :
+ videodrop->srcpad;
+
structure = gst_caps_get_structure (caps, 0);
ret = gst_structure_get_double (structure, "framerate", &fps);
-
if (!ret) return GST_PAD_LINK_REFUSED;
+ if (gst_pad_is_negotiated (otherpad)) {
+ othercaps = gst_caps_copy (caps);
+ if (pad == videodrop->srcpad) {
+ otherfps = videodrop->from_fps;
+ } else {
+ otherfps = videodrop->to_fps;
+ }
+ gst_caps_set_simple (othercaps,
+ "framerate", G_TYPE_DOUBLE, otherfps, NULL);
+ link_ret = gst_pad_try_set_caps (otherpad, othercaps);
+ if (GST_PAD_LINK_FAILED (link_ret)) {
+ return link_ret;
+ }
+ }
+
if (pad == videodrop->srcpad) {
videodrop->to_fps = fps;
} else {
@@ -178,11 +224,13 @@ gst_videodrop_init (GstVideodrop *videodrop)
gst_static_pad_template_get (&gst_videodrop_sink_template), "sink");
gst_element_add_pad (GST_ELEMENT (videodrop), videodrop->sinkpad);
gst_pad_set_chain_function (videodrop->sinkpad, gst_videodrop_chain);
+ gst_pad_set_getcaps_function (videodrop->sinkpad, gst_videodrop_getcaps);
gst_pad_set_link_function (videodrop->sinkpad, gst_videodrop_link);
videodrop->srcpad = gst_pad_new_from_template (
gst_static_pad_template_get (&gst_videodrop_src_template), "src");
gst_element_add_pad (GST_ELEMENT(videodrop), videodrop->srcpad);
+ gst_pad_set_getcaps_function (videodrop->srcpad, gst_videodrop_getcaps);
gst_pad_set_link_function (videodrop->srcpad, gst_videodrop_link);
videodrop->inited = FALSE;