aboutsummaryrefslogtreecommitdiff
path: root/libavformat/replaygain.c
diff options
context:
space:
mode:
authorMichael Niedermayer2014-04-17 21:45:39 +0200
committerMichael Niedermayer2014-04-17 21:45:58 +0200
commitd35efda21a146ad437e194cf124e3ca170bfc82e (patch)
tree20fac70dd33de4d86979fc2c897c88ea27c0e0dc /libavformat/replaygain.c
parent11d187b377be54de23f609592ce0f32d51ed9e6d (diff)
parentae43c10e36197000de2f3cc99ea35727ce98a796 (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.c29
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));
}