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
10ff4209
Commit
10ff4209
authored
May 31, 2015
by
Nikolay Sivov
Committed by
Alexandre Julliard
Jun 01, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dwrite: Handle inline object GetMetrics() failure.
parent
fe2f6b77
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
91 additions
and
3 deletions
+91
-3
layout.c
dlls/dwrite/layout.c
+3
-3
layout.c
dlls/dwrite/tests/layout.c
+88
-0
No files found.
dlls/dwrite/layout.c
View file @
10ff4209
...
...
@@ -603,11 +603,11 @@ static HRESULT layout_compute_runs(struct dwrite_textlayout *layout)
c
->
position
=
0
;
/* there's always one cluster per inline object, so 0 is valid value */
cluster
++
;
/*
TODO: is it fatal if GetMetrics() fails?
*/
/*
it's not fatal if GetMetrics() fails, all returned metrics are ignored
*/
hr
=
IDWriteInlineObject_GetMetrics
(
r
->
u
.
object
.
object
,
&
inlinemetrics
);
if
(
FAILED
(
hr
))
{
FIXME
(
"failed to get inline object metrics, 0x%08x
\n
"
,
hr
);
continue
;
memset
(
&
inlinemetrics
,
0
,
sizeof
(
inlinemetrics
)
);
hr
=
S_OK
;
}
metrics
->
width
=
inlinemetrics
.
width
;
...
...
dlls/dwrite/tests/layout.c
View file @
10ff4209
...
...
@@ -496,6 +496,68 @@ static const IDWriteTextRendererVtbl testrenderervtbl = {
static
IDWriteTextRenderer
testrenderer
=
{
&
testrenderervtbl
};
/* test IDWriteInlineObject */
static
HRESULT
WINAPI
testinlineobj_QI
(
IDWriteInlineObject
*
iface
,
REFIID
riid
,
void
**
obj
)
{
if
(
IsEqualIID
(
riid
,
&
IID_IDWriteInlineObject
)
||
IsEqualIID
(
riid
,
&
IID_IUnknown
))
{
*
obj
=
iface
;
IDWriteInlineObject_AddRef
(
iface
);
return
S_OK
;
}
*
obj
=
NULL
;
return
E_NOINTERFACE
;
}
static
ULONG
WINAPI
testinlineobj_AddRef
(
IDWriteInlineObject
*
iface
)
{
return
2
;
}
static
ULONG
WINAPI
testinlineobj_Release
(
IDWriteInlineObject
*
iface
)
{
return
1
;
}
static
HRESULT
WINAPI
testinlineobj_Draw
(
IDWriteInlineObject
*
iface
,
void
*
client_drawingontext
,
IDWriteTextRenderer
*
renderer
,
FLOAT
originX
,
FLOAT
originY
,
BOOL
is_sideways
,
BOOL
is_rtl
,
IUnknown
*
drawing_effect
)
{
ok
(
0
,
"unexpected call
\n
"
);
return
E_NOTIMPL
;
}
static
HRESULT
WINAPI
testinlineobj_GetMetrics
(
IDWriteInlineObject
*
iface
,
DWRITE_INLINE_OBJECT_METRICS
*
metrics
)
{
metrics
->
width
=
123
.
0
;
return
0x8faecafe
;
}
static
HRESULT
WINAPI
testinlineobj_GetOverhangMetrics
(
IDWriteInlineObject
*
iface
,
DWRITE_OVERHANG_METRICS
*
overhangs
)
{
ok
(
0
,
"unexpected call
\n
"
);
return
E_NOTIMPL
;
}
static
HRESULT
WINAPI
testinlineobj_GetBreakConditions
(
IDWriteInlineObject
*
iface
,
DWRITE_BREAK_CONDITION
*
before
,
DWRITE_BREAK_CONDITION
*
after
)
{
*
before
=
*
after
=
DWRITE_BREAK_CONDITION_NEUTRAL
;
return
S_OK
;
}
static
IDWriteInlineObjectVtbl
testinlineobjvtbl
=
{
testinlineobj_QI
,
testinlineobj_AddRef
,
testinlineobj_Release
,
testinlineobj_Draw
,
testinlineobj_GetMetrics
,
testinlineobj_GetOverhangMetrics
,
testinlineobj_GetBreakConditions
};
static
IDWriteInlineObject
testinlineobj
=
{
&
testinlineobjvtbl
};
static
void
test_CreateTextLayout
(
void
)
{
static
const
WCHAR
strW
[]
=
{
's'
,
't'
,
'r'
,
'i'
,
'n'
,
'g'
,
0
};
...
...
@@ -1336,6 +1398,32 @@ todo_wine
IDWriteTextLayout_Release
(
layout
);
/* single inline object that fails to report its metrics */
hr
=
IDWriteFactory_CreateTextLayout
(
factory
,
strW
,
4
,
format
,
1000
.
0
,
1000
.
0
,
&
layout
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
range
.
startPosition
=
0
;
range
.
length
=
4
;
hr
=
IDWriteTextLayout_SetInlineObject
(
layout
,
&
testinlineobj
,
range
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
count
=
0
;
memset
(
metrics
,
0
,
sizeof
(
metrics
));
hr
=
IDWriteTextLayout_GetClusterMetrics
(
layout
,
metrics
,
3
,
&
count
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
ok
(
count
==
1
,
"got %u
\n
"
,
count
);
/* object sets a width to 123.0, but returns failure from GetMetrics() */
ok
(
metrics
[
0
].
width
==
0
.
0
,
"got %.2f
\n
"
,
metrics
[
0
].
width
);
ok
(
metrics
[
0
].
length
==
4
,
"got %d
\n
"
,
metrics
[
0
].
length
);
todo_wine
ok
(
metrics
[
0
].
canWrapLineAfter
==
1
,
"got %d
\n
"
,
metrics
[
0
].
canWrapLineAfter
);
ok
(
metrics
[
0
].
isWhitespace
==
0
,
"got %d
\n
"
,
metrics
[
0
].
isWhitespace
);
ok
(
metrics
[
0
].
isNewline
==
0
,
"got %d
\n
"
,
metrics
[
0
].
isNewline
);
ok
(
metrics
[
0
].
isSoftHyphen
==
0
,
"got %d
\n
"
,
metrics
[
0
].
isSoftHyphen
);
ok
(
metrics
[
0
].
isRightToLeft
==
0
,
"got %d
\n
"
,
metrics
[
0
].
isRightToLeft
);
IDWriteTextLayout_Release
(
layout
);
IDWriteInlineObject_Release
(
trimm
);
IDWriteTextFormat_Release
(
format
);
IDWriteFactory_Release
(
factory
);
...
...
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