ext/lame/gstlame.c: Fix up bitrate checking macro. Make it give us a

Original commit message from CVS:
* ext/lame/gstlame.c: (gst_lame_sink_setcaps),
(gst_lame_set_property), (gst_lame_setup):
Fix up bitrate checking macro.  Make it give us a
GST_ELEMENT_WARNING message so the application has a chance of
reporting this to the user.  Move the checking to _setup, so we
are sure it runs in the READY state, when we hope to have a pipeline
and a bus that is not flushing.
This fixes e.g. using 96 kbit/sec as a bitrate.
This commit is contained in:
Thomas Vander Stichele 2007-02-21 16:02:33 +00:00
parent 16c774ff13
commit d092f55b65

View file

@ -551,7 +551,7 @@ zero_output_rate:
setup_failed: setup_failed:
{ {
GST_ELEMENT_ERROR (lame, LIBRARY, SETTINGS, GST_ELEMENT_ERROR (lame, LIBRARY, SETTINGS,
(_("Failed to configure LAME encoder. Check your encoding parameters.")), ("Failed to configure LAME encoder. Check your encoding parameters.")); (_("Failed to configure LAME encoder. Check your encoding parameters.")), NULL);
return FALSE; return FALSE;
} }
} }
@ -648,21 +648,37 @@ init_error:
} }
} }
#define CHECK_AND_FIXUP_BITRATE(obj,pspec,rate) \ /* <php-emulation-mode>three underscores for ___rate is really really really
* private as opposed to one underscore<php-emulation-mode> */
/* call this MACRO outside of the NULL state so that we have a higher chance
* of actually having a pipeline and bus to get the message through */
#define CHECK_AND_FIXUP_BITRATE(obj,param,rate) \
G_STMT_START { \ G_STMT_START { \
gint ___rate = rate; \ gint ___rate = rate; \
if (rate <= 64 && (rate % 8) != 0) { \ gint maxrate; \
___rate = GST_ROUND_UP_8 (rate); \ gint multiplier; \
} else if (rate <= 128 && (rate % 16) != 0) { \ if (rate <= 64) { \
___rate = GST_ROUND_UP_16 (rate); \ maxrate = 64; multiplier = 8; \
} else if (rate <= 256 && (rate % 32) != 0) { \ if ((rate % 8) != 0) ___rate = GST_ROUND_UP_8 (rate); \
___rate = GST_ROUND_UP_32 (rate); \ } else if (rate <= 128) { \
} else if (rate <= 320 && (rate % 64) != 0) { \ maxrate = 128; multiplier = 16; \
___rate = GST_ROUND_UP_64 (rate); \ if ((rate % 16) != 0) ___rate = GST_ROUND_UP_16 (rate); \
} else if (rate <= 256) { \
maxrate = 256; multiplier = 32; \
if ((rate % 32) != 0) ___rate = GST_ROUND_UP_32 (rate); \
} else if (rate <= 320) { \
maxrate = 320; multiplier = 64; \
if ((rate % 64) != 0) ___rate = GST_ROUND_UP_64 (rate); \
} \ } \
if (___rate != rate) { \ if (___rate != rate) { \
GST_WARNING_OBJECT (obj, "Bitrate %d not allowed for property '%s', " \ GST_ELEMENT_WARNING (obj, LIBRARY, SETTINGS, \
"changing to %d", rate, g_param_spec_get_name (pspec), ___rate); \ (_("The requested bitrate %d kbit/s for property '%s' " \
"is not allowed. " \
"The bitrate was changed to %d kbit/s."), rate, \
param, ___rate), \
("A bitrate below %d should be a multiple of %d.", \
maxrate, multiplier)); \
rate = ___rate; \ rate = ___rate; \
} \ } \
} G_STMT_END } G_STMT_END
@ -678,7 +694,6 @@ gst_lame_set_property (GObject * object, guint prop_id, const GValue * value,
switch (prop_id) { switch (prop_id) {
case ARG_BITRATE: case ARG_BITRATE:
lame->bitrate = g_value_get_int (value); lame->bitrate = g_value_get_int (value);
CHECK_AND_FIXUP_BITRATE (object, pspec, lame->bitrate);
break; break;
case ARG_COMPRESSION_RATIO: case ARG_COMPRESSION_RATIO:
lame->compression_ratio = g_value_get_float (value); lame->compression_ratio = g_value_get_float (value);
@ -727,15 +742,12 @@ gst_lame_set_property (GObject * object, guint prop_id, const GValue * value,
break; break;
case ARG_VBR_MIN_BITRATE: case ARG_VBR_MIN_BITRATE:
lame->vbr_min_bitrate = g_value_get_int (value); lame->vbr_min_bitrate = g_value_get_int (value);
CHECK_AND_FIXUP_BITRATE (object, pspec, lame->vbr_min_bitrate);
break; break;
case ARG_VBR_MAX_BITRATE: case ARG_VBR_MAX_BITRATE:
lame->vbr_max_bitrate = g_value_get_int (value); lame->vbr_max_bitrate = g_value_get_int (value);
CHECK_AND_FIXUP_BITRATE (object, pspec, lame->vbr_max_bitrate);
break; break;
case ARG_VBR_HARD_MIN: case ARG_VBR_HARD_MIN:
lame->vbr_hard_min = g_value_get_int (value); lame->vbr_hard_min = g_value_get_int (value);
CHECK_AND_FIXUP_BITRATE (object, pspec, lame->vbr_hard_min);
break; break;
case ARG_LOWPASS_FREQ: case ARG_LOWPASS_FREQ:
lame->lowpass_freq = g_value_get_int (value); lame->lowpass_freq = g_value_get_int (value);
@ -1136,6 +1148,7 @@ gst_lame_setup (GstLame * lame)
lame->mode = 3; lame->mode = 3;
CHECK_ERROR (lame_set_num_channels (lame->lgf, lame->num_channels)); CHECK_ERROR (lame_set_num_channels (lame->lgf, lame->num_channels));
CHECK_AND_FIXUP_BITRATE (lame, "bitrate", lame->bitrate);
CHECK_ERROR (lame_set_brate (lame->lgf, lame->bitrate)); CHECK_ERROR (lame_set_brate (lame->lgf, lame->bitrate));
CHECK_ERROR (lame_set_compression_ratio (lame->lgf, lame->compression_ratio)); CHECK_ERROR (lame_set_compression_ratio (lame->lgf, lame->compression_ratio));
CHECK_ERROR (lame_set_quality (lame->lgf, lame->quality)); CHECK_ERROR (lame_set_quality (lame->lgf, lame->quality));
@ -1153,10 +1166,13 @@ gst_lame_setup (GstLame * lame)
CHECK_ERROR (lame_set_VBR_q (lame->lgf, lame->vbr_quality)); CHECK_ERROR (lame_set_VBR_q (lame->lgf, lame->vbr_quality));
CHECK_ERROR (lame_set_VBR_mean_bitrate_kbps (lame->lgf, CHECK_ERROR (lame_set_VBR_mean_bitrate_kbps (lame->lgf,
lame->vbr_mean_bitrate)); lame->vbr_mean_bitrate));
CHECK_AND_FIXUP_BITRATE (lame, "vbr-min-bitrate", lame->vbr_min_bitrate);
CHECK_ERROR (lame_set_VBR_min_bitrate_kbps (lame->lgf, CHECK_ERROR (lame_set_VBR_min_bitrate_kbps (lame->lgf,
lame->vbr_min_bitrate)); lame->vbr_min_bitrate));
CHECK_AND_FIXUP_BITRATE (lame, "vbr-max-bitrate", lame->vbr_max_bitrate);
CHECK_ERROR (lame_set_VBR_max_bitrate_kbps (lame->lgf, CHECK_ERROR (lame_set_VBR_max_bitrate_kbps (lame->lgf,
lame->vbr_max_bitrate)); lame->vbr_max_bitrate));
CHECK_AND_FIXUP_BITRATE (lame, "vbr-hard-min", lame->vbr_hard_min);
CHECK_ERROR (lame_set_VBR_hard_min (lame->lgf, lame->vbr_hard_min)); CHECK_ERROR (lame_set_VBR_hard_min (lame->lgf, lame->vbr_hard_min));
CHECK_ERROR (lame_set_lowpassfreq (lame->lgf, lame->lowpass_freq)); CHECK_ERROR (lame_set_lowpassfreq (lame->lgf, lame->lowpass_freq));
CHECK_ERROR (lame_set_lowpasswidth (lame->lgf, lame->lowpass_width)); CHECK_ERROR (lame_set_lowpasswidth (lame->lgf, lame->lowpass_width));