diff --git a/dlls/avifil32/avifile.c b/dlls/avifil32/avifile.c index f6503fc60c1..8127d608448 100644 --- a/dlls/avifil32/avifile.c +++ b/dlls/avifil32/avifile.c @@ -840,14 +840,18 @@ static LONG WINAPI IAVIStream_fnFindSample(IAVIStream *iface, LONG pos, ULONG 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; + } } else { LONG 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; + } } if (pos > (LONG)This->sInfo.dwStart) @@ -858,30 +862,34 @@ static LONG WINAPI IAVIStream_fnFindSample(IAVIStream *iface, LONG pos, return -1; } - if (flags & FIND_RET) { - RETURN_FOUND: - if (flags & FIND_LENGTH) { - /* 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!"); + RETURN_FOUND: + if (pos < (LONG)This->sInfo.dwStart) + return -1; - pos = This->paf->dwIdxChunkPos; - } /* else logical position */ + switch (flags & FIND_RET) { + 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 -1; + return pos; } static HRESULT WINAPI IAVIStream_fnReadFormat(IAVIStream *iface, LONG pos, diff --git a/dlls/avifil32/wavfile.c b/dlls/avifil32/wavfile.c index 214fc63a3d2..e645fd1c6a7 100644 --- a/dlls/avifil32/wavfile.c +++ b/dlls/avifil32/wavfile.c @@ -757,9 +757,10 @@ static LONG WINAPI IAVIStream_fnFindSample(IAVIStream *iface, LONG pos, pos = 0; } - if (flags & (FIND_LENGTH|FIND_SIZE)) + if ((flags & FIND_RET) == FIND_LENGTH || + (flags & FIND_RET) == FIND_SIZE) return This->sInfo.dwSampleSize; - if (flags & FIND_OFFSET) + if ((flags & FIND_RET) == FIND_OFFSET) return This->ckData.dwDataOffset + pos * This->sInfo.dwSampleSize; return pos;