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
16258171
Commit
16258171
authored
Apr 16, 2008
by
Maarten Lankhorst
Committed by
Alexandre Julliard
Apr 17, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
quartz: Store the stream index in the avi stream for files that have them.
parent
a0e8b97f
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
45 additions
and
4 deletions
+45
-4
avisplit.c
dlls/quartz/avisplit.c
+45
-4
No files found.
dlls/quartz/avisplit.c
View file @
16258171
...
@@ -360,12 +360,13 @@ static HRESULT AVISplitter_QueryAccept(LPVOID iface, const AM_MEDIA_TYPE * pmt)
...
@@ -360,12 +360,13 @@ static HRESULT AVISplitter_QueryAccept(LPVOID iface, const AM_MEDIA_TYPE * pmt)
return
S_FALSE
;
return
S_FALSE
;
}
}
static
HRESULT
AVISplitter_ProcessIndex
(
AVISplitterImpl
*
This
,
LONGLONG
qwOffset
,
DWORD
cb
)
static
HRESULT
AVISplitter_ProcessIndex
(
AVISplitterImpl
*
This
,
AVISTDINDEX
**
index
,
LONGLONG
qwOffset
,
DWORD
cb
)
{
{
AVISTDINDEX
*
pIndex
;
AVISTDINDEX
*
pIndex
;
int
x
;
int
x
;
long
rest
;
long
rest
;
*
index
=
NULL
;
if
(
cb
<
sizeof
(
AVISTDINDEX
))
if
(
cb
<
sizeof
(
AVISTDINDEX
))
{
{
FIXME
(
"size %u too small
\n
"
,
cb
);
FIXME
(
"size %u too small
\n
"
,
cb
);
...
@@ -410,7 +411,7 @@ static HRESULT AVISplitter_ProcessIndex(AVISplitterImpl *This, LONGLONG qwOffset
...
@@ -410,7 +411,7 @@ static HRESULT AVISplitter_ProcessIndex(AVISplitterImpl *This, LONGLONG qwOffset
TRACE
(
"Frame is a keyframe: %s
\n
"
,
keyframe
?
"yes"
:
"no"
);
TRACE
(
"Frame is a keyframe: %s
\n
"
,
keyframe
?
"yes"
:
"no"
);
}
}
CoTaskMemFree
(
pIndex
)
;
*
index
=
pIndex
;
return
S_OK
;
return
S_OK
;
}
}
...
@@ -482,6 +483,10 @@ static HRESULT AVISplitter_ProcessStreamList(AVISplitterImpl * This, const BYTE
...
@@ -482,6 +483,10 @@ static HRESULT AVISplitter_ProcessStreamList(AVISplitterImpl * This, const BYTE
static
const
WCHAR
wszStreamTemplate
[]
=
{
'S'
,
't'
,
'r'
,
'e'
,
'a'
,
'm'
,
' '
,
'%'
,
'0'
,
'2'
,
'd'
,
0
};
static
const
WCHAR
wszStreamTemplate
[]
=
{
'S'
,
't'
,
'r'
,
'e'
,
'a'
,
'm'
,
' '
,
'%'
,
'0'
,
'2'
,
'd'
,
0
};
StreamData
*
stream
;
StreamData
*
stream
;
AVISUPERINDEX
*
superindex
=
NULL
;
AVISTDINDEX
**
stdindex
=
NULL
;
DWORD
nstdindex
=
0
;
props
.
cbAlign
=
1
;
props
.
cbAlign
=
1
;
props
.
cbPrefix
=
0
;
props
.
cbPrefix
=
0
;
props
.
cbBuffer
=
0x20000
;
props
.
cbBuffer
=
0x20000
;
...
@@ -598,6 +603,12 @@ static HRESULT AVISplitter_ProcessStreamList(AVISplitterImpl * This, const BYTE
...
@@ -598,6 +603,12 @@ static HRESULT AVISplitter_ProcessStreamList(AVISplitterImpl * This, const BYTE
break
;
break
;
}
}
if
(
nstdindex
>
0
)
{
ERR
(
"Stream %d got more then 1 superindex?
\n
"
,
This
->
Parser
.
cStreams
);
break
;
}
TRACE
(
"wLongsPerEntry: %hd
\n
"
,
pIndex
->
wLongsPerEntry
);
TRACE
(
"wLongsPerEntry: %hd
\n
"
,
pIndex
->
wLongsPerEntry
);
TRACE
(
"bIndexSubType: %hd
\n
"
,
pIndex
->
bIndexSubType
);
TRACE
(
"bIndexSubType: %hd
\n
"
,
pIndex
->
bIndexSubType
);
TRACE
(
"bIndexType: %hd
\n
"
,
pIndex
->
bIndexType
);
TRACE
(
"bIndexType: %hd
\n
"
,
pIndex
->
bIndexType
);
...
@@ -618,13 +629,24 @@ static HRESULT AVISplitter_ProcessStreamList(AVISplitterImpl * This, const BYTE
...
@@ -618,13 +629,24 @@ static HRESULT AVISplitter_ProcessStreamList(AVISplitterImpl * This, const BYTE
FIXME
(
"Invalid index chunk encountered
\n
"
);
FIXME
(
"Invalid index chunk encountered
\n
"
);
break
;
break
;
}
}
superindex
=
CoTaskMemAlloc
(
pIndex
->
cb
+
sizeof
(
RIFFCHUNK
));
if
(
!
superindex
)
{
WARN
(
"Out of memory
\n
"
);
break
;
}
memcpy
(
superindex
,
pIndex
,
pIndex
->
cb
+
sizeof
(
RIFFCHUNK
));
for
(
x
=
0
;
x
<
pIndex
->
nEntriesInUse
;
++
x
)
for
(
x
=
0
;
x
<
pIndex
->
nEntriesInUse
;
++
x
)
{
{
TRACE
(
"qwOffset: %x%08x
\n
"
,
(
DWORD
)(
pIndex
->
aIndex
[
x
].
qwOffset
>>
32
),
(
DWORD
)
pIndex
->
aIndex
[
x
].
qwOffset
);
TRACE
(
"qwOffset: %x%08x
\n
"
,
(
DWORD
)(
pIndex
->
aIndex
[
x
].
qwOffset
>>
32
),
(
DWORD
)
pIndex
->
aIndex
[
x
].
qwOffset
);
TRACE
(
"dwSize: %u
\n
"
,
pIndex
->
aIndex
[
x
].
dwSize
);
TRACE
(
"dwSize: %u
\n
"
,
pIndex
->
aIndex
[
x
].
dwSize
);
AVISplitter_ProcessIndex
(
This
,
pIndex
->
aIndex
[
x
].
qwOffset
,
pIndex
->
aIndex
[
x
].
dwSize
);
TRACE
(
"dwDuration: %u (unreliable)
\n
"
,
pIndex
->
aIndex
[
x
].
dwDuration
);
TRACE
(
"dwDuration: %u (unreliable)
\n
"
,
pIndex
->
aIndex
[
x
].
dwDuration
);
++
nstdindex
;
stdindex
=
CoTaskMemRealloc
(
stdindex
,
sizeof
(
*
stdindex
)
*
nstdindex
);
AVISplitter_ProcessIndex
(
This
,
&
stdindex
[
nstdindex
-
1
],
pIndex
->
aIndex
[
x
].
qwOffset
,
pIndex
->
aIndex
[
x
].
dwSize
);
}
}
break
;
break
;
}
}
...
@@ -644,10 +666,14 @@ static HRESULT AVISplitter_ProcessStreamList(AVISplitterImpl * This, const BYTE
...
@@ -644,10 +666,14 @@ static HRESULT AVISplitter_ProcessStreamList(AVISplitterImpl * This, const BYTE
TRACE
(
"dwSampleSize = %x
\n
"
,
dwSampleSize
);
TRACE
(
"dwSampleSize = %x
\n
"
,
dwSampleSize
);
TRACE
(
"dwLength = %x
\n
"
,
dwLength
);
TRACE
(
"dwLength = %x
\n
"
,
dwLength
);
This
->
streams
=
CoTaskMemRealloc
(
This
->
streams
,
sizeof
(
StreamData
)
*
(
This
->
Parser
.
cStreams
+
1
));
This
->
streams
=
CoTaskMemRealloc
(
This
->
streams
,
sizeof
(
StreamData
)
*
(
This
->
Parser
.
cStreams
+
1
));
stream
=
This
->
streams
+
This
->
Parser
.
cStreams
;
stream
=
This
->
streams
+
This
->
Parser
.
cStreams
;
stream
->
fSamplesPerSec
=
fSamplesPerSec
;
stream
->
fSamplesPerSec
=
fSamplesPerSec
;
stream
->
dwSampleSize
=
dwSampleSize
;
stream
->
dwSampleSize
=
dwSampleSize
;
stream
->
dwLength
=
dwLength
;
/* TODO: Use this for mediaseeking */
stream
->
dwLength
=
dwLength
;
/* TODO: Use this for mediaseeking */
stream
->
superindex
=
superindex
;
stream
->
entries
=
nstdindex
;
stream
->
stdindex
=
stdindex
;
hr
=
Parser_AddPin
(
&
(
This
->
Parser
),
&
piOutput
,
&
props
,
&
amt
);
hr
=
Parser_AddPin
(
&
(
This
->
Parser
),
&
piOutput
,
&
props
,
&
amt
);
CoTaskMemFree
(
amt
.
pbFormat
);
CoTaskMemFree
(
amt
.
pbFormat
);
...
@@ -862,11 +888,26 @@ static HRESULT AVISplitter_Cleanup(LPVOID iface)
...
@@ -862,11 +888,26 @@ static HRESULT AVISplitter_Cleanup(LPVOID iface)
static
HRESULT
AVISplitter_Disconnect
(
LPVOID
iface
)
static
HRESULT
AVISplitter_Disconnect
(
LPVOID
iface
)
{
{
AVISplitterImpl
*
This
=
iface
;
AVISplitterImpl
*
This
=
iface
;
int
x
;
/* TODO: Remove other memory that's allocated during connect */
/* TODO: Remove other memory that's allocated during connect */
CoTaskMemFree
(
This
->
oldindex
);
CoTaskMemFree
(
This
->
oldindex
);
This
->
oldindex
=
NULL
;
This
->
oldindex
=
NULL
;
for
(
x
=
0
;
x
<
This
->
Parser
.
cStreams
;
++
x
)
{
int
i
;
StreamData
*
stream
=
&
This
->
streams
[
x
];
for
(
i
=
0
;
i
<
stream
->
entries
;
++
i
)
CoTaskMemFree
(
stream
->
stdindex
[
i
]);
CoTaskMemFree
(
stream
->
stdindex
);
CoTaskMemFree
(
stream
->
superindex
);
}
CoTaskMemFree
(
This
->
streams
);
return
S_OK
;
return
S_OK
;
}
}
...
...
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