mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 22:48:49 +00:00
alaw/mulaw: Don't require both, rate and channel, to be set in _getcaps
Fixes bug #572358.
This commit is contained in:
parent
6756475fd3
commit
b3a90202c1
2 changed files with 20 additions and 24 deletions
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue