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
8b831b9d
Commit
8b831b9d
authored
Jan 28, 2016
by
Nikolay Sivov
Committed by
Alexandre Julliard
Jan 29, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dwrite: Return NULL file pointer on CreateCustomFontFileReference() failure.
Signed-off-by:
Nikolay Sivov
<
nsivov@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
a96abff8
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
23 additions
and
0 deletions
+23
-0
main.c
dlls/dwrite/main.c
+2
-0
font.c
dlls/dwrite/tests/font.c
+21
-0
No files found.
dlls/dwrite/main.c
View file @
8b831b9d
...
@@ -779,6 +779,8 @@ static HRESULT WINAPI dwritefactory_CreateCustomFontFileReference(IDWriteFactory
...
@@ -779,6 +779,8 @@ static HRESULT WINAPI dwritefactory_CreateCustomFontFileReference(IDWriteFactory
TRACE
(
"(%p)->(%p %u %p %p)
\n
"
,
This
,
reference_key
,
key_size
,
loader
,
font_file
);
TRACE
(
"(%p)->(%p %u %p %p)
\n
"
,
This
,
reference_key
,
key_size
,
loader
,
font_file
);
*
font_file
=
NULL
;
if
(
!
loader
||
!
factory_get_file_loader
(
This
,
loader
))
if
(
!
loader
||
!
factory_get_file_loader
(
This
,
loader
))
return
E_INVALIDARG
;
return
E_INVALIDARG
;
...
...
dlls/dwrite/tests/font.c
View file @
8b831b9d
...
@@ -666,8 +666,10 @@ if (0)
...
@@ -666,8 +666,10 @@ if (0)
/* null out parameter crashes this call */
/* null out parameter crashes this call */
hr
=
IDWriteGdiInterop_CreateFontFromLOGFONT
(
interop
,
NULL
,
NULL
);
hr
=
IDWriteGdiInterop_CreateFontFromLOGFONT
(
interop
,
NULL
,
NULL
);
font
=
(
void
*
)
0xdeadbeef
;
hr
=
IDWriteGdiInterop_CreateFontFromLOGFONT
(
interop
,
NULL
,
&
font
);
hr
=
IDWriteGdiInterop_CreateFontFromLOGFONT
(
interop
,
NULL
,
&
font
);
EXPECT_HR
(
hr
,
E_INVALIDARG
);
EXPECT_HR
(
hr
,
E_INVALIDARG
);
ok
(
font
==
NULL
,
"got %p
\n
"
,
font
);
memset
(
&
logfont
,
0
,
sizeof
(
logfont
));
memset
(
&
logfont
,
0
,
sizeof
(
logfont
));
logfont
.
lfHeight
=
12
;
logfont
.
lfHeight
=
12
;
...
@@ -1356,15 +1358,22 @@ if (0) /* crashes on native */
...
@@ -1356,15 +1358,22 @@ if (0) /* crashes on native */
todo_wine
todo_wine
ok
(
hr
==
DWRITE_E_UNSUPPORTEDOPERATION
||
broken
(
hr
==
E_INVALIDARG
)
/* older versions */
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
DWRITE_E_UNSUPPORTEDOPERATION
||
broken
(
hr
==
E_INVALIDARG
)
/* older versions */
,
"got 0x%08x
\n
"
,
hr
);
fontface
=
(
void
*
)
0xdeadbeef
;
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
DWRITE_FONT_FACE_TYPE_TYPE1
,
1
,
&
file
,
0
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
fontface
);
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
DWRITE_FONT_FACE_TYPE_TYPE1
,
1
,
&
file
,
0
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
fontface
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
fontface
==
NULL
,
"got %p
\n
"
,
fontface
);
fontface
=
(
void
*
)
0xdeadbeef
;
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
DWRITE_FONT_FACE_TYPE_VECTOR
,
1
,
&
file
,
0
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
fontface
);
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
DWRITE_FONT_FACE_TYPE_VECTOR
,
1
,
&
file
,
0
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
fontface
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
fontface
==
NULL
,
"got %p
\n
"
,
fontface
);
fontface
=
(
void
*
)
0xdeadbeef
;
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
DWRITE_FONT_FACE_TYPE_BITMAP
,
1
,
&
file
,
0
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
fontface
);
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
DWRITE_FONT_FACE_TYPE_BITMAP
,
1
,
&
file
,
0
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
fontface
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
fontface
==
NULL
,
"got %p
\n
"
,
fontface
);
fontface
=
NULL
;
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
DWRITE_FONT_FACE_TYPE_UNKNOWN
,
1
,
&
file
,
0
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
fontface
);
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
DWRITE_FONT_FACE_TYPE_UNKNOWN
,
1
,
&
file
,
0
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
fontface
);
todo_wine
todo_wine
ok
(
hr
==
S_OK
||
broken
(
hr
==
E_INVALIDARG
)
/* < win10 */
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
||
broken
(
hr
==
E_INVALIDARG
)
/* < win10 */
,
"got 0x%08x
\n
"
,
hr
);
...
@@ -1867,8 +1876,10 @@ static void test_CustomFontCollection(void)
...
@@ -1867,8 +1876,10 @@ static void test_CustomFontCollection(void)
hr
=
IDWriteFactory_RegisterFontCollectionLoader
(
factory
,
&
resource_collection
.
IDWriteFontFileCollectionLoader_iface
);
hr
=
IDWriteFactory_RegisterFontCollectionLoader
(
factory
,
&
resource_collection
.
IDWriteFontFileCollectionLoader_iface
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
font_collection
=
(
void
*
)
0xdeadbeef
;
hr
=
IDWriteFactory_CreateCustomFontCollection
(
factory
,
&
collection3
,
"Billy"
,
6
,
&
font_collection
);
hr
=
IDWriteFactory_CreateCustomFontCollection
(
factory
,
&
collection3
,
"Billy"
,
6
,
&
font_collection
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
font_collection
==
NULL
,
"got %p
\n
"
,
font_collection
);
hr
=
IDWriteFactory_CreateCustomFontCollection
(
factory
,
&
collection
,
"Billy"
,
6
,
&
font_collection
);
hr
=
IDWriteFactory_CreateCustomFontCollection
(
factory
,
&
collection
,
"Billy"
,
6
,
&
font_collection
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
...
@@ -1878,8 +1889,10 @@ static void test_CustomFontCollection(void)
...
@@ -1878,8 +1889,10 @@ static void test_CustomFontCollection(void)
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
IDWriteFontCollection_Release
(
font_collection
);
IDWriteFontCollection_Release
(
font_collection
);
font_collection
=
(
void
*
)
0xdeadbeef
;
hr
=
IDWriteFactory_CreateCustomFontCollection
(
factory
,
(
IDWriteFontCollectionLoader
*
)
0xdeadbeef
,
"Billy"
,
6
,
&
font_collection
);
hr
=
IDWriteFactory_CreateCustomFontCollection
(
factory
,
(
IDWriteFontCollectionLoader
*
)
0xdeadbeef
,
"Billy"
,
6
,
&
font_collection
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
font_collection
==
NULL
,
"got %p
\n
"
,
font_collection
);
font
=
FindResourceA
(
GetModuleHandleA
(
NULL
),
(
LPCSTR
)
MAKEINTRESOURCE
(
1
),
(
LPCSTR
)
RT_RCDATA
);
font
=
FindResourceA
(
GetModuleHandleA
(
NULL
),
(
LPCSTR
)
MAKEINTRESOURCE
(
1
),
(
LPCSTR
)
RT_RCDATA
);
ok
(
font
!=
NULL
,
"Failed to find font resource
\n
"
);
ok
(
font
!=
NULL
,
"Failed to find font resource
\n
"
);
...
@@ -2058,11 +2071,15 @@ if (0) { /* crashes on win10 */
...
@@ -2058,11 +2071,15 @@ if (0) { /* crashes on win10 */
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
IDWriteFontFile_Release
(
file
);
IDWriteFontFile_Release
(
file
);
file
=
(
void
*
)
0xdeadbeef
;
hr
=
IDWriteFactory_CreateCustomFontFileReference
(
factory
,
"test"
,
4
,
&
floader3
,
&
file
);
hr
=
IDWriteFactory_CreateCustomFontFileReference
(
factory
,
"test"
,
4
,
&
floader3
,
&
file
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
file
==
NULL
,
"got %p
\n
"
,
file
);
file
=
(
void
*
)
0xdeadbeef
;
hr
=
IDWriteFactory_CreateCustomFontFileReference
(
factory
,
"test"
,
4
,
NULL
,
&
file
);
hr
=
IDWriteFactory_CreateCustomFontFileReference
(
factory
,
"test"
,
4
,
NULL
,
&
file
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
file
==
NULL
,
"got %p
\n
"
,
file
);
file
=
NULL
;
file
=
NULL
;
hr
=
IDWriteFactory_CreateCustomFontFileReference
(
factory
,
"test"
,
4
,
&
floader
,
&
file
);
hr
=
IDWriteFactory_CreateCustomFontFileReference
(
factory
,
"test"
,
4
,
&
floader
,
&
file
);
...
@@ -2101,8 +2118,10 @@ if (0) { /* crashes on win10 */
...
@@ -2101,8 +2118,10 @@ if (0) { /* crashes on win10 */
ok
(
count
==
1
,
"got %i
\n
"
,
count
);
ok
(
count
==
1
,
"got %i
\n
"
,
count
);
/* invalid index */
/* invalid index */
face
=
(
void
*
)
0xdeadbeef
;
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
face_type
,
1
,
&
file
,
1
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
face
);
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
face_type
,
1
,
&
file
,
1
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
face
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
face
==
NULL
,
"got %p
\n
"
,
face
);
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
face_type
,
1
,
&
file
,
0
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
face
);
hr
=
IDWriteFactory_CreateFontFace
(
factory
,
face_type
,
1
,
&
file
,
0
,
DWRITE_FONT_SIMULATIONS_NONE
,
&
face
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
...
@@ -2540,8 +2559,10 @@ static void test_CreateFontFaceFromHdc(void)
...
@@ -2540,8 +2559,10 @@ static void test_CreateFontFaceFromHdc(void)
hr
=
IDWriteFactory_GetGdiInterop
(
factory
,
&
interop
);
hr
=
IDWriteFactory_GetGdiInterop
(
factory
,
&
interop
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
fontface
=
(
void
*
)
0xdeadbeef
;
hr
=
IDWriteGdiInterop_CreateFontFaceFromHdc
(
interop
,
NULL
,
&
fontface
);
hr
=
IDWriteGdiInterop_CreateFontFaceFromHdc
(
interop
,
NULL
,
&
fontface
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
hr
==
E_INVALIDARG
,
"got 0x%08x
\n
"
,
hr
);
ok
(
fontface
==
NULL
,
"got %p
\n
"
,
fontface
);
memset
(
&
logfont
,
0
,
sizeof
(
logfont
));
memset
(
&
logfont
,
0
,
sizeof
(
logfont
));
logfont
.
lfHeight
=
12
;
logfont
.
lfHeight
=
12
;
...
...
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