summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRonald S. Bultje <rbultje@ronald.bitfreak.net>2004-01-25 12:31:29 +0000
committerRonald S. Bultje <rbultje@ronald.bitfreak.net>2004-01-25 12:31:29 +0000
commite202a025fe28c6339fb10092fc80ff983f941691 (patch)
tree85c7d5defca93cc5047370cb2a55349b2e6f1322
parenta77fcb5d88102e0674add81df2d1a999b107a715 (diff)
downloadgstreamer-plugins-bad-e202a025fe28c6339fb10092fc80ff983f941691.tar.gz
ext/divx/gstdivxdec.c: Fix for new capsnego - also fixes gst-player with divxdec.
Original commit message from CVS: 2004-01-25 Ronald Bultje <rbultje@ronald.bitfreak.net> * ext/divx/gstdivxdec.c: (gst_divxdec_init), (gst_divxdec_negotiate): Fix for new capsnego - also fixes gst-player with divxdec.
-rw-r--r--ChangeLog6
-rw-r--r--ext/divx/gstdivxdec.c11
2 files changed, 10 insertions, 7 deletions
diff --git a/ChangeLog b/ChangeLog
index a85068e0e..05c176221 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2004-01-25 Ronald Bultje <rbultje@ronald.bitfreak.net>
+
+ * ext/divx/gstdivxdec.c: (gst_divxdec_init),
+ (gst_divxdec_negotiate):
+ Fix for new capsnego - also fixes gst-player with divxdec.
+
2004-01-25 Julien MOUTTE <julien@moutte.net>
* gst-libs/gst/play/gstplay.c: (gst_play_pipeline_setup),
diff --git a/ext/divx/gstdivxdec.c b/ext/divx/gstdivxdec.c
index 869858a27..192c655e5 100644
--- a/ext/divx/gstdivxdec.c
+++ b/ext/divx/gstdivxdec.c
@@ -173,7 +173,6 @@ gst_divxdec_init (GstDivxDec *divxdec)
gst_static_pad_template_get (&sink_template),
"sink");
gst_element_add_pad(GST_ELEMENT(divxdec), divxdec->sinkpad);
-
gst_pad_set_chain_function(divxdec->sinkpad, gst_divxdec_chain);
gst_pad_set_link_function(divxdec->sinkpad, gst_divxdec_connect);
@@ -182,6 +181,7 @@ gst_divxdec_init (GstDivxDec *divxdec)
gst_static_pad_template_get (&src_template),
"src");
gst_element_add_pad(GST_ELEMENT(divxdec), divxdec->srcpad);
+ gst_pad_use_explicit_caps (divxdec->srcpad);
/* bitrate, etc. */
divxdec->width = divxdec->height = divxdec->csp = divxdec->bitcnt = -1;
@@ -324,7 +324,6 @@ gst_divxdec_chain (GstPad *pad,
static GstPadLinkReturn
gst_divxdec_negotiate (GstDivxDec *divxdec)
{
- GstPadLinkReturn ret;
GstCaps *caps;
struct {
guint32 fourcc;
@@ -414,14 +413,12 @@ gst_divxdec_negotiate (GstDivxDec *divxdec)
NULL);
/*}*/
- if ((ret = gst_pad_try_set_caps(divxdec->srcpad, caps)) > 0) {
+ if (gst_divxdec_setup(divxdec) &&
+ gst_pad_set_explicit_caps(divxdec->srcpad, caps)) {
divxdec->csp = fmt_list[i].csp;
divxdec->bpp = fmt_list[i].bpp;
divxdec->bitcnt = fmt_list[i].bitcnt;
- if (gst_divxdec_setup(divxdec))
- return GST_PAD_LINK_OK;
- } else if (ret == GST_PAD_LINK_DELAYED) {
- return ret; /* trying more is useless */
+ return GST_PAD_LINK_OK;
}
}