Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
cf602ca4
Commit
cf602ca4
authored
Feb 02, 2010
by
Huw Davies
Committed by
Alexandre Julliard
Feb 02, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
oleaut32: Realize the font in getter functions.
parent
bc76916b
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
83 additions
and
53 deletions
+83
-53
olefont.c
dlls/oleaut32/olefont.c
+83
-51
olefont.c
dlls/oleaut32/tests/olefont.c
+0
-2
No files found.
dlls/oleaut32/olefont.c
View file @
cf602ca4
...
@@ -111,6 +111,22 @@ static HFONTItem *find_hfontitem(HFONT hfont)
...
@@ -111,6 +111,22 @@ static HFONTItem *find_hfontitem(HFONT hfont)
return
NULL
;
return
NULL
;
}
}
/* Add an item to the list with one internal reference */
static
HRESULT
add_hfontitem
(
HFONT
hfont
)
{
HFONTItem
*
new_item
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
new_item
));
if
(
!
new_item
)
return
E_OUTOFMEMORY
;
new_item
->
int_refs
=
1
;
new_item
->
total_refs
=
1
;
new_item
->
gdiFont
=
hfont
;
EnterCriticalSection
(
&
OLEFontImpl_csHFONTLIST
);
list_add_tail
(
&
OLEFontImpl_hFontList
,
&
new_item
->
entry
);
LeaveCriticalSection
(
&
OLEFontImpl_csHFONTLIST
);
return
S_OK
;
}
static
HRESULT
inc_int_ref
(
HFONT
hfont
)
static
HRESULT
inc_int_ref
(
HFONT
hfont
)
{
{
HFONTItem
*
item
;
HFONTItem
*
item
;
...
@@ -221,7 +237,7 @@ struct OLEFontImpl
...
@@ -221,7 +237,7 @@ struct OLEFontImpl
* Contain the font associated with this object.
* Contain the font associated with this object.
*/
*/
HFONT
gdiFont
;
HFONT
gdiFont
;
BOOL
dirty
;
/*
/*
* Size ratio
* Size ratio
*/
*/
...
@@ -370,8 +386,8 @@ static void OLEFont_SendNotify(OLEFontImpl* this, DISPID dispID)
...
@@ -370,8 +386,8 @@ static void OLEFont_SendNotify(OLEFontImpl* this, DISPID dispID)
CONNECTDATA
CD
;
CONNECTDATA
CD
;
HRESULT
hres
;
HRESULT
hres
;
dec_int_ref
(
this
->
gdiFont
)
;
this
->
dirty
=
TRUE
;
this
->
gdiFont
=
0
;
hres
=
IConnectionPoint_EnumConnections
(
this
->
pPropertyNotifyCP
,
&
pEnum
);
hres
=
IConnectionPoint_EnumConnections
(
this
->
pPropertyNotifyCP
,
&
pEnum
);
if
(
SUCCEEDED
(
hres
))
if
(
SUCCEEDED
(
hres
))
{
{
...
@@ -526,6 +542,52 @@ static ULONG WINAPI OLEFontImpl_Release(
...
@@ -526,6 +542,52 @@ static ULONG WINAPI OLEFontImpl_Release(
return
ret
;
return
ret
;
}
}
static
void
realize_font
(
OLEFontImpl
*
This
)
{
if
(
This
->
dirty
)
{
LOGFONTW
logFont
;
INT
fontHeight
;
if
(
This
->
gdiFont
)
{
dec_int_ref
(
This
->
gdiFont
);
This
->
gdiFont
=
0
;
}
/*
* The height of the font returned by the get_Size property is the
* height of the font in points multiplied by 10000... Using some
* simple conversions and the ratio given by the application, it can
* be converted to a height in pixels.
*/
/* Standard ratio is 72 / 2540, or 18 / 635 in lowest terms. */
/* Ratio is applied here relative to the standard. */
fontHeight
=
MulDiv
(
This
->
description
.
cySize
.
s
.
Lo
,
This
->
cyLogical
*
635
,
This
->
cyHimetric
*
18
);
memset
(
&
logFont
,
0
,
sizeof
(
LOGFONTW
));
logFont
.
lfHeight
=
((
fontHeight
%
10000L
)
>
5000L
)
?
(
-
fontHeight
/
10000L
)
-
1
:
(
-
fontHeight
/
10000L
);
logFont
.
lfItalic
=
This
->
description
.
fItalic
;
logFont
.
lfUnderline
=
This
->
description
.
fUnderline
;
logFont
.
lfStrikeOut
=
This
->
description
.
fStrikethrough
;
logFont
.
lfWeight
=
This
->
description
.
sWeight
;
logFont
.
lfCharSet
=
This
->
description
.
sCharset
;
logFont
.
lfOutPrecision
=
OUT_CHARACTER_PRECIS
;
logFont
.
lfClipPrecision
=
CLIP_DEFAULT_PRECIS
;
logFont
.
lfQuality
=
DEFAULT_QUALITY
;
logFont
.
lfPitchAndFamily
=
DEFAULT_PITCH
;
lstrcpynW
(
logFont
.
lfFaceName
,
This
->
description
.
lpstrName
,
LF_FACESIZE
);
This
->
gdiFont
=
CreateFontIndirectW
(
&
logFont
);
This
->
dirty
=
FALSE
;
add_hfontitem
(
This
->
gdiFont
);
}
}
/************************************************************************
/************************************************************************
* OLEFontImpl_get_Name (IFont)
* OLEFontImpl_get_Name (IFont)
*
*
...
@@ -543,6 +605,8 @@ static HRESULT WINAPI OLEFontImpl_get_Name(
...
@@ -543,6 +605,8 @@ static HRESULT WINAPI OLEFontImpl_get_Name(
if
(
pname
==
0
)
if
(
pname
==
0
)
return
E_POINTER
;
return
E_POINTER
;
if
(
this
->
dirty
)
realize_font
(
this
);
if
(
this
->
description
.
lpstrName
!=
0
)
if
(
this
->
description
.
lpstrName
!=
0
)
*
pname
=
SysAllocString
(
this
->
description
.
lpstrName
);
*
pname
=
SysAllocString
(
this
->
description
.
lpstrName
);
else
else
...
@@ -607,6 +671,8 @@ static HRESULT WINAPI OLEFontImpl_get_Size(
...
@@ -607,6 +671,8 @@ static HRESULT WINAPI OLEFontImpl_get_Size(
if
(
psize
==
0
)
if
(
psize
==
0
)
return
E_POINTER
;
return
E_POINTER
;
if
(
this
->
dirty
)
realize_font
(
this
);
psize
->
s
.
Hi
=
0
;
psize
->
s
.
Hi
=
0
;
psize
->
s
.
Lo
=
this
->
description
.
cySize
.
s
.
Lo
;
psize
->
s
.
Lo
=
this
->
description
.
cySize
.
s
.
Lo
;
...
@@ -648,6 +714,8 @@ static HRESULT WINAPI OLEFontImpl_get_Bold(
...
@@ -648,6 +714,8 @@ static HRESULT WINAPI OLEFontImpl_get_Bold(
if
(
pbold
==
0
)
if
(
pbold
==
0
)
return
E_POINTER
;
return
E_POINTER
;
if
(
this
->
dirty
)
realize_font
(
this
);
*
pbold
=
this
->
description
.
sWeight
>
550
;
*
pbold
=
this
->
description
.
sWeight
>
550
;
return
S_OK
;
return
S_OK
;
...
@@ -687,6 +755,8 @@ static HRESULT WINAPI OLEFontImpl_get_Italic(
...
@@ -687,6 +755,8 @@ static HRESULT WINAPI OLEFontImpl_get_Italic(
if
(
pitalic
==
0
)
if
(
pitalic
==
0
)
return
E_POINTER
;
return
E_POINTER
;
if
(
this
->
dirty
)
realize_font
(
this
);
*
pitalic
=
this
->
description
.
fItalic
;
*
pitalic
=
this
->
description
.
fItalic
;
return
S_OK
;
return
S_OK
;
...
@@ -728,6 +798,8 @@ static HRESULT WINAPI OLEFontImpl_get_Underline(
...
@@ -728,6 +798,8 @@ static HRESULT WINAPI OLEFontImpl_get_Underline(
if
(
punderline
==
0
)
if
(
punderline
==
0
)
return
E_POINTER
;
return
E_POINTER
;
if
(
this
->
dirty
)
realize_font
(
this
);
*
punderline
=
this
->
description
.
fUnderline
;
*
punderline
=
this
->
description
.
fUnderline
;
return
S_OK
;
return
S_OK
;
...
@@ -769,6 +841,8 @@ static HRESULT WINAPI OLEFontImpl_get_Strikethrough(
...
@@ -769,6 +841,8 @@ static HRESULT WINAPI OLEFontImpl_get_Strikethrough(
if
(
pstrikethrough
==
0
)
if
(
pstrikethrough
==
0
)
return
E_POINTER
;
return
E_POINTER
;
if
(
this
->
dirty
)
realize_font
(
this
);
*
pstrikethrough
=
this
->
description
.
fStrikethrough
;
*
pstrikethrough
=
this
->
description
.
fStrikethrough
;
return
S_OK
;
return
S_OK
;
...
@@ -810,6 +884,8 @@ static HRESULT WINAPI OLEFontImpl_get_Weight(
...
@@ -810,6 +884,8 @@ static HRESULT WINAPI OLEFontImpl_get_Weight(
if
(
pweight
==
0
)
if
(
pweight
==
0
)
return
E_POINTER
;
return
E_POINTER
;
if
(
this
->
dirty
)
realize_font
(
this
);
*
pweight
=
this
->
description
.
sWeight
;
*
pweight
=
this
->
description
.
sWeight
;
return
S_OK
;
return
S_OK
;
...
@@ -851,6 +927,8 @@ static HRESULT WINAPI OLEFontImpl_get_Charset(
...
@@ -851,6 +927,8 @@ static HRESULT WINAPI OLEFontImpl_get_Charset(
if
(
pcharset
==
0
)
if
(
pcharset
==
0
)
return
E_POINTER
;
return
E_POINTER
;
if
(
this
->
dirty
)
realize_font
(
this
);
*
pcharset
=
this
->
description
.
sCharset
;
*
pcharset
=
this
->
description
.
sCharset
;
return
S_OK
;
return
S_OK
;
...
@@ -888,54 +966,7 @@ static HRESULT WINAPI OLEFontImpl_get_hFont(
...
@@ -888,54 +966,7 @@ static HRESULT WINAPI OLEFontImpl_get_hFont(
if
(
phfont
==
NULL
)
if
(
phfont
==
NULL
)
return
E_POINTER
;
return
E_POINTER
;
/*
if
(
this
->
dirty
)
realize_font
(
this
);
* Realize the font if necessary
*/
if
(
this
->
gdiFont
==
0
)
{
LOGFONTW
logFont
;
INT
fontHeight
;
CY
cySize
;
PHFONTItem
newEntry
;
/*
* The height of the font returned by the get_Size property is the
* height of the font in points multiplied by 10000... Using some
* simple conversions and the ratio given by the application, it can
* be converted to a height in pixels.
*/
IFont_get_Size
(
iface
,
&
cySize
);
/* Standard ratio is 72 / 2540, or 18 / 635 in lowest terms. */
/* Ratio is applied here relative to the standard. */
fontHeight
=
MulDiv
(
cySize
.
s
.
Lo
,
this
->
cyLogical
*
635
,
this
->
cyHimetric
*
18
);
memset
(
&
logFont
,
0
,
sizeof
(
LOGFONTW
));
logFont
.
lfHeight
=
((
fontHeight
%
10000L
)
>
5000L
)
?
(
-
fontHeight
/
10000L
)
-
1
:
(
-
fontHeight
/
10000L
);
logFont
.
lfItalic
=
this
->
description
.
fItalic
;
logFont
.
lfUnderline
=
this
->
description
.
fUnderline
;
logFont
.
lfStrikeOut
=
this
->
description
.
fStrikethrough
;
logFont
.
lfWeight
=
this
->
description
.
sWeight
;
logFont
.
lfCharSet
=
this
->
description
.
sCharset
;
logFont
.
lfOutPrecision
=
OUT_CHARACTER_PRECIS
;
logFont
.
lfClipPrecision
=
CLIP_DEFAULT_PRECIS
;
logFont
.
lfQuality
=
DEFAULT_QUALITY
;
logFont
.
lfPitchAndFamily
=
DEFAULT_PITCH
;
strcpyW
(
logFont
.
lfFaceName
,
this
->
description
.
lpstrName
);
this
->
gdiFont
=
CreateFontIndirectW
(
&
logFont
);
/* Add font to the cache */
newEntry
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
HFONTItem
));
newEntry
->
int_refs
=
1
;
newEntry
->
total_refs
=
1
;
newEntry
->
gdiFont
=
this
->
gdiFont
;
EnterCriticalSection
(
&
OLEFontImpl_csHFONTLIST
);
list_add_tail
(
&
OLEFontImpl_hFontList
,
&
newEntry
->
entry
);
LeaveCriticalSection
(
&
OLEFontImpl_csHFONTLIST
);
}
*
phfont
=
this
->
gdiFont
;
*
phfont
=
this
->
gdiFont
;
TRACE
(
"Returning %p
\n
"
,
*
phfont
);
TRACE
(
"Returning %p
\n
"
,
*
phfont
);
...
@@ -2286,6 +2317,7 @@ static OLEFontImpl* OLEFontImpl_Construct(const FONTDESC *fontDesc)
...
@@ -2286,6 +2317,7 @@ static OLEFontImpl* OLEFontImpl_Construct(const FONTDESC *fontDesc)
* Initializing all the other members.
* Initializing all the other members.
*/
*/
newObject
->
gdiFont
=
0
;
newObject
->
gdiFont
=
0
;
newObject
->
dirty
=
TRUE
;
newObject
->
cyLogical
=
72L
;
newObject
->
cyLogical
=
72L
;
newObject
->
cyHimetric
=
2540L
;
newObject
->
cyHimetric
=
2540L
;
newObject
->
pPropertyNotifyCP
=
NULL
;
newObject
->
pPropertyNotifyCP
=
NULL
;
...
...
dlls/oleaut32/tests/olefont.c
View file @
cf602ca4
...
@@ -877,7 +877,6 @@ static void test_hfont_lifetime(void)
...
@@ -877,7 +877,6 @@ static void test_hfont_lifetime(void)
/* put_Size doesn't cause the new font to be realized */
/* put_Size doesn't cause the new font to be realized */
obj_type
=
GetObjectType
(
last_hfont
);
obj_type
=
GetObjectType
(
last_hfont
);
todo_wine
ok
(
obj_type
==
OBJ_FONT
,
"got obj type %d
\n
"
,
obj_type
);
ok
(
obj_type
==
OBJ_FONT
,
"got obj type %d
\n
"
,
obj_type
);
hr
=
IFont_get_hFont
(
font
,
&
hfont
);
hr
=
IFont_get_hFont
(
font
,
&
hfont
);
...
@@ -939,7 +938,6 @@ todo_wine
...
@@ -939,7 +938,6 @@ todo_wine
/* put_Size doesn't cause the new font to be realized */
/* put_Size doesn't cause the new font to be realized */
obj_type
=
GetObjectType
(
last_hfont
);
obj_type
=
GetObjectType
(
last_hfont
);
todo_wine
ok
(
obj_type
==
OBJ_FONT
,
"got obj type %d
\n
"
,
obj_type
);
ok
(
obj_type
==
OBJ_FONT
,
"got obj type %d
\n
"
,
obj_type
);
hr
=
IFont_get_hFont
(
font
,
&
hfont
);
hr
=
IFont_get_hFont
(
font
,
&
hfont
);
...
...
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