mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-19 13:55:41 +00:00
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.
This commit is contained in:
parent
a77fcb5d88
commit
e202a025fe
2 changed files with 10 additions and 7 deletions
|
@ -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>
|
2004-01-25 Julien MOUTTE <julien@moutte.net>
|
||||||
|
|
||||||
* gst-libs/gst/play/gstplay.c: (gst_play_pipeline_setup),
|
* gst-libs/gst/play/gstplay.c: (gst_play_pipeline_setup),
|
||||||
|
|
|
@ -173,7 +173,6 @@ gst_divxdec_init (GstDivxDec *divxdec)
|
||||||
gst_static_pad_template_get (&sink_template),
|
gst_static_pad_template_get (&sink_template),
|
||||||
"sink");
|
"sink");
|
||||||
gst_element_add_pad(GST_ELEMENT(divxdec), divxdec->sinkpad);
|
gst_element_add_pad(GST_ELEMENT(divxdec), divxdec->sinkpad);
|
||||||
|
|
||||||
gst_pad_set_chain_function(divxdec->sinkpad, gst_divxdec_chain);
|
gst_pad_set_chain_function(divxdec->sinkpad, gst_divxdec_chain);
|
||||||
gst_pad_set_link_function(divxdec->sinkpad, gst_divxdec_connect);
|
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),
|
gst_static_pad_template_get (&src_template),
|
||||||
"src");
|
"src");
|
||||||
gst_element_add_pad(GST_ELEMENT(divxdec), divxdec->srcpad);
|
gst_element_add_pad(GST_ELEMENT(divxdec), divxdec->srcpad);
|
||||||
|
gst_pad_use_explicit_caps (divxdec->srcpad);
|
||||||
|
|
||||||
/* bitrate, etc. */
|
/* bitrate, etc. */
|
||||||
divxdec->width = divxdec->height = divxdec->csp = divxdec->bitcnt = -1;
|
divxdec->width = divxdec->height = divxdec->csp = divxdec->bitcnt = -1;
|
||||||
|
@ -324,7 +324,6 @@ gst_divxdec_chain (GstPad *pad,
|
||||||
static GstPadLinkReturn
|
static GstPadLinkReturn
|
||||||
gst_divxdec_negotiate (GstDivxDec *divxdec)
|
gst_divxdec_negotiate (GstDivxDec *divxdec)
|
||||||
{
|
{
|
||||||
GstPadLinkReturn ret;
|
|
||||||
GstCaps *caps;
|
GstCaps *caps;
|
||||||
struct {
|
struct {
|
||||||
guint32 fourcc;
|
guint32 fourcc;
|
||||||
|
@ -414,14 +413,12 @@ gst_divxdec_negotiate (GstDivxDec *divxdec)
|
||||||
NULL);
|
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->csp = fmt_list[i].csp;
|
||||||
divxdec->bpp = fmt_list[i].bpp;
|
divxdec->bpp = fmt_list[i].bpp;
|
||||||
divxdec->bitcnt = fmt_list[i].bitcnt;
|
divxdec->bitcnt = fmt_list[i].bitcnt;
|
||||||
if (gst_divxdec_setup(divxdec))
|
|
||||||
return GST_PAD_LINK_OK;
|
return GST_PAD_LINK_OK;
|
||||||
} else if (ret == GST_PAD_LINK_DELAYED) {
|
|
||||||
return ret; /* trying more is useless */
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue