replay_gain: no CamelCase

Renamed functions and variables.
This commit is contained in:
Max Kellermann 2008-11-11 15:55:34 +01:00
parent 54ad08ab37
commit 114b3c1e78
13 changed files with 119 additions and 111 deletions

View File

@ -70,21 +70,21 @@ static void flacParseReplayGain(const FLAC__StreamMetadata * block,
int found = 0; int found = 0;
if (data->replayGainInfo) if (data->replayGainInfo)
freeReplayGainInfo(data->replayGainInfo); replay_gain_info_free(data->replayGainInfo);
data->replayGainInfo = newReplayGainInfo(); data->replayGainInfo = replay_gain_info_new();
found |= flacFindVorbisCommentFloat(block, "replaygain_album_gain", found |= flacFindVorbisCommentFloat(block, "replaygain_album_gain",
&data->replayGainInfo->albumGain); &data->replayGainInfo->album_gain);
found |= flacFindVorbisCommentFloat(block, "replaygain_album_peak", found |= flacFindVorbisCommentFloat(block, "replaygain_album_peak",
&data->replayGainInfo->albumPeak); &data->replayGainInfo->album_peak);
found |= flacFindVorbisCommentFloat(block, "replaygain_track_gain", found |= flacFindVorbisCommentFloat(block, "replaygain_track_gain",
&data->replayGainInfo->trackGain); &data->replayGainInfo->track_gain);
found |= flacFindVorbisCommentFloat(block, "replaygain_track_peak", found |= flacFindVorbisCommentFloat(block, "replaygain_track_peak",
&data->replayGainInfo->trackPeak); &data->replayGainInfo->track_peak);
if (!found) { if (!found) {
freeReplayGainInfo(data->replayGainInfo); replay_gain_info_free(data->replayGainInfo);
data->replayGainInfo = NULL; data->replayGainInfo = NULL;
} }
} }

View File

@ -145,7 +145,7 @@ typedef struct {
FLAC__uint64 position; FLAC__uint64 position;
struct decoder *decoder; struct decoder *decoder;
struct input_stream *inStream; struct input_stream *inStream;
ReplayGainInfo *replayGainInfo; struct replay_gain_info *replayGainInfo;
struct tag *tag; struct tag *tag;
} FlacData; } FlacData;

View File

