Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
3376ba61
Commit
3376ba61
authored
Jul 21, 2008
by
Maarten Lankhorst
Committed by
Alexandre Julliard
Jul 22, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
quartz: Fix end of stream handling in avi splitter.
The last frame wouldn't always be sent, this fixes that.
parent
396eea60
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
15 deletions
+21
-15
avisplit.c
dlls/quartz/avisplit.c
+21
-15
No files found.
dlls/quartz/avisplit.c
View file @
3376ba61
...
@@ -180,6 +180,14 @@ static HRESULT AVISplitter_next_request(AVISplitterImpl *This, DWORD streamnumbe
...
@@ -180,6 +180,14 @@ static HRESULT AVISplitter_next_request(AVISplitterImpl *This, DWORD streamnumbe
AVISTDINDEX_ENTRY
*
entry
=
&
index
->
aIndex
[
stream
->
pos
];
AVISTDINDEX_ENTRY
*
entry
=
&
index
->
aIndex
[
stream
->
pos
];
BOOL
keyframe
;
BOOL
keyframe
;
/* End of file */
if
(
stream
->
index
>=
stream
->
entries
)
{
ERR
(
"END OF STREAM ON %u
\n
"
,
streamnumber
);
IMediaSample_Release
(
sample
);
return
S_FALSE
;
}
rtSampleStart
=
index
->
qwBaseOffset
;
rtSampleStart
=
index
->
qwBaseOffset
;
keyframe
=
!
(
entry
->
dwSize
>>
31
);
keyframe
=
!
(
entry
->
dwSize
>>
31
);
rtSampleStart
+=
entry
->
dwOffset
;
rtSampleStart
+=
entry
->
dwOffset
;
...
@@ -195,21 +203,21 @@ static HRESULT AVISplitter_next_request(AVISplitterImpl *This, DWORD streamnumbe
...
@@ -195,21 +203,21 @@ static HRESULT AVISplitter_next_request(AVISplitterImpl *This, DWORD streamnumbe
rtSampleStop
=
rtSampleStart
+
MEDIATIME_FROM_BYTES
(
entry
->
dwSize
&
~
(
1
<<
31
));
rtSampleStop
=
rtSampleStart
+
MEDIATIME_FROM_BYTES
(
entry
->
dwSize
&
~
(
1
<<
31
));
TRACE
(
"offset(%u) size(%u)
\n
"
,
(
DWORD
)
BYTES_FROM_MEDIATIME
(
rtSampleStart
),
(
DWORD
)
BYTES_FROM_MEDIATIME
(
rtSampleStop
-
rtSampleStart
));
TRACE
(
"offset(%u) size(%u)
\n
"
,
(
DWORD
)
BYTES_FROM_MEDIATIME
(
rtSampleStart
),
(
DWORD
)
BYTES_FROM_MEDIATIME
(
rtSampleStop
-
rtSampleStart
));
/* End of file */
if
(
stream
->
index
>=
stream
->
entries
)
{
ERR
(
"END OF STREAM ON %u
\n
"
,
streamnumber
);
IMediaSample_Release
(
sample
);
hr
=
AVISplitter_SendEndOfFile
(
This
,
streamnumber
);
return
S_FALSE
;
}
}
}
else
if
(
This
->
oldindex
)
else
if
(
This
->
oldindex
)
{
{
DWORD
flags
=
This
->
oldindex
->
aIndex
[
stream
->
pos
].
dwFlags
;
DWORD
flags
=
This
->
oldindex
->
aIndex
[
stream
->
pos
].
dwFlags
;
DWORD
size
=
This
->
oldindex
->
aIndex
[
stream
->
pos
].
dwSize
;
DWORD
size
=
This
->
oldindex
->
aIndex
[
stream
->
pos
].
dwSize
;
BOOL
keyframe
;
BOOL
keyframe
;
/* End of file */
if
(
stream
->
index
)
{
IMediaSample_Release
(
sample
);
ERR
(
"END OF STREAM ON %u
\n
"
,
streamnumber
);
return
S_FALSE
;
}
keyframe
=
!!
(
flags
&
AVIIF_KEYFRAME
);
keyframe
=
!!
(
flags
&
AVIIF_KEYFRAME
);
rtSampleStart
=
MEDIATIME_FROM_BYTES
(
This
->
offset
);
rtSampleStart
=
MEDIATIME_FROM_BYTES
(
This
->
offset
);
...
@@ -237,15 +245,11 @@ static HRESULT AVISplitter_next_request(AVISplitterImpl *This, DWORD streamnumbe
...
@@ -237,15 +245,11 @@ static HRESULT AVISplitter_next_request(AVISplitterImpl *This, DWORD streamnumbe
}
while
(
stream
->
pos_next
*
sizeof
(
This
->
oldindex
->
aIndex
[
0
])
<
This
->
oldindex
->
cb
}
while
(
stream
->
pos_next
*
sizeof
(
This
->
oldindex
->
aIndex
[
0
])
<
This
->
oldindex
->
cb
&&
StreamFromFOURCC
(
This
->
oldindex
->
aIndex
[
stream
->
pos_next
].
dwChunkId
)
!=
streamnumber
);
&&
StreamFromFOURCC
(
This
->
oldindex
->
aIndex
[
stream
->
pos_next
].
dwChunkId
)
!=
streamnumber
);
/* End of file */
/* End of file
soon
*/
if
(
stream
->
index
)
if
(
stream
->
pos_next
*
sizeof
(
This
->
oldindex
->
aIndex
[
0
])
>=
This
->
oldindex
->
cb
)
{
{
IMediaSample_Release
(
sample
);
stream
->
pos_next
=
0
;
stream
->
pos_next
=
0
;
++
stream
->
index_next
;
++
stream
->
index_next
;
ERR
(
"END OF STREAM ON %u
\n
"
,
streamnumber
);
hr
=
AVISplitter_SendEndOfFile
(
This
,
streamnumber
);
return
S_FALSE
;
}
}
}
}
else
/* TODO: Generate an index automagically */
else
/* TODO: Generate an index automagically */
...
@@ -351,6 +355,8 @@ static DWORD WINAPI AVISplitter_thread_reader(LPVOID data)
...
@@ -351,6 +355,8 @@ static DWORD WINAPI AVISplitter_thread_reader(LPVOID data)
IMediaSample_Release
(
sample
);
IMediaSample_Release
(
sample
);
if
(
hr
==
S_OK
)
if
(
hr
==
S_OK
)
hr
=
nexthr
;
hr
=
nexthr
;
if
(
nexthr
==
S_FALSE
)
AVISplitter_SendEndOfFile
(
This
,
streamnumber
);
}
while
(
hr
==
S_OK
);
}
while
(
hr
==
S_OK
);
FIXME
(
"Thread %u terminated with hr %08x!
\n
"
,
streamnumber
,
hr
);
FIXME
(
"Thread %u terminated with hr %08x!
\n
"
,
streamnumber
,
hr
);
...
...
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