Merge commit 'ae43c10e36197000de2f3cc99ea35727ce98a796'

* commit 'ae43c10e36197000de2f3cc99ea35727ce98a796':
  replaygain: allow exporting already decoded replaygain values

Merged-by: Michael Niedermayer <michaelni@gmx.at>
pull/66/head
Michael Niedermayer 11 years ago
commit d35efda21a
  1. 29
      libavformat/replaygain.c
  2. 7
      libavformat/replaygain.h

@ -66,23 +66,22 @@ static int32_t parse_value(const char *value, int32_t min)
return db * 100000 + sign * mb; return db * 100000 + sign * mb;
} }
static int replaygain_export(AVStream *st, int ff_replaygain_export_raw(AVStream *st, int32_t tg, uint32_t tp,
const uint8_t *track_gain, const uint8_t *track_peak, int32_t ag, uint32_t ap)
const uint8_t *album_gain, const uint8_t *album_peak)
{ {
AVPacketSideData *sd, *tmp; AVPacketSideData *sd, *tmp;
AVReplayGain *replaygain; AVReplayGain *replaygain;
int32_t tg, ag;
uint32_t tp, ap;
tg = parse_value(track_gain, INT32_MIN);
ag = parse_value(album_gain, INT32_MIN);
tp = parse_value(track_peak, 0);
ap = parse_value(album_peak, 0);
if (tg == INT32_MIN && ag == INT32_MIN) if (tg == INT32_MIN && ag == INT32_MIN)
return 0; return 0;
for (int i = 0; i < st->nb_side_data; i++) {
AVPacketSideData *src_sd = &st->side_data[i];
if (src_sd->type == AV_PKT_DATA_REPLAYGAIN)
return 0;
}
replaygain = av_mallocz(sizeof(*replaygain)); replaygain = av_mallocz(sizeof(*replaygain));
if (!replaygain) if (!replaygain)
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
@ -117,9 +116,9 @@ int ff_replaygain_export(AVStream *st, AVDictionary *metadata)
ag = av_dict_get(metadata, "REPLAYGAIN_ALBUM_GAIN", NULL, 0); ag = av_dict_get(metadata, "REPLAYGAIN_ALBUM_GAIN", NULL, 0);
ap = av_dict_get(metadata, "REPLAYGAIN_ALBUM_PEAK", NULL, 0); ap = av_dict_get(metadata, "REPLAYGAIN_ALBUM_PEAK", NULL, 0);
return replaygain_export(st, return ff_replaygain_export_raw(st,
tg ? tg->value : NULL, parse_value(tg ? tg->value : NULL, INT32_MIN),
tp ? tp->value : NULL, parse_value(tp ? tp->value : NULL, 0),
ag ? ag->value : NULL, parse_value(ag ? ag->value : NULL, INT32_MIN),
ap ? ap->value : NULL); parse_value(ap ? ap->value : NULL, 0));
} }

@ -28,4 +28,11 @@
*/ */
int ff_replaygain_export(AVStream *st, AVDictionary *metadata); int ff_replaygain_export(AVStream *st, AVDictionary *metadata);
/**
* Export already decoded replaygain values as per-stream side data.
*/
int ff_replaygain_export_raw(AVStream *st, int32_t tg, uint32_t tp,
int32_t ag, uint32_t ap);
#endif /* AVFORMAT_REPLAYGAIN_H */ #endif /* AVFORMAT_REPLAYGAIN_H */

Loading…
Cancel
Save