# HG changeset patch # User ranma # Date 1083357408 0 # Node ID cccdd44a803054f6c259ae340e4a607669f4637f # Parent a84160d660af1adf831c2ce82e18edb369f0e975 Only use odml index for files that need it diff -r a84160d660af -r cccdd44a8030 libmpdemux/aviheader.c --- a/libmpdemux/aviheader.c Fri Apr 30 20:20:37 2004 +0000 +++ b/libmpdemux/aviheader.c Fri Apr 30 20:36:48 2004 +0000 @@ -225,9 +225,6 @@ uint32_t i; unsigned msize = 0; avisuperindex_chunk *s; - // FIXME: do not use odml index for files that don't need it. - // apparently the odml code is buggy! - if (demuxer->movi_end < 0x7fffffff) break; priv->suidx_size++; priv->suidx = realloc(priv->suidx, priv->suidx_size * sizeof (avisuperindex_chunk)); s = &priv->suidx[priv->suidx_size-1]; @@ -262,7 +259,6 @@ (s->dwChunkId), i, (uint64_t)s->aIndex[i].qwOffset, s->aIndex[i].dwSize, s->aIndex[i].dwDuration); } - priv->isodml++; break; } case ckidSTREAMFORMAT: { // read 'strf' @@ -401,6 +397,15 @@ if (strncmp(riff_type, "AVIX", sizeof riff_type)) mp_msg(MSGT_HEADER, MSGL_WARN, "** warning: this is no extended AVI header..\n"); + else { + /* + * We got an extended AVI header, so we need to switch to + * ODML to get seeking to work, provided we got indx chunks + * in the header (suidx_size > 0). + */ + if (priv->suidx_size > 0) + priv->isodml = 1; + } chunksize = 0; list_end = 0; /* a new list will follow */ break; }