[FFmpeg-cvslog] lavf/id3v2: always strdup the value.
Clément Bœsch
git at videolan.org
Sat May 19 12:32:32 CEST 2012
ffmpeg | branch: master | Clément Bœsch <ubitux at gmail.com> | Sat May 12 22:39:30 2012 +0200| [e5fcf3646acd633bfad1806fc778bc33748e6f5f] | committer: Clément Bœsch
lavf/id3v2: always strdup the value.
This simplifies the code but also fix a warning: ff_id3v1_genre_str
array contains const strings so do the string dup now instead of in
av_dict_set().
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=e5fcf3646acd633bfad1806fc778bc33748e6f5f
---
libavformat/id3v2.c | 11 ++++-------
1 file changed, 4 insertions(+), 7 deletions(-)
diff --git a/libavformat/id3v2.c b/libavformat/id3v2.c
index 97a23c4..3b02d2b 100644
--- a/libavformat/id3v2.c
+++ b/libavformat/id3v2.c
@@ -272,7 +272,7 @@ static int decode_str(AVFormatContext *s, AVIOContext *pb, int encoding,
static void read_ttag(AVFormatContext *s, AVIOContext *pb, int taglen, const char *key)
{
uint8_t *dst;
- int encoding, dict_flags = AV_DICT_DONT_OVERWRITE;
+ int encoding, dict_flags = AV_DICT_DONT_OVERWRITE | AV_DICT_DONT_STRDUP_VAL;
unsigned genre;
if (taglen < 1)
@@ -290,7 +290,7 @@ static void read_ttag(AVFormatContext *s, AVIOContext *pb, int taglen, const cha
&& (sscanf(dst, "(%d)", &genre) == 1 || sscanf(dst, "%d", &genre) == 1)
&& genre <= ID3v1_GENRE_MAX) {
av_freep(&dst);
- dst = ff_id3v1_genre_str[genre];
+ dst = av_strdup(ff_id3v1_genre_str[genre]);
} else if (!(strcmp(key, "TXXX") && strcmp(key, "TXX"))) {
/* dst now contains the key, need to get value */
key = dst;
@@ -299,11 +299,8 @@ static void read_ttag(AVFormatContext *s, AVIOContext *pb, int taglen, const cha
av_freep(&key);
return;
}
- dict_flags |= AV_DICT_DONT_STRDUP_VAL | AV_DICT_DONT_STRDUP_KEY;
- }
- else if (*dst)
- dict_flags |= AV_DICT_DONT_STRDUP_VAL;
- else
+ dict_flags |= AV_DICT_DONT_STRDUP_KEY;
+ } else if (!*dst)
av_freep(&dst);
if (dst)
More information about the ffmpeg-cvslog
mailing list