aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBaptiste Coudurier <baptiste.coudurier@gmail.com>2007-12-16 18:20:27 +0000
committerBaptiste Coudurier <baptiste.coudurier@gmail.com>2007-12-16 18:20:27 +0000
commit73d07c275adc939b967737d31927784857efd153 (patch)
tree05f8ee4c8d84e1490298b3064d8b476212226bd4
parent23d2cfe9a539ffbce0ac2bde1caf830ca135b3c5 (diff)
downloadffmpeg-73d07c275adc939b967737d31927784857efd153.tar.gz
save pointer to parse table, it is unlikely to change
Originally committed as revision 11237 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r--libavformat/mov.c15
1 files changed, 6 insertions, 9 deletions
diff --git a/libavformat/mov.c b/libavformat/mov.c
index 8700d90499..45856fc0d2 100644
--- a/libavformat/mov.c
+++ b/libavformat/mov.c
@@ -118,10 +118,6 @@ typedef struct MOVContext {
int64_t mdat_offset;
int total_streams;
MOVStreamContext *streams[MAX_STREAMS];
-
- const struct MOVParseTableEntry *parse_table; /* could be eventually used to change the table */
- /* NOTE: for recursion save to/ restore from local variable! */
-
AVPaletteControl palette_control;
MOV_mdat_t *mdat_list;
int mdat_count;
@@ -147,6 +143,8 @@ typedef struct MOVParseTableEntry {
mov_parse_function func;
} MOVParseTableEntry;
+static const MOVParseTableEntry mov_default_parse_table[];
+
static int mov_read_default(MOVContext *c, ByteIOContext *pb, MOV_atom_t atom)
{
int64_t total_size = 0;
@@ -183,16 +181,16 @@ static int mov_read_default(MOVContext *c, ByteIOContext *pb, MOV_atom_t atom)
break;
a.size = FFMIN(a.size, atom.size - total_size);
- for (i = 0; c->parse_table[i].type != 0L
- && c->parse_table[i].type != a.type; i++)
+ for (i = 0; mov_default_parse_table[i].type != 0L
+ && mov_default_parse_table[i].type != a.type; i++)
/* empty */;
- if (c->parse_table[i].type == 0) { /* skip leaf atoms data */
+ if (mov_default_parse_table[i].type == 0) { /* skip leaf atoms data */
url_fskip(pb, a.size);
} else {
offset_t start_pos = url_ftell(pb);
int64_t left;
- err = (c->parse_table[i].func)(c, pb, a);
+ err = (mov_default_parse_table[i].func)(c, pb, a);
if (c->found_moov && c->found_mdat)
break;
left = a.size - url_ftell(pb) + start_pos;
@@ -1427,7 +1425,6 @@ static int mov_read_header(AVFormatContext *s, AVFormatParameters *ap)
MOV_atom_t atom = { 0, 0, 0 };
mov->fc = s;
- mov->parse_table = mov_default_parse_table;
if(!url_is_streamed(pb)) /* .mov and .mp4 aren't streamable anyway (only progressive download if moov is before mdat) */
atom.size = url_fsize(pb);