alaw/mulaw: Don't require both, rate and channel, to be set in _getcaps

Fixes bug #572358.
This commit is contained in:
Olivier Crete 2009-02-22 18:46:03 +01:00 committed by Sebastian Dröge
parent 6756475fd3
commit b3a90202c1
2 changed files with 20 additions and 24 deletions

View file

@ -318,8 +318,8 @@ gst_alaw_enc_getcaps (GstPad * pad)
GstStructure *structure; GstStructure *structure;
const GValue *orate, *ochans; const GValue *orate, *ochans;
const GValue *rate, *chans; const GValue *rate, *chans;
GValue irate = { 0 }, ichans = { GValue irate = { 0 };
0}; GValue ichans = { 0 };
if (gst_caps_is_empty (othercaps) || gst_caps_is_any (othercaps)) if (gst_caps_is_empty (othercaps) || gst_caps_is_any (othercaps))
goto done; goto done;
@ -327,22 +327,20 @@ gst_alaw_enc_getcaps (GstPad * pad)
structure = gst_caps_get_structure (othercaps, 0); structure = gst_caps_get_structure (othercaps, 0);
orate = gst_structure_get_value (structure, "rate"); orate = gst_structure_get_value (structure, "rate");
ochans = gst_structure_get_value (structure, "channels"); ochans = gst_structure_get_value (structure, "channels");
if (!orate || !ochans)
goto done;
structure = gst_caps_get_structure (base_caps, 0); structure = gst_caps_get_structure (base_caps, 0);
rate = gst_structure_get_value (structure, "rate"); rate = gst_structure_get_value (structure, "rate");
chans = gst_structure_get_value (structure, "channels"); chans = gst_structure_get_value (structure, "channels");
if (!rate || !chans)
goto done;
if (orate) {
gst_value_intersect (&irate, orate, rate); gst_value_intersect (&irate, orate, rate);
gst_value_intersect (&ichans, ochans, chans);
/* Set the samplerate/channels on the to-be-returned caps */
structure = gst_caps_get_structure (base_caps, 0);
gst_structure_set_value (structure, "rate", &irate); gst_structure_set_value (structure, "rate", &irate);
}
if (ochans) {
gst_value_intersect (&ichans, ochans, chans);
gst_structure_set_value (structure, "channels", &ichans); gst_structure_set_value (structure, "channels", &ichans);
}
done: done:
gst_caps_unref (othercaps); gst_caps_unref (othercaps);

View file

@ -75,8 +75,8 @@ mulawenc_getcaps (GstPad * pad)
GstStructure *structure; GstStructure *structure;
const GValue *orate, *ochans; const GValue *orate, *ochans;
const GValue *rate, *chans; const GValue *rate, *chans;
GValue irate = { 0 }, ichans = { GValue irate = { 0 };
0}; GValue ichans = { 0 };
if (gst_caps_is_empty (othercaps) || gst_caps_is_any (othercaps)) if (gst_caps_is_empty (othercaps) || gst_caps_is_any (othercaps))
goto done; goto done;
@ -84,22 +84,20 @@ mulawenc_getcaps (GstPad * pad)
structure = gst_caps_get_structure (othercaps, 0); structure = gst_caps_get_structure (othercaps, 0);
orate = gst_structure_get_value (structure, "rate"); orate = gst_structure_get_value (structure, "rate");
ochans = gst_structure_get_value (structure, "channels"); ochans = gst_structure_get_value (structure, "channels");
if (!orate || !ochans)
goto done;
structure = gst_caps_get_structure (base_caps, 0); structure = gst_caps_get_structure (base_caps, 0);
rate = gst_structure_get_value (structure, "rate"); rate = gst_structure_get_value (structure, "rate");
chans = gst_structure_get_value (structure, "channels"); chans = gst_structure_get_value (structure, "channels");
if (!rate || !chans)
goto done;
if (orate) {
gst_value_intersect (&irate, orate, rate); gst_value_intersect (&irate, orate, rate);
gst_value_intersect (&ichans, ochans, chans);
/* Set the samplerate/channels on the to-be-returned caps */
structure = gst_caps_get_structure (base_caps, 0);
gst_structure_set_value (structure, "rate", &irate); gst_structure_set_value (structure, "rate", &irate);
}
if (ochans) {
gst_value_intersect (&ichans, ochans, chans);
gst_structure_set_value (structure, "channels", &ichans); gst_structure_set_value (structure, "channels", &ichans);
}
done: done:
gst_caps_unref (othercaps); gst_caps_unref (othercaps);