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
d14b2f0f
Commit
d14b2f0f
authored
Apr 03, 2002
by
Huw D M Davies
Committed by
Alexandre Julliard
Apr 03, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Load libfreetype.so on the fly with dlopen and friends.
parent
7ed8cee8
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
73 additions
and
19 deletions
+73
-19
Makefile.in
dlls/gdi/Makefile.in
+0
-1
freetype.c
dlls/gdi/freetype.c
+0
-0
Makefile.in
dlls/wineps/Makefile.in
+1
-1
truetype.c
dlls/wineps/truetype.c
+72
-17
No files found.
dlls/gdi/Makefile.in
View file @
d14b2f0f
...
@@ -6,7 +6,6 @@ VPATH = @srcdir@
...
@@ -6,7 +6,6 @@ VPATH = @srcdir@
MODULE
=
gdi32.dll
MODULE
=
gdi32.dll
ALTNAMES
=
gdi.exe dispdib.dll wing.dll
ALTNAMES
=
gdi.exe dispdib.dll wing.dll
IMPORTS
=
kernel32.dll ntdll.dll
IMPORTS
=
kernel32.dll ntdll.dll
EXTRALIBS
=
@FREETYPELIBS@
EXTRAINCL
=
@FREETYPEINCL@
EXTRAINCL
=
@FREETYPEINCL@
C_SRCS
=
\
C_SRCS
=
\
...
...
dlls/gdi/freetype.c
View file @
d14b2f0f
This diff is collapsed.
Click to expand it.
dlls/wineps/Makefile.in
View file @
d14b2f0f
...
@@ -5,7 +5,7 @@ VPATH = @srcdir@
...
@@ -5,7 +5,7 @@ VPATH = @srcdir@
MODULE
=
wineps.dll
MODULE
=
wineps.dll
ALTNAMES
=
wineps16.dll
ALTNAMES
=
wineps16.dll
IMPORTS
=
user32.dll gdi32.dll winspool.drv kernel32.dll ntdll.dll
IMPORTS
=
user32.dll gdi32.dll winspool.drv kernel32.dll ntdll.dll
EXTRALIBS
=
@CUPSLIBS@
@FREETYPELIBS@
EXTRALIBS
=
@CUPSLIBS@
EXTRAINCL
=
@FREETYPEINCL@
EXTRAINCL
=
@FREETYPEINCL@
FONTMETRICS
=
\
FONTMETRICS
=
\
...
...
dlls/wineps/truetype.c
View file @
d14b2f0f
...
@@ -26,6 +26,7 @@
...
@@ -26,6 +26,7 @@
*
*
*/
*/
#include "config.h"
#include "config.h"
#include "wine/port.h"
#ifdef HAVE_FREETYPE
#ifdef HAVE_FREETYPE
...
@@ -76,6 +77,22 @@ WINE_DEFAULT_DEBUG_CHANNEL(psdrv);
...
@@ -76,6 +77,22 @@ WINE_DEFAULT_DEBUG_CHANNEL(psdrv);
#define GLYPH_LOAD_FLAGS ( FT_LOAD_NO_SCALE | \
#define GLYPH_LOAD_FLAGS ( FT_LOAD_NO_SCALE | \
FT_LOAD_IGNORE_TRANSFORM | \
FT_LOAD_IGNORE_TRANSFORM | \
FT_LOAD_LINEAR_DESIGN )
FT_LOAD_LINEAR_DESIGN )
static
void
*
ft_handle
=
NULL
;
#define MAKE_FUNCPTR(f) static typeof(f) * p##f = NULL;
MAKE_FUNCPTR
(
FT_Done_Face
)
MAKE_FUNCPTR
(
FT_Done_FreeType
)
MAKE_FUNCPTR
(
FT_Get_Char_Index
)
MAKE_FUNCPTR
(
FT_Get_Glyph_Name
)
MAKE_FUNCPTR
(
FT_Get_Sfnt_Name
)
MAKE_FUNCPTR
(
FT_Get_Sfnt_Name_Count
)
MAKE_FUNCPTR
(
FT_Get_Sfnt_Table
)
MAKE_FUNCPTR
(
FT_Init_FreeType
)
MAKE_FUNCPTR
(
FT_Load_Glyph
)
MAKE_FUNCPTR
(
FT_New_Face
)
MAKE_FUNCPTR
(
FT_Set_Charmap
)
#undef MAKE_FUNCPTR
/*******************************************************************************
/*******************************************************************************
* FindCharMap
* FindCharMap
...
@@ -129,7 +146,7 @@ static BOOL FindCharMap(FT_Face face, FT_CharMap *p_charmap, LPSTR *p_sz)
...
@@ -129,7 +146,7 @@ static BOOL FindCharMap(FT_Face face, FT_CharMap *p_charmap, LPSTR *p_sz)
return
TRUE
;
return
TRUE
;
}
}
error
=
FT_Set_Charmap
(
face
,
charmap
);
error
=
p
FT_Set_Charmap
(
face
,
charmap
);
if
(
error
!=
FT_Err_Ok
)
if
(
error
!=
FT_Err_Ok
)
{
{
ERR
(
"%s returned %i
\n
"
,
"FT_Set_Charmap"
,
error
);
ERR
(
"%s returned %i
\n
"
,
"FT_Set_Charmap"
,
error
);
...
@@ -217,11 +234,11 @@ static BOOL FindMSTTString(FT_Face face, FT_CharMap charmap, FT_UShort name_id,
...
@@ -217,11 +234,11 @@ static BOOL FindMSTTString(FT_Face face, FT_CharMap charmap, FT_UShort name_id,
FT_SfntName
name
;
FT_SfntName
name
;
FT_Error
error
;
FT_Error
error
;
num_strings
=
FT_Get_Sfnt_Name_Count
(
face
);
num_strings
=
p
FT_Get_Sfnt_Name_Count
(
face
);
for
(
string_index
=
0
;
string_index
<
num_strings
;
++
string_index
)
for
(
string_index
=
0
;
string_index
<
num_strings
;
++
string_index
)
{
{
error
=
FT_Get_Sfnt_Name
(
face
,
string_index
,
&
name
);
error
=
p
FT_Get_Sfnt_Name
(
face
,
string_index
,
&
name
);
if
(
error
!=
FT_Err_Ok
)
if
(
error
!=
FT_Err_Ok
)
{
{
ERR
(
"%s returned %i
\n
"
,
"FT_Get_Sfnt_Name"
,
error
);
ERR
(
"%s returned %i
\n
"
,
"FT_Get_Sfnt_Name"
,
error
);
...
@@ -278,10 +295,10 @@ static BOOL StartAFM(FT_Face face, AFM **p_afm)
...
@@ -278,10 +295,10 @@ static BOOL StartAFM(FT_Face face, AFM **p_afm)
USHORT
em_size
;
USHORT
em_size
;
AFM
*
afm
;
AFM
*
afm
;
head
=
FT_Get_Sfnt_Table
(
face
,
ft_sfnt_head
);
head
=
p
FT_Get_Sfnt_Table
(
face
,
ft_sfnt_head
);
post
=
FT_Get_Sfnt_Table
(
face
,
ft_sfnt_post
);
post
=
p
FT_Get_Sfnt_Table
(
face
,
ft_sfnt_post
);
os2
=
FT_Get_Sfnt_Table
(
face
,
ft_sfnt_os2
);
os2
=
p
FT_Get_Sfnt_Table
(
face
,
ft_sfnt_os2
);
hhea
=
FT_Get_Sfnt_Table
(
face
,
ft_sfnt_hhea
);
hhea
=
p
FT_Get_Sfnt_Table
(
face
,
ft_sfnt_hhea
);
if
(
head
==
NULL
||
post
==
NULL
||
os2
==
NULL
||
hhea
==
NULL
||
if
(
head
==
NULL
||
post
==
NULL
||
os2
==
NULL
||
hhea
==
NULL
||
os2
->
version
==
0xffff
)
/* old Macintosh font */
os2
->
version
==
0xffff
)
/* old Macintosh font */
...
@@ -337,7 +354,7 @@ static BOOL ReadCharMetrics(FT_Face face, AFM *afm, AFMMETRICS **p_metrics)
...
@@ -337,7 +354,7 @@ static BOOL ReadCharMetrics(FT_Face face, AFM *afm, AFMMETRICS **p_metrics)
USHORT
em_size
=
afm
->
WinMetrics
.
usUnitsPerEm
;
USHORT
em_size
=
afm
->
WinMetrics
.
usUnitsPerEm
;
for
(
charcode
=
0
,
index
=
0
;
charcode
<
65536
;
++
charcode
)
for
(
charcode
=
0
,
index
=
0
;
charcode
<
65536
;
++
charcode
)
if
(
FT_Get_Char_Index
(
face
,
charcode
)
!=
0
)
if
(
p
FT_Get_Char_Index
(
face
,
charcode
)
!=
0
)
++
index
;
/* count # of glyphs */
++
index
;
/* count # of glyphs */
afm
->
NumofMetrics
=
index
;
afm
->
NumofMetrics
=
index
;
...
@@ -348,21 +365,21 @@ static BOOL ReadCharMetrics(FT_Face face, AFM *afm, AFMMETRICS **p_metrics)
...
@@ -348,21 +365,21 @@ static BOOL ReadCharMetrics(FT_Face face, AFM *afm, AFMMETRICS **p_metrics)
for
(
charcode
=
0
,
index
=
0
;
charcode
<
65536
;
++
charcode
)
for
(
charcode
=
0
,
index
=
0
;
charcode
<
65536
;
++
charcode
)
{
{
FT_UInt
glyph_index
=
FT_Get_Char_Index
(
face
,
charcode
);
FT_UInt
glyph_index
=
p
FT_Get_Char_Index
(
face
,
charcode
);
FT_Error
error
;
FT_Error
error
;
CHAR
buffer
[
128
];
/* for glyph names */
CHAR
buffer
[
128
];
/* for glyph names */
if
(
glyph_index
==
0
)
if
(
glyph_index
==
0
)
continue
;
continue
;
error
=
FT_Load_Glyph
(
face
,
glyph_index
,
GLYPH_LOAD_FLAGS
);
error
=
p
FT_Load_Glyph
(
face
,
glyph_index
,
GLYPH_LOAD_FLAGS
);
if
(
error
!=
FT_Err_Ok
)
if
(
error
!=
FT_Err_Ok
)
{
{
ERR
(
"%s returned %i
\n
"
,
"FT_Load_Glyph"
,
error
);
ERR
(
"%s returned %i
\n
"
,
"FT_Load_Glyph"
,
error
);
goto
cleanup
;
goto
cleanup
;
}
}
error
=
FT_Get_Glyph_Name
(
face
,
glyph_index
,
buffer
,
sizeof
(
buffer
));
error
=
p
FT_Get_Glyph_Name
(
face
,
glyph_index
,
buffer
,
sizeof
(
buffer
));
if
(
error
!=
FT_Err_Ok
)
if
(
error
!=
FT_Err_Ok
)
{
{
ERR
(
"%s returned %i
\n
"
,
"FT_Get_Glyph_Name"
,
error
);
ERR
(
"%s returned %i
\n
"
,
"FT_Get_Glyph_Name"
,
error
);
...
@@ -471,7 +488,7 @@ static BOOL ReadTrueTypeFile(FT_Library library, LPCSTR filename)
...
@@ -471,7 +488,7 @@ static BOOL ReadTrueTypeFile(FT_Library library, LPCSTR filename)
TRACE
(
"%s
\n
"
,
filename
);
TRACE
(
"%s
\n
"
,
filename
);
error
=
FT_New_Face
(
library
,
filename
,
0
,
&
face
);
error
=
p
FT_New_Face
(
library
,
filename
,
0
,
&
face
);
if
(
error
!=
FT_Err_Ok
)
if
(
error
!=
FT_Err_Ok
)
{
{
WARN
(
"FreeType error %i opening %s
\n
"
,
error
,
filename
);
WARN
(
"FreeType error %i opening %s
\n
"
,
error
,
filename
);
...
@@ -482,7 +499,7 @@ static BOOL ReadTrueTypeFile(FT_Library library, LPCSTR filename)
...
@@ -482,7 +499,7 @@ static BOOL ReadTrueTypeFile(FT_Library library, LPCSTR filename)
{
{
if
(
BuildTrueTypeAFM
(
face
)
==
FALSE
)
if
(
BuildTrueTypeAFM
(
face
)
==
FALSE
)
{
{
FT_Done_Face
(
face
);
p
FT_Done_Face
(
face
);
return
FALSE
;
return
FALSE
;
}
}
}
}
...
@@ -491,7 +508,7 @@ static BOOL ReadTrueTypeFile(FT_Library library, LPCSTR filename)
...
@@ -491,7 +508,7 @@ static BOOL ReadTrueTypeFile(FT_Library library, LPCSTR filename)
WARN
(
"Required information missing from %s
\n
"
,
filename
);
WARN
(
"Required information missing from %s
\n
"
,
filename
);
}
}
error
=
FT_Done_Face
(
face
);
error
=
p
FT_Done_Face
(
face
);
if
(
error
!=
FT_Err_Ok
)
if
(
error
!=
FT_Err_Ok
)
{
{
ERR
(
"%s returned %i
\n
"
,
"FT_Done_Face"
,
error
);
ERR
(
"%s returned %i
\n
"
,
"FT_Done_Face"
,
error
);
...
@@ -572,10 +589,36 @@ BOOL PSDRV_GetTrueTypeMetrics(void)
...
@@ -572,10 +589,36 @@ BOOL PSDRV_GetTrueTypeMetrics(void)
0
,
KEY_READ
,
&
hkey
)
!=
ERROR_SUCCESS
)
0
,
KEY_READ
,
&
hkey
)
!=
ERROR_SUCCESS
)
return
TRUE
;
return
TRUE
;
error
=
FT_Init_FreeType
(
&
library
);
ft_handle
=
wine_dlopen
(
"libfreetype.so"
,
RTLD_NOW
,
NULL
,
0
);
if
(
!
ft_handle
)
{
WINE_MESSAGE
(
"Wine cannot find the FreeType font library. To enable Wine to
\n
"
"use TrueType fonts please install a version of FreeType greater than
\n
"
"or equal to 2.0.5.
\n
"
"http://www.freetype.org
\n
"
);
return
TRUE
;
}
#define LOAD_FUNCPTR(f) if((p##f = wine_dlsym(ft_handle, #f, NULL, 0)) == NULL) goto sym_not_found;
LOAD_FUNCPTR
(
FT_Done_Face
)
LOAD_FUNCPTR
(
FT_Done_FreeType
)
LOAD_FUNCPTR
(
FT_Get_Char_Index
)
LOAD_FUNCPTR
(
FT_Get_Glyph_Name
)
LOAD_FUNCPTR
(
FT_Get_Sfnt_Name
)
LOAD_FUNCPTR
(
FT_Get_Sfnt_Name_Count
)
LOAD_FUNCPTR
(
FT_Get_Sfnt_Table
)
LOAD_FUNCPTR
(
FT_Init_FreeType
)
LOAD_FUNCPTR
(
FT_Load_Glyph
)
LOAD_FUNCPTR
(
FT_New_Face
)
LOAD_FUNCPTR
(
FT_Set_Charmap
)
#undef LOAD_FUNCPTR
error
=
pFT_Init_FreeType
(
&
library
);
if
(
error
!=
FT_Err_Ok
)
if
(
error
!=
FT_Err_Ok
)
{
{
ERR
(
"%s returned %i
\n
"
,
"FT_Init_FreeType"
,
error
);
ERR
(
"%s returned %i
\n
"
,
"FT_Init_FreeType"
,
error
);
wine_dlclose
(
ft_handle
,
NULL
,
0
);
RegCloseKey
(
hkey
);
RegCloseKey
(
hkey
);
return
FALSE
;
return
FALSE
;
}
}
...
@@ -591,7 +634,7 @@ BOOL PSDRV_GetTrueTypeMetrics(void)
...
@@ -591,7 +634,7 @@ BOOL PSDRV_GetTrueTypeMetrics(void)
if
(
ReadTrueTypeDir
(
library
,
value_buf
)
==
FALSE
)
if
(
ReadTrueTypeDir
(
library
,
value_buf
)
==
FALSE
)
{
{
RegCloseKey
(
hkey
);
RegCloseKey
(
hkey
);
FT_Done_FreeType
(
library
);
p
FT_Done_FreeType
(
library
);
return
FALSE
;
return
FALSE
;
}
}
...
@@ -602,7 +645,19 @@ BOOL PSDRV_GetTrueTypeMetrics(void)
...
@@ -602,7 +645,19 @@ BOOL PSDRV_GetTrueTypeMetrics(void)
}
}
RegCloseKey
(
hkey
);
RegCloseKey
(
hkey
);
FT_Done_FreeType
(
library
);
pFT_Done_FreeType
(
library
);
wine_dlclose
(
ft_handle
,
NULL
,
0
);
ft_handle
=
NULL
;
return
TRUE
;
sym_not_found:
WINE_MESSAGE
(
"Wine cannot find certain functions that it needs inside the FreeType
\n
"
"font library. To enable Wine to use TrueType fonts please upgrade
\n
"
"FreeType to at least version 2.0.5.
\n
"
"http://www.freetype.org
\n
"
);
wine_dlclose
(
ft_handle
,
NULL
,
0
);
ft_handle
=
NULL
;
return
TRUE
;
return
TRUE
;
}
}
...
...
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