diff options
author | Michael Niedermayer | 2014-04-17 21:45:39 +0200 |
---|---|---|
committer | Michael Niedermayer | 2014-04-17 21:45:58 +0200 |
commit | d35efda21a146ad437e194cf124e3ca170bfc82e (patch) | |
tree | 20fac70dd33de4d86979fc2c897c88ea27c0e0dc /libavformat/replaygain.c | |
parent | 11d187b377be54de23f609592ce0f32d51ed9e6d (diff) | |
parent | ae43c10e36197000de2f3cc99ea35727ce98a796 (diff) |
Merge commit 'ae43c10e36197000de2f3cc99ea35727ce98a796'
* commit 'ae43c10e36197000de2f3cc99ea35727ce98a796':
replaygain: allow exporting already decoded replaygain values
Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavformat/replaygain.c')
-rw-r--r-- | libavformat/replaygain.c | 29 |
1 files changed, 14 insertions, 15 deletions
diff --git a/libavformat/replaygain.c b/libavformat/replaygain.c index 2d478ac6d3..eccbb0179c 100644 --- a/libavformat/replaygain.c +++ b/libavformat/replaygain.c @@ -66,23 +66,22 @@ static int32_t parse_value(const char *value, int32_t min) return db * 100000 + sign * mb; } -static int replaygain_export(AVStream *st, - const uint8_t *track_gain, const uint8_t *track_peak, - const uint8_t *album_gain, const uint8_t *album_peak) +int ff_replaygain_export_raw(AVStream *st, int32_t tg, uint32_t tp, + int32_t ag, uint32_t ap) { AVPacketSideData *sd, *tmp; 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) 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)); if (!replaygain) 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); ap = av_dict_get(metadata, "REPLAYGAIN_ALBUM_PEAK", NULL, 0); - return replaygain_export(st, - tg ? tg->value : NULL, - tp ? tp->value : NULL, - ag ? ag->value : NULL, - ap ? ap->value : NULL); + return ff_replaygain_export_raw(st, + parse_value(tg ? tg->value : NULL, INT32_MIN), + parse_value(tp ? tp->value : NULL, 0), + parse_value(ag ? ag->value : NULL, INT32_MIN), + parse_value(ap ? ap->value : NULL, 0)); } |