@ -368,7 +368,7 @@ flac_decode_internal(struct decoder * decoder, struct input_stream *inStream,
fail: fail:
if (data.replayGainInfo) if (data.replayGainInfo)
freeReplayGainInfo(data.replayGainInfo); replay_gain_info_free(data.replayGainInfo);
if (flacDec) if (flacDec)
flac_delete(flacDec); flac_delete(flacDec);

View File

@ -204,16 +204,17 @@ mp3_fill_buffer(struct mp3_data *data)
} }
#ifdef HAVE_ID3TAG #ifdef HAVE_ID3TAG
static ReplayGainInfo *parse_id3_replay_gain_info(struct id3_tag *tag) static struct replay_gain_info *
parse_id3_replay_gain_info(struct id3_tag *tag)
{ {
int i; int i;
char *key; char *key;
char *value; char *value;
struct id3_frame *frame; struct id3_frame *frame;
bool found = false; bool found = false;
ReplayGainInfo *replay_gain_info; struct replay_gain_info *replay_gain_info;
replay_gain_info = newReplayGainInfo(); replay_gain_info = replay_gain_info_new();
for (i = 0; (frame = id3_tag_findframe(tag, "TXXX", i)); i++) { for (i = 0; (frame = id3_tag_findframe(tag, "TXXX", i)); i++) {
if (frame->nfields < 3) if (frame->nfields < 3)
@ -227,16 +228,16 @@ static ReplayGainInfo *parse_id3_replay_gain_info(struct id3_tag *tag)
(&frame->fields[2])); (&frame->fields[2]));
if (strcasecmp(key, "replaygain_track_gain") == 0) { if (strcasecmp(key, "replaygain_track_gain") == 0) {
replay_gain_info->trackGain = atof(value); replay_gain_info->track_gain = atof(value);
found = true; found = true;
} else if (strcasecmp(key, "replaygain_album_gain") == 0) { } else if (strcasecmp(key, "replaygain_album_gain") == 0) {
replay_gain_info->albumGain = atof(value); replay_gain_info->album_gain = atof(value);
found = true; found = true;
} else if (strcasecmp(key, "replaygain_track_peak") == 0) { } else if (strcasecmp(key, "replaygain_track_peak") == 0) {
replay_gain_info->trackPeak = atof(value); replay_gain_info->track_peak = atof(value);
found = true; found = true;
} else if (strcasecmp(key, "replaygain_album_peak") == 0) { } else if (strcasecmp(key, "replaygain_album_peak") == 0) {
replay_gain_info->albumPeak = atof(value); replay_gain_info->album_peak = atof(value);
found = true; found = true;
} }
@ -246,7 +247,7 @@ static ReplayGainInfo *parse_id3_replay_gain_info(struct id3_tag *tag)
if (found) if (found)
return replay_gain_info; return replay_gain_info;
freeReplayGainInfo(replay_gain_info); replay_gain_info_free(replay_gain_info);
return NULL; return NULL;
} }
#endif #endif
@ -254,7 +255,7 @@ static ReplayGainInfo *parse_id3_replay_gain_info(struct id3_tag *tag)
#ifdef HAVE_ID3TAG #ifdef HAVE_ID3TAG
static void mp3_parse_id3(struct mp3_data *data, size_t tagsize, static void mp3_parse_id3(struct mp3_data *data, size_t tagsize,
struct tag **mpd_tag, struct tag **mpd_tag,
ReplayGainInfo **replay_gain_info_r) struct replay_gain_info **replay_gain_info_r)
{ {
struct id3_tag *id3_tag = NULL; struct id3_tag *id3_tag = NULL;
id3_length_t count; id3_length_t count;
@ -307,10 +308,11 @@ static void mp3_parse_id3(struct mp3_data *data, size_t tagsize,
} }
if (replay_gain_info_r) { if (replay_gain_info_r) {
ReplayGainInfo *tmp_rgi = parse_id3_replay_gain_info(id3_tag); struct replay_gain_info *tmp_rgi =
parse_id3_replay_gain_info(id3_tag);
if (tmp_rgi != NULL) { if (tmp_rgi != NULL) {
if (*replay_gain_info_r) if (*replay_gain_info_r)
freeReplayGainInfo(*replay_gain_info_r); replay_gain_info_free(*replay_gain_info_r);
*replay_gain_info_r = tmp_rgi; *replay_gain_info_r = tmp_rgi;
} }
} }
@ -323,7 +325,7 @@ static void mp3_parse_id3(struct mp3_data *data, size_t tagsize,
static enum mp3_action static enum mp3_action
decode_next_frame_header(struct mp3_data *data, struct tag **tag, decode_next_frame_header(struct mp3_data *data, struct tag **tag,
ReplayGainInfo **replay_gain_info_r) struct replay_gain_info **replay_gain_info_r)
{ {
enum mad_layer layer; enum mad_layer layer;
@ -698,7 +700,7 @@ mp3_filesize_to_song_length(struct mp3_data *data)
static bool static bool
mp3_decode_first_frame(struct mp3_data *data, struct tag **tag, mp3_decode_first_frame(struct mp3_data *data, struct tag **tag,
ReplayGainInfo **replay_gain_info_r) struct replay_gain_info **replay_gain_info_r)
{ {
struct decoder *decoder = data->decoder; struct decoder *decoder = data->decoder;
struct xing xing; struct xing xing;
@ -758,9 +760,9 @@ mp3_decode_first_frame(struct mp3_data *data, struct tag **tag,
* parse_lame() for details. -- jat */ * parse_lame() for details. -- jat */
if (replay_gain_info_r && !*replay_gain_info_r && if (replay_gain_info_r && !*replay_gain_info_r &&
lame.track_gain) { lame.track_gain) {
*replay_gain_info_r = newReplayGainInfo(); *replay_gain_info_r = replay_gain_info_new();
(*replay_gain_info_r)->trackGain = lame.track_gain; (*replay_gain_info_r)->track_gain = lame.track_gain;
(*replay_gain_info_r)->trackPeak = lame.peak; (*replay_gain_info_r)->track_peak = lame.peak;
} }
} }
} }
@ -813,7 +815,7 @@ static int mp3_total_file_time(const char *file)
static bool static bool
mp3_open(struct input_stream *is, struct mp3_data *data, mp3_open(struct input_stream *is, struct mp3_data *data,
struct decoder *decoder, struct tag **tag, struct decoder *decoder, struct tag **tag,
ReplayGainInfo **replay_gain_info_r) struct replay_gain_info **replay_gain_info_r)
{ {
mp3_data_init(data, decoder, is); mp3_data_init(data, decoder, is);
*tag = NULL; *tag = NULL;
@ -877,7 +879,7 @@ mp3_update_timer_next_frame(struct mp3_data *data)
*/ */
static enum decoder_command static enum decoder_command
mp3_send_pcm(struct mp3_data *data, unsigned i, unsigned pcm_length, mp3_send_pcm(struct mp3_data *data, unsigned i, unsigned pcm_length,
ReplayGainInfo *replay_gain_info) struct replay_gain_info *replay_gain_info)
{ {
unsigned max_samples; unsigned max_samples;
@ -916,7 +918,8 @@ mp3_send_pcm(struct mp3_data *data, unsigned i, unsigned pcm_length,
* Synthesize the current frame and send it via decoder_data(). * Synthesize the current frame and send it via decoder_data().
*/ */
static enum decoder_command static enum decoder_command
mp3_synth_and_send(struct mp3_data *data, ReplayGainInfo *replay_gain_info) mp3_synth_and_send(struct mp3_data *data,
struct replay_gain_info *replay_gain_info)
{ {
unsigned i, pcm_length; unsigned i, pcm_length;
enum decoder_command cmd; enum decoder_command cmd;
@ -971,7 +974,7 @@ mp3_synth_and_send(struct mp3_data *data, ReplayGainInfo *replay_gain_info)
} }
static bool static bool
mp3_read(struct mp3_data *data, ReplayGainInfo **replay_gain_info_r) mp3_read(struct mp3_data *data, struct replay_gain_info **replay_gain_info_r)
{ {
struct decoder *decoder = data->decoder; struct decoder *decoder = data->decoder;
int ret; int ret;
@ -1052,7 +1055,7 @@ mp3_decode(struct decoder *decoder, struct input_stream *input_stream)
{ {
struct mp3_data data; struct mp3_data data;
struct tag *tag = NULL; struct tag *tag = NULL;
ReplayGainInfo *replay_gain_info = NULL; struct replay_gain_info *replay_gain_info = NULL;
struct audio_format audio_format; struct audio_format audio_format;
if (!mp3_open(input_stream, &data, decoder, &tag, &replay_gain_info)) { if (!mp3_open(input_stream, &data, decoder, &tag, &replay_gain_info)) {
@ -1077,7 +1080,7 @@ mp3_decode(struct decoder *decoder, struct input_stream *input_stream)
while (mp3_read(&data, &replay_gain_info)) ; while (mp3_read(&data, &replay_gain_info)) ;
if (replay_gain_info) if (replay_gain_info)
freeReplayGainInfo(replay_gain_info); replay_gain_info_free(replay_gain_info);
if (decoder_get_command(decoder) == DECODE_COMMAND_SEEK && if (decoder_get_command(decoder) == DECODE_COMMAND_SEEK &&
data.mute_frame == MUTEFRAME_SEEK) data.mute_frame == MUTEFRAME_SEEK)

View File

@ -120,7 +120,7 @@ mpc_decode(struct decoder *mpd_decoder, struct input_stream *inStream)
mpc_uint32_t vbrUpdateBits; mpc_uint32_t vbrUpdateBits;
float total_time; float total_time;
int i; int i;
ReplayGainInfo *replayGainInfo = NULL; struct replay_gain_info *replayGainInfo = NULL;
data.inStream = inStream; data.inStream = inStream;
data.decoder = mpd_decoder; data.decoder = mpd_decoder;
@ -156,11 +156,11 @@ mpc_decode(struct decoder *mpd_decoder, struct input_stream *inStream)
audio_format.channels = info.channels; audio_format.channels = info.channels;
audio_format.sample_rate = info.sample_freq; audio_format.sample_rate = info.sample_freq;
replayGainInfo = newReplayGainInfo(); replayGainInfo = replay_gain_info_new();
replayGainInfo->albumGain = info.gain_album * 0.01; replayGainInfo->album_gain = info.gain_album * 0.01;
replayGainInfo->albumPeak = info.peak_album / 32767.0; replayGainInfo->album_peak = info.peak_album / 32767.0;
replayGainInfo->trackGain = info.gain_title * 0.01; replayGainInfo->track_gain = info.gain_title * 0.01;
replayGainInfo->trackPeak = info.peak_title / 32767.0; replayGainInfo->track_peak = info.peak_title / 32767.0;
decoder_initialized(mpd_decoder, &audio_format, decoder_initialized(mpd_decoder, &audio_format,
inStream->seekable, inStream->seekable,
@ -231,7 +231,7 @@ mpc_decode(struct decoder *mpd_decoder, struct input_stream *inStream)
replayGainInfo); replayGainInfo);
} }
freeReplayGainInfo(replayGainInfo); replay_gain_info_free(replayGainInfo);
return true; return true;
} }

View File

@ -31,7 +31,7 @@ static void oggflac_cleanup(FlacData * data,
OggFLAC__SeekableStreamDecoder * decoder) OggFLAC__SeekableStreamDecoder * decoder)
{ {
if (data->replayGainInfo) if (data->replayGainInfo)
freeReplayGainInfo(data->replayGainInfo); replay_gain_info_free(data->replayGainInfo);
if (decoder) if (decoder)
OggFLAC__seekable_stream_decoder_delete(decoder); OggFLAC__seekable_stream_decoder_delete(decoder);
} }

View File

@ -93,31 +93,33 @@ static const char *ogg_parseComment(const char *comment, const char *needle)
return NULL; return NULL;
} }
static void ogg_getReplayGainInfo(char **comments, ReplayGainInfo ** infoPtr) static void
ogg_getReplayGainInfo(char **comments,
struct replay_gain_info **infoPtr)
{ {
const char *temp; const char *temp;
bool found = false; bool found = false;
if (*infoPtr) if (*infoPtr)
freeReplayGainInfo(*infoPtr); replay_gain_info_free(*infoPtr);
*infoPtr = newReplayGainInfo(); *infoPtr = replay_gain_info_new();
while (*comments) { while (*comments) {
if ((temp = if ((temp =
ogg_parseComment(*comments, "replaygain_track_gain"))) { ogg_parseComment(*comments, "replaygain_track_gain"))) {
(*infoPtr)->trackGain = atof(temp); (*infoPtr)->track_gain = atof(temp);
found = true; found = true;
} else if ((temp = ogg_parseComment(*comments, } else if ((temp = ogg_parseComment(*comments,
"replaygain_album_gain"))) { "replaygain_album_gain"))) {
(*infoPtr)->albumGain = atof(temp); (*infoPtr)->album_gain = atof(temp);
found = true; found = true;
} else if ((temp = ogg_parseComment(*comments, } else if ((temp = ogg_parseComment(*comments,
"replaygain_track_peak"))) { "replaygain_track_peak"))) {
(*infoPtr)->trackPeak = atof(temp); (*infoPtr)->track_peak = atof(temp);
found = true; found = true;
} else if ((temp = ogg_parseComment(*comments, } else if ((temp = ogg_parseComment(*comments,
"replaygain_album_peak"))) { "replaygain_album_peak"))) {
(*infoPtr)->albumPeak = atof(temp); (*infoPtr)->album_peak = atof(temp);
found = true; found = true;
} }
@ -125,7 +127,7 @@ static void ogg_getReplayGainInfo(char **comments, ReplayGainInfo ** infoPtr)
} }
if (!found) { if (!found) {
freeReplayGainInfo(*infoPtr); replay_gain_info_free(*infoPtr);
*infoPtr = NULL; *infoPtr = NULL;
} }
} }
@ -209,7 +211,7 @@ oggvorbis_decode(struct decoder *decoder, struct input_stream *inStream)
int chunkpos = 0; int chunkpos = 0;
long bitRate = 0; long bitRate = 0;
long test; long test;
ReplayGainInfo *replayGainInfo = NULL; struct replay_gain_info *replayGainInfo = NULL;
char **comments; char **comments;
const char *errorStr; const char *errorStr;
bool initialized = false; bool initialized = false;
@ -324,7 +326,7 @@ oggvorbis_decode(struct decoder *decoder, struct input_stream *inStream)
} }
if (replayGainInfo) if (replayGainInfo)
freeReplayGainInfo(replayGainInfo); replay_gain_info_free(replayGainInfo);
ov_clear(&vf); ov_clear(&vf);
return true; return true;

View File

@ -121,7 +121,7 @@ format_samples_float(mpd_unused int bytes_per_sample, void *buffer,
*/ */
static void static void
wavpack_decode(struct decoder * decoder, WavpackContext *wpc, bool canseek, wavpack_decode(struct decoder * decoder, WavpackContext *wpc, bool canseek,
ReplayGainInfo *replayGainInfo) struct replay_gain_info *replayGainInfo)
{ {
struct audio_format audio_format; struct audio_format audio_format;
void (*format_samples)(int bytes_per_sample, void (*format_samples)(int bytes_per_sample,
@ -229,43 +229,43 @@ wavpack_tag(WavpackContext *wpc, char *key)
return value; return value;
} }
static ReplayGainInfo * static struct replay_gain_info *
wavpack_replaygain(WavpackContext *wpc) wavpack_replaygain(WavpackContext *wpc)
{ {
static char replaygain_track_gain[] = "replaygain_track_gain"; static char replaygain_track_gain[] = "replaygain_track_gain";
static char replaygain_album_gain[] = "replaygain_album_gain"; static char replaygain_album_gain[] = "replaygain_album_gain";
static char replaygain_track_peak[] = "replaygain_track_peak"; static char replaygain_track_peak[] = "replaygain_track_peak";
static char replaygain_album_peak[] = "replaygain_album_peak"; static char replaygain_album_peak[] = "replaygain_album_peak";
ReplayGainInfo *replay_gain_info; struct replay_gain_info *replay_gain_info;
bool found = false; bool found = false;
char *value; char *value;
replay_gain_info = newReplayGainInfo(); replay_gain_info = replay_gain_info_new();
value = wavpack_tag(wpc, replaygain_track_gain); value = wavpack_tag(wpc, replaygain_track_gain);
if (value) { if (value) {
replay_gain_info->trackGain = atof(value); replay_gain_info->track_gain = atof(value);
free(value); free(value);
found = true; found = true;
} }
value = wavpack_tag(wpc, replaygain_album_gain); value = wavpack_tag(wpc, replaygain_album_gain);
if (value) { if (value) {
replay_gain_info->albumGain = atof(value); replay_gain_info->album_gain = atof(value);
free(value); free(value);
found = true; found = true;
} }
value = wavpack_tag(wpc, replaygain_track_peak); value = wavpack_tag(wpc, replaygain_track_peak);
if (value) { if (value) {
replay_gain_info->trackPeak = atof(value); replay_gain_info->track_peak = atof(value);
free(value); free(value);
found = true; found = true;
} }
value = wavpack_tag(wpc, replaygain_album_peak); value = wavpack_tag(wpc, replaygain_album_peak);
if (value) { if (value) {
replay_gain_info->albumPeak = atof(value); replay_gain_info->album_peak = atof(value);
free(value); free(value);
found = true; found = true;
} }
@ -275,7 +275,7 @@ wavpack_replaygain(WavpackContext *wpc)
return replay_gain_info; return replay_gain_info;
} }
freeReplayGainInfo(replay_gain_info); replay_gain_info_free(replay_gain_info);
return NULL; return NULL;
} }
@ -537,7 +537,7 @@ wavpack_filedecode(struct decoder *decoder, const char *fname)
{ {
char error[ERRORLEN]; char error[ERRORLEN];
WavpackContext *wpc; WavpackContext *wpc;
ReplayGainInfo *replay_gain_info; struct replay_gain_info *replay_gain_info;
wpc = WavpackOpenFileInput(fname, error, wpc = WavpackOpenFileInput(fname, error,
OPEN_TAGS | OPEN_WVC | OPEN_TAGS | OPEN_WVC |
@ -553,7 +553,7 @@ wavpack_filedecode(struct decoder *decoder, const char *fname)
wavpack_decode(decoder, wpc, true, replay_gain_info); wavpack_decode(decoder, wpc, true, replay_gain_info);
if (replay_gain_info) { if (replay_gain_info) {
freeReplayGainInfo(replay_gain_info); replay_gain_info_free(replay_gain_info);
} }
WavpackCloseFile(wpc); WavpackCloseFile(wpc);

View File

@ -175,7 +175,7 @@ decoder_data(struct decoder *decoder,
struct input_stream *is, struct input_stream *is,
void *_data, size_t length, void *_data, size_t length,
float data_time, uint16_t bitRate, float data_time, uint16_t bitRate,
ReplayGainInfo *replay_gain_info) struct replay_gain_info *replay_gain_info)
{ {
static char *conv_buffer; static char *conv_buffer;
static size_t conv_buffer_size; static size_t conv_buffer_size;
@ -234,8 +234,8 @@ decoder_data(struct decoder *decoder,
data, &decoder->conv_state); data, &decoder->conv_state);
} }
if (replay_gain_info != NULL && (replayGainState != REPLAYGAIN_OFF)) if (replay_gain_info != NULL && (replay_gain_mode != REPLAY_GAIN_OFF))
doReplayGain(replay_gain_info, data, length, replay_gain_apply(replay_gain_info, data, length,
&dc.out_audio_format); &dc.out_audio_format);
else if (normalizationEnabled) else if (normalizationEnabled)
normalizeData(data, length, &dc.out_audio_format); normalizeData(data, length, &dc.out_audio_format);

View File

@ -143,7 +143,7 @@ enum decoder_command
decoder_data(struct decoder *decoder, decoder_data(struct decoder *decoder,
struct input_stream *inStream, struct input_stream *inStream,
void *data, size_t datalen, float data_time, uint16_t bitRate, void *data, size_t datalen, float data_time, uint16_t bitRate,
ReplayGainInfo * replayGainInfo); struct replay_gain_info *replay_gain_info);
/** /**
* This function is called by the decoder plugin when it has * This function is called by the decoder plugin when it has

View File

@ -429,7 +429,7 @@ int main(int argc, char *argv[])
initAudioDriver(); initAudioDriver();
initVolume(); initVolume();
client_manager_init(); client_manager_init();
initReplayGainState(); replay_gain_global_init();
initNormalization(); initNormalization();
input_stream_global_init(); input_stream_global_init();

View File

@ -26,11 +26,11 @@
#include "os_compat.h" #include "os_compat.h"
/* Added 4/14/2004 by AliasMrJones */ /* Added 4/14/2004 by AliasMrJones */
int replayGainState = REPLAYGAIN_OFF; int replay_gain_mode = REPLAY_GAIN_OFF;
static float replayGainPreamp = 1.0; static float replay_gain_preamp = 1.0;
void initReplayGainState(void) void replay_gain_global_init(void)
{ {
ConfigParam *param = getConfigParam(CONF_REPLAYGAIN); ConfigParam *param = getConfigParam(CONF_REPLAYGAIN);
@ -38,9 +38,9 @@ void initReplayGainState(void)
return; return;
if (strcmp(param->value, "track") == 0) { if (strcmp(param->value, "track") == 0) {
replayGainState = REPLAYGAIN_TRACK; replay_gain_mode = REPLAY_GAIN_TRACK;
} else if (strcmp(param->value, "album") == 0) { } else if (strcmp(param->value, "album") == 0) {
replayGainState = REPLAYGAIN_ALBUM; replay_gain_mode = REPLAY_GAIN_ALBUM;
} else { } else {
FATAL("replaygain value \"%s\" at line %i is invalid\n", FATAL("replaygain value \"%s\" at line %i is invalid\n",
param->value, param->line); param->value, param->line);
@ -62,18 +62,18 @@ void initReplayGainState(void)
"15 at line %i\n", param->value, param->line); "15 at line %i\n", param->value, param->line);
} }
replayGainPreamp = pow(10, f / 20.0); replay_gain_preamp = pow(10, f / 20.0);
} }
} }
static float computeReplayGainScale(float gain, float peak) static float calc_replay_gain_scale(float gain, float peak)
{ {
float scale; float scale;
if (gain == 0.0) if (gain == 0.0)
return (1); return (1);
scale = pow(10.0, gain / 20.0); scale = pow(10.0, gain / 20.0);
scale *= replayGainPreamp; scale *= replay_gain_preamp;
if (scale > 15.0) if (scale > 15.0)
scale = 15.0; scale = 15.0;
@ -83,28 +83,29 @@ static float computeReplayGainScale(float gain, float peak)
return (scale); return (scale);
} }
ReplayGainInfo *newReplayGainInfo(void) struct replay_gain_info *replay_gain_info_new(void)
{ {
ReplayGainInfo *ret = xmalloc(sizeof(ReplayGainInfo)); struct replay_gain_info *ret = xmalloc(sizeof(*ret));
ret->albumGain = 0.0; ret->album_gain = 0.0;
ret->albumPeak = 0.0; ret->album_peak = 0.0;
ret->trackGain = 0.0; ret->track_gain = 0.0;
ret->trackPeak = 0.0; ret->track_peak = 0.0;
/* set to -1 so that we know in doReplayGain to compute the scale */ /* set to -1 so that we know in replay_gain_apply to compute the scale */
ret->scale = -1.0; ret->scale = -1.0;
return ret; return ret;
} }
void freeReplayGainInfo(ReplayGainInfo * info) void replay_gain_info_free(struct replay_gain_info *info)
{ {
free(info); free(info);
} }
void doReplayGain(ReplayGainInfo * info, char *buffer, int bufferSize, void
replay_gain_apply(struct replay_gain_info *info, char *buffer, int size,
const struct audio_format *format) const struct audio_format *format)
{ {
int16_t *buffer16; int16_t *buffer16;
@ -112,22 +113,22 @@ void doReplayGain(ReplayGainInfo * info, char *buffer, int bufferSize,
int32_t temp32; int32_t temp32;
float scale; float scale;
if (replayGainState == REPLAYGAIN_OFF || !info) if (replay_gain_mode == REPLAY_GAIN_OFF || !info)
return; return;
if (info->scale < 0) { if (info->scale < 0) {
switch (replayGainState) { switch (replay_gain_mode) {
case REPLAYGAIN_TRACK: case REPLAY_GAIN_TRACK:
DEBUG("computing ReplayGain track scale with gain %f, " DEBUG("computing ReplayGain track scale with gain %f, "
"peak %f\n", info->trackGain, info->trackPeak); "peak %f\n", info->track_gain, info->track_peak);
info->scale = computeReplayGainScale(info->trackGain, info->scale = calc_replay_gain_scale(info->track_gain,
info->trackPeak); info->track_peak);
break; break;
default: default:
DEBUG("computing ReplayGain album scale with gain %f, " DEBUG("computing ReplayGain album scale with gain %f, "
"peak %f\n", info->albumGain, info->albumPeak); "peak %f\n", info->album_gain, info->album_peak);
info->scale = computeReplayGainScale(info->albumGain, info->scale = calc_replay_gain_scale(info->album_gain,
info->albumPeak); info->album_peak);
break; break;
} }
} }
@ -142,23 +143,23 @@ void doReplayGain(ReplayGainInfo * info, char *buffer, int bufferSize,
switch (format->bits) { switch (format->bits) {
case 16: case 16:
while (bufferSize > 0) { while (size > 0) {
temp32 = *buffer16; temp32 = *buffer16;
temp32 *= scale; temp32 *= scale;
*buffer16 = temp32 > 32767 ? 32767 : *buffer16 = temp32 > 32767 ? 32767 :
(temp32 < -32768 ? -32768 : temp32); (temp32 < -32768 ? -32768 : temp32);
buffer16++; buffer16++;
bufferSize -= 2; size -= 2;
} }
break; break;
case 8: case 8:
while (bufferSize > 0) { while (size > 0) {
temp32 = *buffer8; temp32 = *buffer8;
temp32 *= scale; temp32 *= scale;
*buffer8 = temp32 > 127 ? 127 : *buffer8 = temp32 > 127 ? 127 :
(temp32 < -128 ? -128 : temp32); (temp32 < -128 ? -128 : temp32);
buffer8++; buffer8++;
bufferSize--; size--;
} }
break; break;
default: default:

View File

@ -17,34 +17,36 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/ */
#ifndef MPD_REPLAYGAIN_H #ifndef MPD_REPLAY_GAIN_H
#define MPD_REPLAYGAIN_H #define MPD_REPLAY_GAIN_H
#define REPLAYGAIN_OFF 0 #define REPLAY_GAIN_OFF 0
#define REPLAYGAIN_TRACK 1 #define REPLAY_GAIN_TRACK 1
#define REPLAYGAIN_ALBUM 2 #define REPLAY_GAIN_ALBUM 2
struct audio_format; struct audio_format;
extern int replayGainState; extern int replay_gain_mode;
typedef struct _ReplayGainInfo { struct replay_gain_info {
float albumGain; float album_gain;
float albumPeak; float album_peak;
float trackGain; float track_gain;
float trackPeak; float track_peak;
/* used internally by mpd, to mess with it */ /* used internally by mpd, to mess with it */
float scale; float scale;
} ReplayGainInfo; };
ReplayGainInfo *newReplayGainInfo(void); struct replay_gain_info *
replay_gain_info_new(void);
void freeReplayGainInfo(ReplayGainInfo * info); void replay_gain_info_free(struct replay_gain_info *info);
void initReplayGainState(void); void replay_gain_global_init(void);
void doReplayGain(ReplayGainInfo * info, char *buffer, int bufferSize, void
replay_gain_apply(struct replay_gain_info *info, char *buffer, int bufferSize,
const struct audio_format *format); const struct audio_format *format);
#endif #endif