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
0bda3a3d
Commit
0bda3a3d
authored
Sep 24, 2020
by
Michael Stefaniuc
Committed by
Alexandre Julliard
Sep 25, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dmime: Reimplement the segment item parser.
Signed-off-by:
Michael Stefaniuc
<
mstefani@winehq.org
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
dbc3449e
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
47 additions
and
87 deletions
+47
-87
segtriggertrack.c
dlls/dmime/segtriggertrack.c
+47
-87
No files found.
dlls/dmime/segtriggertrack.c
View file @
0bda3a3d
...
@@ -24,7 +24,6 @@
...
@@ -24,7 +24,6 @@
#include "wine/heap.h"
#include "wine/heap.h"
WINE_DEFAULT_DEBUG_CHANNEL
(
dmime
);
WINE_DEFAULT_DEBUG_CHANNEL
(
dmime
);
WINE_DECLARE_DEBUG_CHANNEL
(
dmfile
);
/*****************************************************************************
/*****************************************************************************
* IDirectMusicSegTriggerTrack implementation
* IDirectMusicSegTriggerTrack implementation
...
@@ -259,94 +258,55 @@ static inline IDirectMusicSegTriggerTrack *impl_from_IPersistStream(IPersistStre
...
@@ -259,94 +258,55 @@ static inline IDirectMusicSegTriggerTrack *impl_from_IPersistStream(IPersistStre
return
CONTAINING_RECORD
(
iface
,
IDirectMusicSegTriggerTrack
,
dmobj
.
IPersistStream_iface
);
return
CONTAINING_RECORD
(
iface
,
IDirectMusicSegTriggerTrack
,
dmobj
.
IPersistStream_iface
);
}
}
static
HRESULT
parse_segment
(
IDirectMusicSegTriggerTrack
*
This
,
DWORD
size
,
IStream
*
pStm
)
static
HRESULT
parse_segment_item
(
IDirectMusicSegTriggerTrack
*
This
,
IStream
*
stream
,
const
struct
chunk_entry
*
lseg
)
{
{
DMUS_PRIVATE_CHUNK
Chunk
;
struct
chunk_entry
chunk
=
{.
parent
=
lseg
};
DWORD
ListSize
[
3
],
ListCount
[
3
];
DMUS_PRIVATE_SEGMENT_ITEM
*
item
;
LARGE_INTEGER
liMove
;
/* used when skipping chunks */
HRESULT
hr
;
HRESULT
hr
;
/* First chunk is a header */
IDirectMusicObject
*
pObject
=
NULL
;
if
(
stream_get_chunk
(
stream
,
&
chunk
)
!=
S_OK
||
chunk
.
id
!=
DMUS_FOURCC_SEGMENTITEM_CHUNK
)
LPDMUS_PRIVATE_SEGMENT_ITEM
pNewItem
=
NULL
;
return
DMUS_E_TRACK_HDR_NOT_FIRST_CK
;
if
(
!
(
item
=
heap_alloc_zero
(
sizeof
(
*
item
))))
ListSize
[
0
]
=
size
-
sizeof
(
FOURCC
);
return
E_OUTOFMEMORY
;
ListCount
[
0
]
=
0
;
hr
=
stream_chunk_get_data
(
stream
,
&
chunk
,
&
item
->
header
,
sizeof
(
DMUS_IO_SEGMENT_ITEM_HEADER
));
if
(
FAILED
(
hr
))
do
{
goto
error
;
IStream_Read
(
pStm
,
&
Chunk
,
sizeof
(
FOURCC
)
+
sizeof
(
DWORD
),
NULL
);
ListCount
[
0
]
+=
sizeof
(
FOURCC
)
+
sizeof
(
DWORD
)
+
Chunk
.
dwSize
;
TRACE
(
"Found DMUS_IO_SEGMENT_ITEM_HEADER
\n
"
);
TRACE_
(
dmfile
)(
": %s chunk (size = %d)"
,
debugstr_fourcc
(
Chunk
.
fccID
),
Chunk
.
dwSize
);
TRACE
(
"
\t
lTimePhysical: %u
\n
"
,
item
->
header
.
lTimeLogical
);
switch
(
Chunk
.
fccID
)
{
TRACE
(
"
\t
lTimePhysical: %u
\n
"
,
item
->
header
.
lTimePhysical
);
case
DMUS_FOURCC_SEGMENTITEM_CHUNK
:
{
TRACE
(
"
\t
dwPlayFlags: %#08x
\n
"
,
item
->
header
.
dwPlayFlags
);
TRACE_
(
dmfile
)(
": segment item chunk
\n
"
);
TRACE
(
"
\t
dwFlags: %#08x
\n
"
,
item
->
header
.
dwFlags
);
/** alloc new item entry */
pNewItem
=
HeapAlloc
(
GetProcessHeap
(),
HEAP_ZERO_MEMORY
,
sizeof
(
DMUS_PRIVATE_SEGMENT_ITEM
));
/* Second chunk is a reference list */
if
(
!
pNewItem
)
if
(
stream_next_chunk
(
stream
,
&
chunk
)
!=
S_OK
||
chunk
.
id
!=
FOURCC_LIST
||
return
E_OUTOFMEMORY
;
chunk
.
type
!=
DMUS_FOURCC_REF_LIST
)
{
hr
=
DMUS_E_INVALID_SEGMENTTRIGGERTRACK
;
IStream_Read
(
pStm
,
&
pNewItem
->
header
,
sizeof
(
DMUS_IO_SEGMENT_ITEM_HEADER
),
NULL
);
goto
error
;
TRACE_
(
dmfile
)(
" - lTimePhysical: %u
\n
"
,
pNewItem
->
header
.
lTimeLogical
);
TRACE_
(
dmfile
)(
" - lTimePhysical: %u
\n
"
,
pNewItem
->
header
.
lTimePhysical
);
TRACE_
(
dmfile
)(
" - dwPlayFlags: 0x%08x
\n
"
,
pNewItem
->
header
.
dwPlayFlags
);
TRACE_
(
dmfile
)(
" - dwFlags: 0x%08x
\n
"
,
pNewItem
->
header
.
dwFlags
);
list_add_tail
(
&
This
->
Items
,
&
pNewItem
->
entry
);
break
;
}
case
DMUS_FOURCC_SEGMENTITEMNAME_CHUNK
:
{
TRACE_
(
dmfile
)(
": segment item name chunk
\n
"
);
if
(
!
pNewItem
)
{
ERR
(
": pNewItem not allocated, bad chunk order?
\n
"
);
return
E_FAIL
;
}
IStream_Read
(
pStm
,
pNewItem
->
wszName
,
Chunk
.
dwSize
,
NULL
);
TRACE_
(
dmfile
)(
" - name: %s
\n
"
,
debugstr_w
(
pNewItem
->
wszName
));
break
;
}
case
FOURCC_LIST
:
{
struct
chunk_entry
list
=
{.
id
=
FOURCC_LIST
,
.
size
=
Chunk
.
dwSize
};
static
const
LARGE_INTEGER
zero
;
IStream_Seek
(
pStm
,
zero
,
STREAM_SEEK_CUR
,
&
list
.
offset
);
list
.
offset
.
QuadPart
-=
sizeof
(
FOURCC
)
+
sizeof
(
DWORD
);
IStream_Read
(
pStm
,
&
Chunk
.
fccID
,
sizeof
(
FOURCC
),
NULL
);
TRACE_
(
dmfile
)(
": LIST chunk of type %s"
,
debugstr_fourcc
(
Chunk
.
fccID
));
list
.
type
=
Chunk
.
fccID
;
ListSize
[
1
]
=
Chunk
.
dwSize
-
sizeof
(
FOURCC
);
ListCount
[
1
]
=
0
;
switch
(
Chunk
.
fccID
)
{
case
DMUS_FOURCC_REF_LIST
:
{
TRACE_
(
dmfile
)(
": DMRF (DM References) list
\n
"
);
hr
=
dmobj_parsereference
(
pStm
,
&
list
,
&
pObject
);
if
(
FAILED
(
hr
))
{
ERR
(
": could not load Reference
\n
"
);
return
hr
;
}
if
(
!
pNewItem
)
{
ERR
(
": pNewItem not allocated, bad chunk order?
\n
"
);
return
E_FAIL
;
}
pNewItem
->
pObject
=
pObject
;
break
;
}
default:
{
TRACE_
(
dmfile
)(
": unknown (skipping)
\n
"
);
liMove
.
QuadPart
=
Chunk
.
dwSize
-
sizeof
(
FOURCC
);
IStream_Seek
(
pStm
,
liMove
,
STREAM_SEEK_CUR
,
NULL
);
break
;
}
}
break
;
}
default:
{
TRACE_
(
dmfile
)(
": unknown chunk (irrelevant & skipping)
\n
"
);
liMove
.
QuadPart
=
Chunk
.
dwSize
;
IStream_Seek
(
pStm
,
liMove
,
STREAM_SEEK_CUR
,
NULL
);
break
;
}
}
if
(
FAILED
(
hr
=
dmobj_parsereference
(
stream
,
&
chunk
,
&
item
->
pObject
)))
goto
error
;
/* Optional third chunk if the reference is a motif */
if
(
item
->
header
.
dwFlags
&
DMUS_SEGMENTTRACKF_MOTIF
)
{
if
(
FAILED
(
hr
=
stream_next_chunk
(
stream
,
&
chunk
)))
goto
error
;
if
(
chunk
.
id
==
DMUS_FOURCC_SEGMENTITEMNAME_CHUNK
)
if
(
FAILED
(
hr
=
stream_chunk_get_wstr
(
stream
,
&
chunk
,
item
->
wszName
,
DMUS_MAX_NAME
)))
goto
error
;
TRACE
(
"Found motif name: %s
\n
"
,
debugstr_w
(
item
->
wszName
));
}
}
TRACE_
(
dmfile
)(
": ListCount[0] = %d < ListSize[0] = %d
\n
"
,
ListCount
[
0
],
ListSize
[
0
]);
}
while
(
ListCount
[
0
]
<
ListSize
[
0
]);
list_add_tail
(
&
This
->
Items
,
&
item
->
entry
);
return
S_OK
;
return
S_OK
;
error:
heap_free
(
item
);
return
hr
;
}
}
static
HRESULT
parse_segments_list
(
IDirectMusicSegTriggerTrack
*
This
,
IStream
*
stream
,
static
HRESULT
parse_segments_list
(
IDirectMusicSegTriggerTrack
*
This
,
IStream
*
stream
,
...
@@ -359,7 +319,7 @@ static HRESULT parse_segments_list(IDirectMusicSegTriggerTrack *This, IStream *s
...
@@ -359,7 +319,7 @@ static HRESULT parse_segments_list(IDirectMusicSegTriggerTrack *This, IStream *s
while
((
hr
=
stream_next_chunk
(
stream
,
&
chunk
))
==
S_OK
)
while
((
hr
=
stream_next_chunk
(
stream
,
&
chunk
))
==
S_OK
)
if
(
chunk
.
id
==
FOURCC_LIST
&&
chunk
.
type
==
DMUS_FOURCC_SEGMENT_LIST
)
if
(
chunk
.
id
==
FOURCC_LIST
&&
chunk
.
type
==
DMUS_FOURCC_SEGMENT_LIST
)
if
(
FAILED
(
hr
=
parse_segment
(
This
,
stream
,
&
chunk
)))
if
(
FAILED
(
hr
=
parse_segment
_item
(
This
,
stream
,
&
chunk
)))
break
;
break
;
return
SUCCEEDED
(
hr
)
?
S_OK
:
hr
;
return
SUCCEEDED
(
hr
)
?
S_OK
:
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