Kaynağa Gözat

Merge commit 'd6b9ce99ea384fb676561461768b8316725a4ccd'

* commit 'd6b9ce99ea384fb676561461768b8316725a4ccd':
  flac demuxer: parse the WAVEFORMATEXTENSIBLE_CHANNEL_MASK tag

Merged-by: Michael Niedermayer <michaelni@gmx.at>
Michael Niedermayer 11 yıl önce
ebeveyn
işleme
03ffaed3f0
1 değiştirilmiş dosya ile 15 ekleme ve 0 silme
  1. 15 0
      libavformat/flacdec.c

+ 15 - 0
libavformat/flacdec.c

@@ -136,9 +136,24 @@ static int flac_read_header(AVFormatContext *s)
             }
             }
             /* process supported blocks other than STREAMINFO */
             /* process supported blocks other than STREAMINFO */
             if (metadata_type == FLAC_METADATA_TYPE_VORBIS_COMMENT) {
             if (metadata_type == FLAC_METADATA_TYPE_VORBIS_COMMENT) {
+                AVDictionaryEntry *chmask;
+
                 if (ff_vorbis_comment(s, &s->metadata, buffer, metadata_size)) {
                 if (ff_vorbis_comment(s, &s->metadata, buffer, metadata_size)) {
                     av_log(s, AV_LOG_WARNING, "error parsing VorbisComment metadata\n");
                     av_log(s, AV_LOG_WARNING, "error parsing VorbisComment metadata\n");
                 }
                 }
+
+                /* parse the channels mask if present */
+                chmask = av_dict_get(s->metadata, "WAVEFORMATEXTENSIBLE_CHANNEL_MASK", NULL, 0);
+                if (chmask) {
+                    uint64_t mask = strtol(chmask->value, NULL, 0);
+                    if (!mask || mask & ~0x3ffffULL) {
+                        av_log(s, AV_LOG_WARNING,
+                               "Invalid value of WAVEFORMATEXTENSIBLE_CHANNEL_MASK\n");
+                    } else {
+                        st->codec->channel_layout = mask;
+                        av_dict_set(&s->metadata, "WAVEFORMATEXTENSIBLE_CHANNEL_MASK", NULL, 0);
+                    }
+                }
             }
             }
             av_freep(&buffer);
             av_freep(&buffer);
         }
         }