summaryrefslogtreecommitdiffstats
path: root/ext/faad
diff options
context:
space:
mode:
Diffstat (limited to 'ext/faad')
-rw-r--r--ext/faad/gstfaad.c273
1 files changed, 122 insertions, 151 deletions
diff --git a/ext/faad/gstfaad.c b/ext/faad/gstfaad.c
index 3be8fd92..56879070 100644
--- a/ext/faad/gstfaad.c
+++ b/ext/faad/gstfaad.c
@@ -25,53 +25,32 @@
#include "gstfaad.h"
-GST_PAD_TEMPLATE_FACTORY (sink_template,
+GstStaticPadTemplate sink_template = GST_STATIC_PAD_TEMPLATE (
"sink",
GST_PAD_SINK,
GST_PAD_ALWAYS,
- GST_CAPS_NEW (
- "faad_mpeg_templ",
- "audio/mpeg",
- "systemstream", GST_PROPS_BOOLEAN (FALSE),
- "mpegversion", GST_PROPS_LIST (
- GST_PROPS_INT (2),
- GST_PROPS_INT (4)
- )
+ GST_STATIC_CAPS ("audio/mpeg, "
+ "systemstream = (bool) FALSE, "
+ "mpegversion = { (int) 2, (int) 4 }"
)
);
-GST_PAD_TEMPLATE_FACTORY (src_template,
+GstStaticPadTemplate src_template = GST_STATIC_PAD_TEMPLATE (
"src",
GST_PAD_SRC,
GST_PAD_ALWAYS,
- GST_CAPS_NEW (
- "faad_int_templ",
- "audio/x-raw-int",
- "endianness", GST_PROPS_INT (G_BYTE_ORDER),
- "signed", GST_PROPS_BOOLEAN (TRUE),
- "width", GST_PROPS_LIST (
- GST_PROPS_INT (16),
- GST_PROPS_INT (24),
- GST_PROPS_INT (32)
- ),
- "depth", GST_PROPS_LIST (
- GST_PROPS_INT (16),
- GST_PROPS_INT (24),
- GST_PROPS_INT (32)
- ),
- "rate", GST_PROPS_INT_RANGE (8000, 96000),
- "channels", GST_PROPS_INT_RANGE (1, 6)
- ),
- GST_CAPS_NEW (
- "faad_float_templ",
- "audio/x-raw-float",
- "endianness", GST_PROPS_INT (G_BYTE_ORDER),
- "depth", GST_PROPS_LIST (
- GST_PROPS_INT (32), /* float */
- GST_PROPS_INT (64) /* double */
- ),
- "rate", GST_PROPS_INT_RANGE (8000, 96000),
- "channels", GST_PROPS_INT_RANGE (1, 6)
+ GST_STATIC_CAPS ("audio/x-raw-int, "
+ "endianness = (int) BYTE_ORDER, "
+ "signed = (bool) TRUE, "
+ "width = { (int) 16, (int) 24, (int) 32 }, "
+ "depth = { (int) 16, (int) 24, (int) 32 }, "
+ "rate = (int) [ 8000, 96000 ], "
+ "channels = (int) [ 1, 6 ];"
+ "audio/x-raw-float, "
+ "endianness = (int) BYTE_ORDER, "
+ "depth = { (int) 32, (int) 64 }, "
+ "rate = (int) [ 8000, 96000 ], "
+ "channels = (int) [ 1, 6 ];"
)
);
@@ -81,12 +60,11 @@ static void gst_faad_init (GstFaad *faad);
static GstPadLinkReturn
gst_faad_sinkconnect (GstPad *pad,
- GstCaps *caps);
+ const GstCaps *caps);
static GstPadLinkReturn
gst_faad_srcconnect (GstPad *pad,
- GstCaps *caps);
-static GstCaps *gst_faad_srcgetcaps (GstPad *pad,
- GstCaps *caps);
+ const GstCaps *caps);
+static GstCaps *gst_faad_srcgetcaps (GstPad *pad);
static void gst_faad_chain (GstPad *pad,
GstData *data);
static GstElementStateReturn
@@ -133,9 +111,9 @@ gst_faad_base_init (GstFaadClass *klass)
GstElementClass *element_class = GST_ELEMENT_CLASS (klass);
gst_element_class_add_pad_template (element_class,
- GST_PAD_TEMPLATE_GET (src_template));
+ gst_static_pad_template_get (&src_template));
gst_element_class_add_pad_template (element_class,
- GST_PAD_TEMPLATE_GET (sink_template));
+ gst_static_pad_template_get (&sink_template));
gst_element_class_set_details (element_class, &gst_faad_details);
}
@@ -160,13 +138,13 @@ gst_faad_init (GstFaad *faad)
GST_FLAG_SET (faad, GST_ELEMENT_EVENT_AWARE);
faad->sinkpad = gst_pad_new_from_template (
- GST_PAD_TEMPLATE_GET (sink_template), "sink");
+ gst_static_pad_template_get (&sink_template), "sink");
gst_element_add_pad (GST_ELEMENT (faad), faad->sinkpad);
gst_pad_set_chain_function (faad->sinkpad, gst_faad_chain);
gst_pad_set_link_function (faad->sinkpad, gst_faad_sinkconnect);
faad->srcpad = gst_pad_new_from_template (
- GST_PAD_TEMPLATE_GET (src_template), "src");
+ gst_static_pad_template_get (&src_template), "src");
gst_element_add_pad (GST_ELEMENT (faad), faad->srcpad);
gst_pad_set_link_function (faad->srcpad, gst_faad_srcconnect);
@@ -179,19 +157,15 @@ gst_faad_init (GstFaad *faad)
static GstPadLinkReturn
gst_faad_sinkconnect (GstPad *pad,
- GstCaps *caps)
+ const GstCaps *caps)
{
- if (!GST_CAPS_IS_FIXED (caps))
- return GST_PAD_LINK_DELAYED;
-
/* oh, we really don't care what's in here. We'll
* get AAC audio (MPEG-2/4) anyway, so why bother? */
return GST_PAD_LINK_OK;
}
static GstCaps *
-gst_faad_srcgetcaps (GstPad *pad,
- GstCaps *caps)
+gst_faad_srcgetcaps (GstPad *pad)
{
GstFaad *faad = GST_FAAD (gst_pad_get_parent (pad));
@@ -204,149 +178,146 @@ gst_faad_srcgetcaps (GstPad *pad,
switch (conf->outputFormat) {
case FAAD_FMT_16BIT:
- caps = GST_CAPS_NEW ("faad_src_int16",
- "audio/x-raw-int",
- "signed", GST_PROPS_BOOLEAN (TRUE),
- "width", GST_PROPS_INT (16),
- "depth", GST_PROPS_INT (16));
+ caps = gst_caps_new_simple ("audio/x-raw-int",
+ "signed", G_TYPE_BOOLEAN, TRUE,
+ "width", G_TYPE_INT, 16,
+ "depth", G_TYPE_INT, 16,
+ NULL);
break;
case FAAD_FMT_24BIT:
- caps = GST_CAPS_NEW ("faad_src_int24",
- "audio/x-raw-int",
- "signed", GST_PROPS_BOOLEAN (TRUE),
- "width", GST_PROPS_INT (24),
- "depth", GST_PROPS_INT (24));
+ caps = gst_caps_new_simple ("audio/x-raw-int",
+ "signed", G_TYPE_BOOLEAN, TRUE,
+ "width", G_TYPE_INT, 24,
+ "depth", G_TYPE_INT, 24,
+ NULL);
break;
case FAAD_FMT_32BIT:
- caps = GST_CAPS_NEW ("faad_src_int32",
- "audio/x-raw-int",
- "signed", GST_PROPS_BOOLEAN (TRUE),
- "width", GST_PROPS_INT (32),
- "depth", GST_PROPS_INT (32));
+ caps = gst_caps_new_simple ("audio/x-raw-int",
+ "signed", G_TYPE_BOOLEAN, TRUE,
+ "width", G_TYPE_INT, 32,
+ "depth", G_TYPE_INT, 32,
+ NULL);
break;
case FAAD_FMT_FLOAT:
- caps = GST_CAPS_NEW ("faad_src_float32",
- "audio/x-raw-float",
- "depth", GST_PROPS_INT (32));
+ caps = gst_caps_new_simple ("audio/x-raw-float",
+ "depth", G_TYPE_INT, 32,
+ NULL);
break;
case FAAD_FMT_DOUBLE:
- caps = GST_CAPS_NEW ("faad_src_float64",
- "audio/x-raw-float",
- "depth", GST_PROPS_INT (64));
+ caps = gst_caps_new_simple ("audio/x-raw-float",
+ "depth", G_TYPE_INT, 64,
+ NULL);
break;
default:
- caps = GST_CAPS_NONE;
+ caps = gst_caps_new_empty ();
break;
}
- if (caps) {
- GstPropsEntry *samplerate, *channels, *endianness;
+ if (!gst_caps_is_empty (caps)) {
+ GstStructure *structure = gst_caps_get_structure (caps, 0);
if (faad->samplerate != -1) {
- samplerate = gst_props_entry_new ("rate",
- GST_PROPS_INT (faad->samplerate));
+ gst_structure_set (structure,
+ "rate", G_TYPE_INT, faad->samplerate,
+ NULL);
} else {
- samplerate = gst_props_entry_new ("rate",
- GST_PROPS_INT_RANGE (8000, 96000));
+ gst_structure_set (structure,
+ "rate", GST_TYPE_INT_RANGE, 8000, 96000,
+ NULL);
}
- gst_props_add_entry (caps->properties, samplerate);
if (faad->channels != -1) {
- channels = gst_props_entry_new ("channels",
- GST_PROPS_INT (faad->channels));
+ gst_structure_set (structure,
+ "channels", G_TYPE_INT, faad->channels,
+ NULL);
} else {
- channels = gst_props_entry_new ("channels",
- GST_PROPS_INT_RANGE (1, 6));
+ gst_structure_set (structure,
+ "channels", GST_TYPE_INT_RANGE, 1, 6,
+ NULL);
}
- gst_props_add_entry (caps->properties, channels);
- endianness = gst_props_entry_new ("endianness",
- GST_PROPS_INT (G_BYTE_ORDER));
- gst_props_add_entry (caps->properties, endianness);
+ gst_structure_set (structure,
+ "endianness", G_TYPE_INT, G_BYTE_ORDER,
+ NULL);
}
return caps;
}
- return gst_pad_template_get_caps (
- GST_PAD_TEMPLATE_GET (src_template));
+ return GST_PAD_TEMPLATE_CAPS (GST_PAD_PAD_TEMPLATE (pad));
}
static GstPadLinkReturn
gst_faad_srcconnect (GstPad *pad,
- GstCaps *caps)
+ const GstCaps *caps)
{
+ GstStructure *structure;
+ const gchar *mimetype;
+ gint fmt;
+ gint depth;
GstFaad *faad = GST_FAAD (gst_pad_get_parent (pad));
- GstCaps *t;
if (!faad->handle ||
(faad->samplerate == -1 || faad->channels == -1)) {
return GST_PAD_LINK_DELAYED;
}
- /* we do samplerate/channels ourselves */
- for (t = caps; t != NULL; t = t->next) {
- gst_props_remove_entry_by_name (t->properties, "rate");
- gst_props_remove_entry_by_name (t->properties, "channels");
- }
-
- /* go through list */
- caps = gst_caps_normalize (caps);
- for ( ; caps != NULL; caps = caps->next) {
- const gchar *mimetype = gst_caps_get_mime (caps);
- gint depth = 0, fmt = 0;
-
- if (!strcmp (mimetype, "audio/x-raw-int")) {
- gint width = 0;
-
- if (gst_caps_has_fixed_property (caps, "depth") &&
- gst_caps_has_fixed_property (caps, "width"))
- gst_caps_get (caps, "depth", &depth,
- "width", &width, NULL);
- if (depth != width)
- continue;
-
- switch (depth) {
- case 16:
- fmt = FAAD_FMT_16BIT;
- break;
- case 24:
- fmt = FAAD_FMT_24BIT;
- break;
- case 32:
- fmt = FAAD_FMT_32BIT;
- break;
- }
- } else {
- if (gst_caps_has_fixed_property (caps, "depth"))
- gst_caps_get_int (caps, "depth", &depth);
-
- switch (depth) {
- case 32:
- fmt = FAAD_FMT_FLOAT;
- break;
- case 64:
- fmt = FAAD_FMT_DOUBLE;
+ structure = gst_caps_get_structure (caps, 0);
+ mimetype = gst_structure_get_name (structure);
+
+ if (!strcmp (mimetype, "audio/x-raw-int")) {
+ gint width;
+
+ if (!gst_structure_get_int (structure, "depth", &depth) ||
+ !gst_structure_get_int (structure, "width", &width))
+ return GST_PAD_LINK_REFUSED;
+ if (depth != width)
+ return GST_PAD_LINK_REFUSED;
+
+ switch (depth) {
+ case 16:
+ fmt = FAAD_FMT_16BIT;
+ break;
+ case 24:
+ fmt = FAAD_FMT_24BIT;
+ break;
+ case 32:
+ fmt = FAAD_FMT_32BIT;
+ break;
+ }
+ } else {
+ if (!gst_structure_get_int (structure, "depth", &depth))
+ return GST_PAD_LINK_REFUSED;
+
+ switch (depth) {
+ case 32:
+ fmt = FAAD_FMT_FLOAT;
+ break;
+ case 64:
+ fmt = FAAD_FMT_DOUBLE;
break;
- }
}
+ }
- if (fmt) {
- GstCaps *newcaps;
- faacDecConfiguration *conf;
-
- conf = faacDecGetCurrentConfiguration (faad->handle);
- conf->outputFormat = fmt;
- faacDecSetConfiguration (faad->handle, conf);
- /* FIXME: handle return value, how? */
+ if (fmt) {
+ GstCaps *newcaps, *intersect;
+ faacDecConfiguration *conf;
- newcaps = gst_faad_srcgetcaps (pad, NULL);
- g_assert (GST_CAPS_IS_FIXED (newcaps));
- if (gst_pad_try_set_caps (pad, newcaps) > 0) {
- faad->bps = depth / 8;
- return GST_PAD_LINK_DONE;
- }
+ conf = faacDecGetCurrentConfiguration (faad->handle);
+ conf->outputFormat = fmt;
+ faacDecSetConfiguration (faad->handle, conf);
+ /* FIXME: handle return value, how? */
+
+ newcaps = gst_faad_srcgetcaps (pad);
+ g_assert (gst_caps_is_fixed (newcaps));
+ intersect = gst_caps_intersect (newcaps, caps);
+ gst_caps_free (newcaps);
+ if (!gst_caps_is_empty (intersect)) {
+ gst_caps_free (intersect);
+ faad->bps = depth / 8;
+ return GST_PAD_LINK_OK;
}
+ gst_caps_free (intersect);
}
return GST_PAD_LINK_REFUSED;