Commit 8209799d authored by aurel's avatar aurel

matroskadec: remove now useless expected_id parameter from ebml_parse()

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@14588 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 490e3984
...@@ -968,7 +968,7 @@ matroska_probe (AVProbeData *p) ...@@ -968,7 +968,7 @@ matroska_probe (AVProbeData *p)
} }
static int ebml_parse(MatroskaDemuxContext *matroska, EbmlSyntax *syntax, static int ebml_parse(MatroskaDemuxContext *matroska, EbmlSyntax *syntax,
void *data, uint32_t expected_id, int once); void *data, int once);
static int ebml_parse_elem(MatroskaDemuxContext *matroska, static int ebml_parse_elem(MatroskaDemuxContext *matroska,
EbmlSyntax *syntax, void *data) EbmlSyntax *syntax, void *data)
...@@ -1001,8 +1001,8 @@ static int ebml_parse_elem(MatroskaDemuxContext *matroska, ...@@ -1001,8 +1001,8 @@ static int ebml_parse_elem(MatroskaDemuxContext *matroska,
return res; return res;
if (id == MATROSKA_ID_SEGMENT) if (id == MATROSKA_ID_SEGMENT)
matroska->segment_start = url_ftell(matroska->ctx->pb); matroska->segment_start = url_ftell(matroska->ctx->pb);
return ebml_parse(matroska, syntax->def.n, data, 0, 0); return ebml_parse(matroska, syntax->def.n, data, 0);
case EBML_PASS: return ebml_parse(matroska, syntax->def.n, data, 0, 1); case EBML_PASS: return ebml_parse(matroska, syntax->def.n, data, 1);
case EBML_STOP: *(int *)data = 1; return 1; case EBML_STOP: *(int *)data = 1; return 1;
default: return ebml_read_skip(matroska); default: return ebml_read_skip(matroska);
} }
...@@ -1021,7 +1021,7 @@ static int ebml_parse_id(MatroskaDemuxContext *matroska, EbmlSyntax *syntax, ...@@ -1021,7 +1021,7 @@ static int ebml_parse_id(MatroskaDemuxContext *matroska, EbmlSyntax *syntax,
} }
static int ebml_parse(MatroskaDemuxContext *matroska, EbmlSyntax *syntax, static int ebml_parse(MatroskaDemuxContext *matroska, EbmlSyntax *syntax,
void *data, uint32_t expected_id, int once) void *data, int once)
{ {
int i, res = 0, res2; int i, res = 0, res2;
uint32_t id = 0; uint32_t id = 0;
...@@ -1040,14 +1040,6 @@ static int ebml_parse(MatroskaDemuxContext *matroska, EbmlSyntax *syntax, ...@@ -1040,14 +1040,6 @@ static int ebml_parse(MatroskaDemuxContext *matroska, EbmlSyntax *syntax,
break; break;
} }
if (expected_id) {
res = ebml_read_master(matroska, &id);
if (id != expected_id)
return AVERROR_INVALIDDATA;
if (id == MATROSKA_ID_SEGMENT)
matroska->segment_start = url_ftell(matroska->ctx->pb);
}
while (!res) { while (!res) {
res2 = ebml_read_element_id(matroska, &id); res2 = ebml_read_element_id(matroska, &id);
if (res2 < 0) if (res2 < 0)
...@@ -1261,7 +1253,7 @@ matroska_read_header (AVFormatContext *s, ...@@ -1261,7 +1253,7 @@ matroska_read_header (AVFormatContext *s,
matroska->ctx = s; matroska->ctx = s;
/* First read the EBML header. */ /* First read the EBML header. */
if (ebml_parse(matroska, ebml_syntax, &ebml, 0, 1) if (ebml_parse(matroska, ebml_syntax, &ebml, 1)
|| ebml.version > EBML_VERSION || ebml.max_size > sizeof(uint64_t) || ebml.version > EBML_VERSION || ebml.max_size > sizeof(uint64_t)
|| ebml.id_length > sizeof(uint32_t) || strcmp(ebml.doctype, "matroska") || ebml.id_length > sizeof(uint32_t) || strcmp(ebml.doctype, "matroska")
|| ebml.doctype_version > 2) { || ebml.doctype_version > 2) {
...@@ -1274,7 +1266,7 @@ matroska_read_header (AVFormatContext *s, ...@@ -1274,7 +1266,7 @@ matroska_read_header (AVFormatContext *s,
ebml_free(ebml_syntax, &ebml); ebml_free(ebml_syntax, &ebml);
/* The next thing is a segment. */ /* The next thing is a segment. */
if (ebml_parse(matroska, matroska_segments, matroska, 0, 1) < 0) if (ebml_parse(matroska, matroska_segments, matroska, 1) < 0)
return -1; return -1;
matroska_execute_seekhead(matroska); matroska_execute_seekhead(matroska);
...@@ -1766,7 +1758,7 @@ matroska_parse_cluster (MatroskaDemuxContext *matroska) ...@@ -1766,7 +1758,7 @@ matroska_parse_cluster (MatroskaDemuxContext *matroska)
MatroskaCluster cluster = { 0 }; MatroskaCluster cluster = { 0 };
EbmlList *blocks_list; EbmlList *blocks_list;
MatroskaBlock *blocks; MatroskaBlock *blocks;
int i, res = ebml_parse(matroska, matroska_clusters, &cluster, 0, 1); int i, res = ebml_parse(matroska, matroska_clusters, &cluster, 1);
blocks_list = &cluster.blocks; blocks_list = &cluster.blocks;
blocks = blocks_list->elem; blocks = blocks_list->elem;
for (i=0; !res && i<blocks_list->nb_elem; i++) for (i=0; !res && i<blocks_list->nb_elem; i++)
......
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