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
305a315a
Commit
305a315a
authored
Feb 10, 2022
by
Nikolay Sivov
Committed by
Alexandre Julliard
Feb 10, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mfreadwrite/reader: Use resolver functionality for content type resolution.
Signed-off-by:
Nikolay Sivov
<
nsivov@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
0b98026e
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
3 additions
and
99 deletions
+3
-99
reader.c
dlls/mfreadwrite/reader.c
+2
-95
mfplat.c
dlls/mfreadwrite/tests/mfplat.c
+1
-4
No files found.
dlls/mfreadwrite/reader.c
View file @
305a315a
...
@@ -2390,94 +2390,6 @@ failed:
...
@@ -2390,94 +2390,6 @@ failed:
return
hr
;
return
hr
;
}
}
static
HRESULT
bytestream_get_url_hint
(
IMFByteStream
*
stream
,
WCHAR
const
**
url
)
{
static
const
unsigned
char
asfmagic
[]
=
{
0x30
,
0x26
,
0xb2
,
0x75
,
0x8e
,
0x66
,
0xcf
,
0x11
,
0xa6
,
0xd9
,
0x00
,
0xaa
,
0x00
,
0x62
,
0xce
,
0x6c
};
static
const
unsigned
char
wavmagic
[]
=
{
'R'
,
'I'
,
'F'
,
'F'
,
0x00
,
0x00
,
0x00
,
0x00
,
'W'
,
'A'
,
'V'
,
'E'
,
'f'
,
'm'
,
't'
,
' '
};
static
const
unsigned
char
wavmask
[]
=
{
0xff
,
0xff
,
0xff
,
0xff
,
0x00
,
0x00
,
0x00
,
0x00
,
0xff
,
0xff
,
0xff
,
0xff
,
0xff
,
0xff
,
0xff
,
0xff
};
static
const
unsigned
char
isommagic
[]
=
{
0x00
,
0x00
,
0x00
,
0x00
,
'f'
,
't'
,
'y'
,
'p'
,
'i'
,
's'
,
'o'
,
'm'
,
0x00
,
0x00
,
0x00
,
0x00
};
static
const
unsigned
char
mp4_magic
[]
=
{
0x00
,
0x00
,
0x00
,
0x00
,
'f'
,
't'
,
'y'
,
'p'
,
'M'
,
'S'
,
'N'
,
'V'
,
0x00
,
0x00
,
0x00
,
0x00
};
static
const
unsigned
char
mp42magic
[]
=
{
0x00
,
0x00
,
0x00
,
0x00
,
'f'
,
't'
,
'y'
,
'p'
,
'm'
,
'p'
,
'4'
,
'2'
,
0x00
,
0x00
,
0x00
,
0x00
};
static
const
unsigned
char
mp4vmagic
[]
=
{
0x00
,
0x00
,
0x00
,
0x00
,
'f'
,
't'
,
'y'
,
'p'
,
'M'
,
'4'
,
'V'
,
' '
,
0x00
,
0x00
,
0x00
,
0x00
};
static
const
unsigned
char
mp4mask
[]
=
{
0x00
,
0x00
,
0x00
,
0x00
,
0xff
,
0xff
,
0xff
,
0xff
,
0xff
,
0xff
,
0xff
,
0xff
,
0x00
,
0x00
,
0x00
,
0x00
};
static
const
struct
stream_content_url_hint
{
const
unsigned
char
*
magic
;
const
WCHAR
*
url
;
const
unsigned
char
*
mask
;
}
url_hints
[]
=
{
{
asfmagic
,
L".asf"
},
{
wavmagic
,
L".wav"
,
wavmask
},
{
isommagic
,
L".mp4"
,
mp4mask
},
{
mp42magic
,
L".mp4"
,
mp4mask
},
{
mp4_magic
,
L".mp4"
,
mp4mask
},
{
mp4vmagic
,
L".m4v"
,
mp4mask
},
};
unsigned
char
buffer
[
4
*
sizeof
(
unsigned
int
)],
pattern
[
4
*
sizeof
(
unsigned
int
)];
IMFAttributes
*
attributes
;
DWORD
length
=
0
,
caps
=
0
;
unsigned
int
i
,
j
;
QWORD
position
;
HRESULT
hr
;
*
url
=
NULL
;
if
(
SUCCEEDED
(
IMFByteStream_QueryInterface
(
stream
,
&
IID_IMFAttributes
,
(
void
**
)
&
attributes
)))
{
UINT32
string_length
=
0
;
IMFAttributes_GetStringLength
(
attributes
,
&
MF_BYTESTREAM_CONTENT_TYPE
,
&
string_length
);
IMFAttributes_Release
(
attributes
);
if
(
string_length
)
return
S_OK
;
}
if
(
FAILED
(
hr
=
IMFByteStream_GetCapabilities
(
stream
,
&
caps
)))
return
hr
;
if
(
!
(
caps
&
MFBYTESTREAM_IS_SEEKABLE
))
return
S_OK
;
if
(
FAILED
(
hr
=
IMFByteStream_GetCurrentPosition
(
stream
,
&
position
)))
return
hr
;
hr
=
IMFByteStream_Read
(
stream
,
buffer
,
sizeof
(
buffer
),
&
length
);
IMFByteStream_SetCurrentPosition
(
stream
,
position
);
if
(
FAILED
(
hr
))
return
hr
;
if
(
length
<
sizeof
(
buffer
))
return
S_OK
;
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
url_hints
);
++
i
)
{
memcpy
(
pattern
,
buffer
,
sizeof
(
buffer
));
if
(
url_hints
[
i
].
mask
)
{
unsigned
int
*
mask
=
(
unsigned
int
*
)
url_hints
[
i
].
mask
;
unsigned
int
*
data
=
(
unsigned
int
*
)
pattern
;
for
(
j
=
0
;
j
<
sizeof
(
buffer
)
/
sizeof
(
unsigned
int
);
++
j
)
data
[
j
]
&=
mask
[
j
];
}
if
(
!
memcmp
(
pattern
,
url_hints
[
i
].
magic
,
sizeof
(
pattern
)))
{
*
url
=
url_hints
[
i
].
url
;
break
;
}
}
if
(
*
url
)
TRACE
(
"Stream type guessed as %s from %s.
\n
"
,
debugstr_w
(
*
url
),
debugstr_an
((
char
*
)
buffer
,
length
));
else
WARN
(
"Unrecognized content type %s.
\n
"
,
debugstr_an
((
char
*
)
buffer
,
length
));
return
S_OK
;
}
static
HRESULT
create_source_reader_from_stream
(
IMFByteStream
*
stream
,
IMFAttributes
*
attributes
,
static
HRESULT
create_source_reader_from_stream
(
IMFByteStream
*
stream
,
IMFAttributes
*
attributes
,
REFIID
riid
,
void
**
out
)
REFIID
riid
,
void
**
out
)
{
{
...
@@ -2485,13 +2397,8 @@ static HRESULT create_source_reader_from_stream(IMFByteStream *stream, IMFAttrib
...
@@ -2485,13 +2397,8 @@ static HRESULT create_source_reader_from_stream(IMFByteStream *stream, IMFAttrib
IMFSourceResolver
*
resolver
;
IMFSourceResolver
*
resolver
;
MF_OBJECT_TYPE
obj_type
;
MF_OBJECT_TYPE
obj_type
;
IMFMediaSource
*
source
;
IMFMediaSource
*
source
;
const
WCHAR
*
url
;
HRESULT
hr
;
HRESULT
hr
;
/* If stream does not have content type set, try to guess from starting byte sequence. */
if
(
FAILED
(
hr
=
bytestream_get_url_hint
(
stream
,
&
url
)))
return
hr
;
if
(
FAILED
(
hr
=
MFCreateSourceResolver
(
&
resolver
)))
if
(
FAILED
(
hr
=
MFCreateSourceResolver
(
&
resolver
)))
return
hr
;
return
hr
;
...
@@ -2499,8 +2406,8 @@ static HRESULT create_source_reader_from_stream(IMFByteStream *stream, IMFAttrib
...
@@ -2499,8 +2406,8 @@ static HRESULT create_source_reader_from_stream(IMFByteStream *stream, IMFAttrib
IMFAttributes_GetUnknown
(
attributes
,
&
MF_SOURCE_READER_MEDIASOURCE_CONFIG
,
&
IID_IPropertyStore
,
IMFAttributes_GetUnknown
(
attributes
,
&
MF_SOURCE_READER_MEDIASOURCE_CONFIG
,
&
IID_IPropertyStore
,
(
void
**
)
&
props
);
(
void
**
)
&
props
);
hr
=
IMFSourceResolver_CreateObjectFromByteStream
(
resolver
,
stream
,
url
,
MF_RESOLUTION_MEDIASOURCE
,
props
,
hr
=
IMFSourceResolver_CreateObjectFromByteStream
(
resolver
,
stream
,
NULL
,
MF_RESOLUTION_MEDIASOURCE
&
obj_type
,
(
IUnknown
**
)
&
source
);
|
MF_RESOLUTION_CONTENT_DOES_NOT_HAVE_TO_MATCH_EXTENSION_OR_MIME_TYPE
,
props
,
&
obj_type
,
(
IUnknown
**
)
&
source
);
IMFSourceResolver_Release
(
resolver
);
IMFSourceResolver_Release
(
resolver
);
if
(
props
)
if
(
props
)
IPropertyStore_Release
(
props
);
IPropertyStore_Release
(
props
);
...
...
dlls/mfreadwrite/tests/mfplat.c
View file @
305a315a
...
@@ -877,13 +877,10 @@ skip_read_sample:
...
@@ -877,13 +877,10 @@ skip_read_sample:
refcount
=
get_refcount
(
attributes
);
refcount
=
get_refcount
(
attributes
);
hr
=
MFCreateSourceReaderFromByteStream
(
stream
,
attributes
,
&
reader
);
hr
=
MFCreateSourceReaderFromByteStream
(
stream
,
attributes
,
&
reader
);
todo_wine
{
ok
(
hr
==
S_OK
,
"Failed to create source reader, hr %#x.
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"Failed to create source reader, hr %#x.
\n
"
,
hr
);
ok
(
get_refcount
(
attributes
)
>
refcount
,
"Unexpected refcount.
\n
"
);
ok
(
get_refcount
(
attributes
)
>
refcount
,
"Unexpected refcount.
\n
"
);
}
IMFAttributes_Release
(
attributes
);
IMFAttributes_Release
(
attributes
);
if
(
hr
==
S_OK
)
IMFSourceReader_Release
(
reader
);
IMFSourceReader_Release
(
reader
);
IMFByteStream_Release
(
stream
);
IMFByteStream_Release
(
stream
);
}
}
...
...
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