Fixed multiple bugs in FindSample implementation of AVI and WAV file

handler.
This commit is contained in:
Michael Günnewig 2003-11-26 22:04:29 +00:00 committed by Alexandre Julliard
parent 12f7a36132
commit edd8bc3a77
2 changed files with 35 additions and 26 deletions

View File

@ -840,14 +840,18 @@ static LONG WINAPI IAVIStream_fnFindSample(IAVIStream *iface, LONG pos,
ULONG n; ULONG n;
for (n = 0; n < This->sInfo.dwFormatChangeCount; n++) for (n = 0; n < This->sInfo.dwFormatChangeCount; n++)
if (This->idxFmtChanges[n].ckid >= pos) if (This->idxFmtChanges[n].ckid >= pos) {
pos = This->idxFmtChanges[n].ckid;
goto RETURN_FOUND; goto RETURN_FOUND;
}
} else { } else {
LONG n; LONG n;
for (n = (LONG)This->sInfo.dwFormatChangeCount; n >= 0; n--) { for (n = (LONG)This->sInfo.dwFormatChangeCount; n >= 0; n--) {
if (This->idxFmtChanges[n].ckid <= pos) if (This->idxFmtChanges[n].ckid <= pos) {
pos = This->idxFmtChanges[n].ckid;
goto RETURN_FOUND; goto RETURN_FOUND;
}
} }
if (pos > (LONG)This->sInfo.dwStart) if (pos > (LONG)This->sInfo.dwStart)
@ -858,30 +862,34 @@ static LONG WINAPI IAVIStream_fnFindSample(IAVIStream *iface, LONG pos,
return -1; return -1;
} }
if (flags & FIND_RET) { RETURN_FOUND:
RETURN_FOUND: if (pos < (LONG)This->sInfo.dwStart)
if (flags & FIND_LENGTH) { return -1;
/* logical size */
if (This->sInfo.dwSampleSize)
pos = This->sInfo.dwSampleSize;
else
pos = 1;
} else if (flags & FIND_OFFSET) {
/* physical position */
pos = This->idxFrames[pos].dwChunkOffset + offset * This->sInfo.dwSampleSize;
} else if (flags & FIND_SIZE) {
/* physical size */
pos = This->idxFrames[pos].dwChunkLength;
} else if (flags & FIND_INDEX) {
FIXME(": FIND_INDEX flag is not supported!");
pos = This->paf->dwIdxChunkPos; switch (flags & FIND_RET) {
} /* else logical position */ case FIND_LENGTH:
/* physical size */
pos = This->idxFrames[pos].dwChunkLength;
break;
case FIND_OFFSET:
/* physical position */
pos = This->idxFrames[pos].dwChunkOffset + 2 * sizeof(DWORD)
+ offset * This->sInfo.dwSampleSize;
break;
case FIND_SIZE:
/* logical size */
if (This->sInfo.dwSampleSize)
pos = This->sInfo.dwSampleSize;
else
pos = 1;
break;
case FIND_INDEX:
FIXME(": FIND_INDEX flag is not supported!\n");
/* This is an index in the index-table on disc. */
break;
}; /* else logical position */
return pos; return pos;
}
return -1;
} }
static HRESULT WINAPI IAVIStream_fnReadFormat(IAVIStream *iface, LONG pos, static HRESULT WINAPI IAVIStream_fnReadFormat(IAVIStream *iface, LONG pos,

View File

@ -757,9 +757,10 @@ static LONG WINAPI IAVIStream_fnFindSample(IAVIStream *iface, LONG pos,
pos = 0; pos = 0;
} }
if (flags & (FIND_LENGTH|FIND_SIZE)) if ((flags & FIND_RET) == FIND_LENGTH ||
(flags & FIND_RET) == FIND_SIZE)
return This->sInfo.dwSampleSize; return This->sInfo.dwSampleSize;
if (flags & FIND_OFFSET) if ((flags & FIND_RET) == FIND_OFFSET)
return This->ckData.dwDataOffset + pos * This->sInfo.dwSampleSize; return This->ckData.dwDataOffset + pos * This->sInfo.dwSampleSize;
return pos; return pos;