Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
94ef3740
Commit
94ef3740
authored
Jul 24, 2008
by
Maarten Lankhorst
Committed by
Alexandre Julliard
Jul 29, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
quartz: Fix support for files with multiple odml indexes.
parent
6becc9e1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
11 additions
and
12 deletions
+11
-12
avisplit.c
dlls/quartz/avisplit.c
+11
-12
No files found.
dlls/quartz/avisplit.c
View file @
94ef3740
...
...
@@ -183,7 +183,7 @@ static HRESULT AVISplitter_next_request(AVISplitterImpl *This, DWORD streamnumbe
/* End of file */
if
(
stream
->
index
>=
stream
->
entries
)
{
ERR
(
"END OF STREAM ON %u
\n
"
,
streamnumber
);
TRACE
(
"END OF STREAM ON %u
\n
"
,
streamnumber
);
IMediaSample_Release
(
sample
);
return
S_FALSE
;
}
...
...
@@ -213,8 +213,8 @@ static HRESULT AVISplitter_next_request(AVISplitterImpl *This, DWORD streamnumbe
/* End of file */
if
(
stream
->
index
)
{
TRACE
(
"END OF STREAM ON %u
\n
"
,
streamnumber
);
IMediaSample_Release
(
sample
);
ERR
(
"END OF STREAM ON %u
\n
"
,
streamnumber
);
return
S_FALSE
;
}
...
...
@@ -502,6 +502,7 @@ static HRESULT AVISplitter_done_process(LPVOID iface)
ResetEvent
(
stream
->
packet_queued
);
}
FIXME
(
"All threads are now terminated
\n
"
);
return
S_OK
;
}
...
...
@@ -516,8 +517,7 @@ static HRESULT AVISplitter_QueryAccept(LPVOID iface, const AM_MEDIA_TYPE * pmt)
static
HRESULT
AVISplitter_ProcessIndex
(
AVISplitterImpl
*
This
,
AVISTDINDEX
**
index
,
LONGLONG
qwOffset
,
DWORD
cb
)
{
AVISTDINDEX
*
pIndex
;
int
x
;
long
rest
;
int
x
,
rest
;
*
index
=
NULL
;
if
(
cb
<
sizeof
(
AVISTDINDEX
))
...
...
@@ -531,12 +531,7 @@ static HRESULT AVISplitter_ProcessIndex(AVISplitterImpl *This, AVISTDINDEX **ind
return
E_OUTOFMEMORY
;
IAsyncReader_SyncRead
(((
PullPin
*
)
This
->
Parser
.
ppPins
[
0
])
->
pReader
,
qwOffset
,
cb
,
(
BYTE
*
)
pIndex
);
pIndex
=
CoTaskMemRealloc
(
pIndex
,
pIndex
->
cb
);
if
(
!
pIndex
)
return
E_OUTOFMEMORY
;
IAsyncReader_SyncRead
(((
PullPin
*
)
This
->
Parser
.
ppPins
[
0
])
->
pReader
,
qwOffset
,
pIndex
->
cb
,
(
BYTE
*
)
pIndex
);
rest
=
pIndex
->
cb
-
sizeof
(
AVISUPERINDEX
)
+
sizeof
(
RIFFCHUNK
)
+
sizeof
(
pIndex
->
aIndex
[
0
])
*
ANYSIZE_ARRAY
;
rest
=
cb
-
sizeof
(
AVISUPERINDEX
)
+
sizeof
(
RIFFCHUNK
)
+
sizeof
(
pIndex
->
aIndex
);
TRACE
(
"FOURCC: %s
\n
"
,
debugstr_an
((
char
*
)
&
pIndex
->
fcc
,
4
));
TRACE
(
"wLongsPerEntry: %hd
\n
"
,
pIndex
->
wLongsPerEntry
);
...
...
@@ -552,7 +547,11 @@ static HRESULT AVISplitter_ProcessIndex(AVISplitterImpl *This, AVISTDINDEX **ind
||
rest
<
(
pIndex
->
nEntriesInUse
*
sizeof
(
DWORD
)
*
pIndex
->
wLongsPerEntry
)
||
(
pIndex
->
bIndexSubType
!=
AVI_INDEX_SUB_DEFAULT
))
{
FIXME
(
"Invalid index chunk encountered
\n
"
);
FIXME
(
"Invalid index chunk encountered: %u/%u, %u/%u, %u/%u, %u/%u
\n
"
,
pIndex
->
bIndexType
,
AVI_INDEX_OF_CHUNKS
,
pIndex
->
wLongsPerEntry
,
2
,
rest
,
(
pIndex
->
nEntriesInUse
*
sizeof
(
DWORD
)
*
pIndex
->
wLongsPerEntry
),
pIndex
->
bIndexSubType
,
AVI_INDEX_SUB_DEFAULT
);
*
index
=
NULL
;
return
E_INVALIDARG
;
}
...
...
@@ -814,7 +813,7 @@ static HRESULT AVISplitter_ProcessStreamList(AVISplitterImpl * This, const BYTE
TRACE
(
"dwSize: %u
\n
"
,
pIndex
->
aIndex
[
x
].
dwSize
);
TRACE
(
"dwDuration: %u (unreliable)
\n
"
,
pIndex
->
aIndex
[
x
].
dwDuration
);
AVISplitter_ProcessIndex
(
This
,
&
stream
->
stdindex
[
nstdindex
-
1
],
pIndex
->
aIndex
[
x
].
qwOffset
,
pIndex
->
aIndex
[
x
].
dwSize
);
AVISplitter_ProcessIndex
(
This
,
&
stream
->
stdindex
[
x
],
pIndex
->
aIndex
[
x
].
qwOffset
,
pIndex
->
aIndex
[
x
].
dwSize
);
}
break
;
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment