Commit b682b98a authored by aurel's avatar aurel

don't rely on a specific appearance order for ebml elements at the same level


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@8181 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent b2967fb1
...@@ -289,6 +289,10 @@ typedef struct MatroskaSubtitleTrack { ...@@ -289,6 +289,10 @@ typedef struct MatroskaSubtitleTrack {
//.. //..
} MatroskaSubtitleTrack; } MatroskaSubtitleTrack;
#define MAX_TRACK_SIZE (FFMAX(FFMAX(sizeof(MatroskaVideoTrack), \
sizeof(MatroskaAudioTrack)), \
sizeof(MatroskaSubtitleTrack)))
typedef struct MatroskaLevel { typedef struct MatroskaLevel {
uint64_t start, length; uint64_t start, length;
} MatroskaLevel; } MatroskaLevel;
...@@ -1165,7 +1169,7 @@ matroska_add_stream (MatroskaDemuxContext *matroska) ...@@ -1165,7 +1169,7 @@ matroska_add_stream (MatroskaDemuxContext *matroska)
av_log(matroska->ctx, AV_LOG_DEBUG, "parsing track, adding stream..,\n"); av_log(matroska->ctx, AV_LOG_DEBUG, "parsing track, adding stream..,\n");
/* Allocate a generic track. As soon as we know its type we'll realloc. */ /* Allocate a generic track. As soon as we know its type we'll realloc. */
track = av_mallocz(sizeof(MatroskaTrack)); track = av_mallocz(MAX_TRACK_SIZE);
matroska->num_tracks++; matroska->num_tracks++;
/* start with the master */ /* start with the master */
...@@ -1204,30 +1208,19 @@ matroska_add_stream (MatroskaDemuxContext *matroska) ...@@ -1204,30 +1208,19 @@ matroska_add_stream (MatroskaDemuxContext *matroska)
/* track type (video, audio, combined, subtitle, etc.) */ /* track type (video, audio, combined, subtitle, etc.) */
case MATROSKA_ID_TRACKTYPE: { case MATROSKA_ID_TRACKTYPE: {
uint64_t num; uint64_t num;
if (track->type != 0) { if ((res = ebml_read_uint(matroska, &id, &num)) < 0)
break;
if (track->type && track->type != num) {
av_log(matroska->ctx, AV_LOG_INFO, av_log(matroska->ctx, AV_LOG_INFO,
"More than one tracktype in an entry - skip\n"); "More than one tracktype in an entry - skip\n");
break; break;
} }
if ((res = ebml_read_uint(matroska, &id, &num)) < 0)
break;
track->type = num; track->type = num;
/* ok, so we're actually going to reallocate this thing */
switch (track->type) { switch (track->type) {
case MATROSKA_TRACK_TYPE_VIDEO: case MATROSKA_TRACK_TYPE_VIDEO:
track = (MatroskaTrack *)
av_realloc(track, sizeof(MatroskaVideoTrack));
break;
case MATROSKA_TRACK_TYPE_AUDIO: case MATROSKA_TRACK_TYPE_AUDIO:
track = (MatroskaTrack *)
av_realloc(track, sizeof(MatroskaAudioTrack));
((MatroskaAudioTrack *)track)->channels = 1;
((MatroskaAudioTrack *)track)->samplerate = 8000;
break;
case MATROSKA_TRACK_TYPE_SUBTITLE: case MATROSKA_TRACK_TYPE_SUBTITLE:
track = (MatroskaTrack *)
av_realloc(track, sizeof(MatroskaSubtitleTrack));
break; break;
case MATROSKA_TRACK_TYPE_COMPLEX: case MATROSKA_TRACK_TYPE_COMPLEX:
case MATROSKA_TRACK_TYPE_LOGO: case MATROSKA_TRACK_TYPE_LOGO:
...@@ -1246,6 +1239,8 @@ matroska_add_stream (MatroskaDemuxContext *matroska) ...@@ -1246,6 +1239,8 @@ matroska_add_stream (MatroskaDemuxContext *matroska)
/* tracktype specific stuff for video */ /* tracktype specific stuff for video */
case MATROSKA_ID_TRACKVIDEO: { case MATROSKA_ID_TRACKVIDEO: {
MatroskaVideoTrack *videotrack; MatroskaVideoTrack *videotrack;
if (!track->type)
track->type = MATROSKA_TRACK_TYPE_VIDEO;
if (track->type != MATROSKA_TRACK_TYPE_VIDEO) { if (track->type != MATROSKA_TRACK_TYPE_VIDEO) {
av_log(matroska->ctx, AV_LOG_INFO, av_log(matroska->ctx, AV_LOG_INFO,
"video data in non-video track - ignoring\n"); "video data in non-video track - ignoring\n");
...@@ -1413,6 +1408,8 @@ matroska_add_stream (MatroskaDemuxContext *matroska) ...@@ -1413,6 +1408,8 @@ matroska_add_stream (MatroskaDemuxContext *matroska)
/* tracktype specific stuff for audio */ /* tracktype specific stuff for audio */
case MATROSKA_ID_TRACKAUDIO: { case MATROSKA_ID_TRACKAUDIO: {
MatroskaAudioTrack *audiotrack; MatroskaAudioTrack *audiotrack;
if (!track->type)
track->type = MATROSKA_TRACK_TYPE_AUDIO;
if (track->type != MATROSKA_TRACK_TYPE_AUDIO) { if (track->type != MATROSKA_TRACK_TYPE_AUDIO) {
av_log(matroska->ctx, AV_LOG_INFO, av_log(matroska->ctx, AV_LOG_INFO,
"audio data in non-audio track - ignoring\n"); "audio data in non-audio track - ignoring\n");
...@@ -1421,6 +1418,8 @@ matroska_add_stream (MatroskaDemuxContext *matroska) ...@@ -1421,6 +1418,8 @@ matroska_add_stream (MatroskaDemuxContext *matroska)
} else if ((res = ebml_read_master(matroska, &id)) < 0) } else if ((res = ebml_read_master(matroska, &id)) < 0)
break; break;
audiotrack = (MatroskaAudioTrack *)track; audiotrack = (MatroskaAudioTrack *)track;
audiotrack->channels = 1;
audiotrack->samplerate = 8000;
while (res == 0) { while (res == 0) {
if (!(id = ebml_peek_id(matroska, &matroska->level_up))) { if (!(id = ebml_peek_id(matroska, &matroska->level_up))) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment