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
03fa4c6f
Commit
03fa4c6f
authored
Jul 14, 2004
by
Huw Davies
Committed by
Alexandre Julliard
Jul 14, 2004
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix font replacements to work with bitmap fonts.
Enumerate System, Terminal, FixedSys in that order.
parent
390f97a0
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
18 deletions
+21
-18
freetype.c
dlls/gdi/freetype.c
+21
-18
No files found.
dlls/gdi/freetype.c
View file @
03fa4c6f
...
@@ -151,6 +151,14 @@ typedef struct {
...
@@ -151,6 +151,14 @@ typedef struct {
FT_Short
internal_leading
;
FT_Short
internal_leading
;
}
Bitmap_Size
;
}
Bitmap_Size
;
/* FT_Bitmap_Size gained 3 new elements between FreeType 2.1.4 and 2.1.5
So to let this compile on older versions of FreeType we'll define the
new structure here. */
typedef
struct
{
FT_Short
height
,
width
;
FT_Pos
size
,
x_ppem
,
y_ppem
;
}
My_FT_Bitmap_Size
;
typedef
struct
tagFace
{
typedef
struct
tagFace
{
WCHAR
*
StyleName
;
WCHAR
*
StyleName
;
char
*
file
;
char
*
file
;
...
@@ -234,9 +242,9 @@ static const WCHAR System_Value[] = {'F','O','N','T','S','.','F','O','N','\0'};
...
@@ -234,9 +242,9 @@ static const WCHAR System_Value[] = {'F','O','N','T','S','.','F','O','N','\0'};
static
const
WCHAR
OEMFont_Value
[]
=
{
'O'
,
'E'
,
'M'
,
'F'
,
'O'
,
'N'
,
'T'
,
'.'
,
'F'
,
'O'
,
'N'
,
'\0'
};
static
const
WCHAR
OEMFont_Value
[]
=
{
'O'
,
'E'
,
'M'
,
'F'
,
'O'
,
'N'
,
'T'
,
'.'
,
'F'
,
'O'
,
'N'
,
'\0'
};
static
const
WCHAR
*
SystemFontValues
[
4
]
=
{
static
const
WCHAR
*
SystemFontValues
[
4
]
=
{
FixedSys_Value
,
System_Value
,
System_Value
,
OEMFont_Value
,
OEMFont_Value
,
FixedSys_Value
,
NULL
NULL
};
};
...
@@ -415,6 +423,11 @@ static BOOL AddFontFileToList(const char *file, char *fake_family, DWORD flags)
...
@@ -415,6 +423,11 @@ static BOOL AddFontFileToList(const char *file, char *fake_family, DWORD flags)
bitmap_num
=
0
;
bitmap_num
=
0
;
do
{
do
{
My_FT_Bitmap_Size
*
size
=
NULL
;
if
(
!
FT_IS_SCALABLE
(
ft_face
))
size
=
(
My_FT_Bitmap_Size
*
)
ft_face
->
available_sizes
+
bitmap_num
;
len
=
MultiByteToWideChar
(
CP_ACP
,
0
,
family_name
,
-
1
,
NULL
,
0
);
len
=
MultiByteToWideChar
(
CP_ACP
,
0
,
family_name
,
-
1
,
NULL
,
0
);
FamilyW
=
HeapAlloc
(
GetProcessHeap
(),
0
,
len
*
sizeof
(
WCHAR
));
FamilyW
=
HeapAlloc
(
GetProcessHeap
(),
0
,
len
*
sizeof
(
WCHAR
));
MultiByteToWideChar
(
CP_ACP
,
0
,
family_name
,
-
1
,
FamilyW
,
len
);
MultiByteToWideChar
(
CP_ACP
,
0
,
family_name
,
-
1
,
FamilyW
,
len
);
...
@@ -441,10 +454,10 @@ static BOOL AddFontFileToList(const char *file, char *fake_family, DWORD flags)
...
@@ -441,10 +454,10 @@ static BOOL AddFontFileToList(const char *file, char *fake_family, DWORD flags)
next
=
NULL
;
next
=
NULL
;
for
(
insertface
=
&
(
*
pfamily
)
->
FirstFace
;
*
insertface
;
for
(
insertface
=
&
(
*
pfamily
)
->
FirstFace
;
*
insertface
;
insertface
=
&
(
*
insertface
)
->
next
)
{
insertface
=
&
(
*
insertface
)
->
next
)
{
if
(
!
strcmpW
((
*
insertface
)
->
StyleName
,
StyleW
)
&&
FT_IS_SCALABLE
(
ft_face
))
{
if
(
!
strcmpW
((
*
insertface
)
->
StyleName
,
StyleW
)
&&
(
FT_IS_SCALABLE
(
ft_face
)
||
(
size
->
y_ppem
==
(
*
insertface
)
->
size
.
y_ppem
)
))
{
TRACE
(
"Already loaded font %s %s original version is %lx, this version is %lx
\n
"
,
TRACE
(
"Already loaded font %s %s original version is %lx, this version is %lx
\n
"
,
debugstr_w
((
*
pfamily
)
->
FamilyName
),
debugstr_w
(
StyleW
),
debugstr_w
((
*
pfamily
)
->
FamilyName
),
debugstr_w
(
StyleW
),
(
*
insertface
)
->
font_version
,
pHeader
->
Font_Revision
);
(
*
insertface
)
->
font_version
,
pHeader
?
pHeader
->
Font_Revision
:
0
);
if
(
fake_family
)
{
if
(
fake_family
)
{
TRACE
(
"This font is a replacement but the original really exists, so we'll skip the replacement
\n
"
);
TRACE
(
"This font is a replacement but the original really exists, so we'll skip the replacement
\n
"
);
...
@@ -452,7 +465,7 @@ static BOOL AddFontFileToList(const char *file, char *fake_family, DWORD flags)
...
@@ -452,7 +465,7 @@ static BOOL AddFontFileToList(const char *file, char *fake_family, DWORD flags)
pFT_Done_Face
(
ft_face
);
pFT_Done_Face
(
ft_face
);
return
FALSE
;
return
FALSE
;
}
}
if
(
pHeader
->
Font_Revision
<=
(
*
insertface
)
->
font_version
)
{
if
(
!
pHeader
||
pHeader
->
Font_Revision
<=
(
*
insertface
)
->
font_version
)
{
TRACE
(
"Original font is newer so skipping this one
\n
"
);
TRACE
(
"Original font is newer so skipping this one
\n
"
);
HeapFree
(
GetProcessHeap
(),
0
,
StyleW
);
HeapFree
(
GetProcessHeap
(),
0
,
StyleW
);
pFT_Done_Face
(
ft_face
);
pFT_Done_Face
(
ft_face
);
...
@@ -483,16 +496,6 @@ static BOOL AddFontFileToList(const char *file, char *fake_family, DWORD flags)
...
@@ -483,16 +496,6 @@ static BOOL AddFontFileToList(const char *file, char *fake_family, DWORD flags)
memset
(
&
(
*
insertface
)
->
size
,
0
,
sizeof
((
*
insertface
)
->
size
));
memset
(
&
(
*
insertface
)
->
size
,
0
,
sizeof
((
*
insertface
)
->
size
));
(
*
insertface
)
->
scalable
=
TRUE
;
(
*
insertface
)
->
scalable
=
TRUE
;
}
else
{
}
else
{
/* FT_Bitmap_Size gained 3 new elements between FreeType 2.1.4 and 2.1.5
So to let this compile on older versions of FreeType we'll define the
new structure here. Note that this code is never executed when run with
earlier versions of the library because of the version check above */
struct
my_bitmap_size
{
FT_Short
height
,
width
;
FT_Pos
size
,
x_ppem
,
y_ppem
;
}
*
size
;
size
=
(
struct
my_bitmap_size
*
)
ft_face
->
available_sizes
+
bitmap_num
;
TRACE
(
"Adding bitmap size h %d w %d size %ld x_ppem %ld y_ppem %ld
\n
"
,
TRACE
(
"Adding bitmap size h %d w %d size %ld x_ppem %ld y_ppem %ld
\n
"
,
size
->
height
,
size
->
width
,
size
->
size
>>
6
,
size
->
height
,
size
->
width
,
size
->
size
>>
6
,
size
->
x_ppem
>>
6
,
size
->
y_ppem
>>
6
);
size
->
x_ppem
>>
6
,
size
->
y_ppem
>>
6
);
...
@@ -737,7 +740,7 @@ static void LoadReplaceList(void)
...
@@ -737,7 +740,7 @@ static void LoadReplaceList(void)
TRACE
(
"mapping %s %s to %s
\n
"
,
debugstr_w
(
family
->
FamilyName
),
TRACE
(
"mapping %s %s to %s
\n
"
,
debugstr_w
(
family
->
FamilyName
),
debugstr_w
(
face
->
StyleName
),
value
);
debugstr_w
(
face
->
StyleName
),
value
);
/* Now add a new entry with the new family name */
/* Now add a new entry with the new family name */
AddFontFileToList
(
face
->
file
,
value
,
face
->
external
?
ADDFONT_EXTERNAL_FONT
:
0
);
AddFontFileToList
(
face
->
file
,
value
,
ADDFONT_FORCE_BITMAP
|
(
face
->
external
?
ADDFONT_EXTERNAL_FONT
:
0
)
);
}
}
break
;
break
;
}
}
...
@@ -1104,6 +1107,9 @@ BOOL WineEngInit(void)
...
@@ -1104,6 +1107,9 @@ BOOL WineEngInit(void)
}
}
WaitForSingleObject
(
font_mutex
,
INFINITE
);
WaitForSingleObject
(
font_mutex
,
INFINITE
);
/* load the system fonts */
load_system_fonts
();
/* load in the fonts from %WINDOWSDIR%\\Fonts first of all */
/* load in the fonts from %WINDOWSDIR%\\Fonts first of all */
GetWindowsDirectoryW
(
windowsdir
,
sizeof
(
windowsdir
)
/
sizeof
(
WCHAR
));
GetWindowsDirectoryW
(
windowsdir
,
sizeof
(
windowsdir
)
/
sizeof
(
WCHAR
));
strcatW
(
windowsdir
,
fontsW
);
strcatW
(
windowsdir
,
fontsW
);
...
@@ -1113,9 +1119,6 @@ BOOL WineEngInit(void)
...
@@ -1113,9 +1119,6 @@ BOOL WineEngInit(void)
HeapFree
(
GetProcessHeap
(),
0
,
unixname
);
HeapFree
(
GetProcessHeap
(),
0
,
unixname
);
}
}
/* now load the system fonts */
load_system_fonts
();
/* now look under HKLM\Software\Microsoft\Windows[ NT]\CurrentVersion\Fonts
/* now look under HKLM\Software\Microsoft\Windows[ NT]\CurrentVersion\Fonts
for any fonts not installed in %WINDOWSDIR%\Fonts. They will have their
for any fonts not installed in %WINDOWSDIR%\Fonts. They will have their
full path as the entry. Also look for any .fon fonts, since ReadFontDir
full path as the entry. Also look for any .fon fonts, since ReadFontDir
...
...
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