Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-fonts
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
Aleksandr Isakov
wine-fonts
Commits
fb013d7a
Commit
fb013d7a
authored
Aug 12, 2015
by
Nikolay Sivov
Committed by
Alexandre Julliard
Aug 13, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dwrite: Fix family name extraction order.
parent
d41f5682
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
48 additions
and
27 deletions
+48
-27
dwrite_private.h
dlls/dwrite/dwrite_private.h
+2
-1
font.c
dlls/dwrite/font.c
+2
-20
gdiinterop.c
dlls/dwrite/gdiinterop.c
+1
-1
opentype.c
dlls/dwrite/opentype.c
+43
-5
No files found.
dlls/dwrite/dwrite_private.h
View file @
fb013d7a
...
...
@@ -152,7 +152,8 @@ extern HRESULT opentype_get_font_table(IDWriteFontFileStream*,DWRITE_FONT_FACE_T
extern
HRESULT
opentype_cmap_get_unicode_ranges
(
void
*
,
UINT32
,
DWRITE_UNICODE_RANGE
*
,
UINT32
*
)
DECLSPEC_HIDDEN
;
extern
void
opentype_get_font_properties
(
IDWriteFontFileStream
*
,
DWRITE_FONT_FACE_TYPE
,
UINT32
,
struct
dwrite_font_props
*
)
DECLSPEC_HIDDEN
;
extern
void
opentype_get_font_metrics
(
IDWriteFontFileStream
*
,
DWRITE_FONT_FACE_TYPE
,
UINT32
,
DWRITE_FONT_METRICS1
*
,
DWRITE_CARET_METRICS
*
)
DECLSPEC_HIDDEN
;
extern
HRESULT
opentype_get_font_strings_from_id
(
const
void
*
,
DWRITE_INFORMATIONAL_STRING_ID
,
IDWriteLocalizedStrings
**
)
DECLSPEC_HIDDEN
;
extern
HRESULT
opentype_get_font_info_strings
(
const
void
*
,
DWRITE_INFORMATIONAL_STRING_ID
,
IDWriteLocalizedStrings
**
)
DECLSPEC_HIDDEN
;
extern
HRESULT
opentype_get_font_familyname
(
IDWriteFontFileStream
*
,
UINT32
,
DWRITE_FONT_FACE_TYPE
,
IDWriteLocalizedStrings
**
)
DECLSPEC_HIDDEN
;
extern
HRESULT
opentype_get_typographic_features
(
IDWriteFontFace
*
,
UINT32
,
UINT32
,
UINT32
,
UINT32
*
,
DWRITE_FONT_FEATURE_TAG
*
)
DECLSPEC_HIDDEN
;
extern
BOOL
opentype_get_vdmx_size
(
const
void
*
,
INT
,
UINT16
*
,
UINT16
*
)
DECLSPEC_HIDDEN
;
extern
UINT32
opentype_get_cpal_palettecount
(
const
void
*
)
DECLSPEC_HIDDEN
;
...
...
dlls/dwrite/font.c
View file @
fb013d7a
...
...
@@ -1108,24 +1108,6 @@ static const IDWriteFontFace2Vtbl dwritefontfacevtbl = {
dwritefontface2_GetRecommendedRenderingMode
};
HRESULT
get_family_names_from_stream
(
IDWriteFontFileStream
*
stream
,
UINT32
index
,
DWRITE_FONT_FACE_TYPE
facetype
,
IDWriteLocalizedStrings
**
names
)
{
const
void
*
name_table
=
NULL
;
void
*
name_context
;
HRESULT
hr
=
E_FAIL
;
opentype_get_font_table
(
stream
,
facetype
,
index
,
MS_NAME_TAG
,
&
name_table
,
&
name_context
,
NULL
,
NULL
);
if
(
name_table
)
{
hr
=
opentype_get_font_strings_from_id
(
name_table
,
DWRITE_INFORMATIONAL_STRING_WIN32_FAMILY_NAMES
,
names
);
IDWriteFontFileStream_ReleaseFileFragment
(
stream
,
name_context
);
}
else
*
names
=
NULL
;
return
hr
;
}
static
HRESULT
get_fontface_from_font
(
struct
dwrite_font
*
font
,
IDWriteFontFace2
**
fontface
)
{
struct
dwrite_font_data
*
data
=
font
->
data
;
...
...
@@ -1318,7 +1300,7 @@ static HRESULT WINAPI dwritefont_GetInformationalStrings(IDWriteFont2 *iface,
WARN
(
"no NAME table found.
\n
"
);
if
(
table_exists
)
{
hr
=
opentype_get_font_
strings_from_id
(
table_data
,
stringid
,
&
data
->
info_strings
[
stringid
]);
hr
=
opentype_get_font_
info_strings
(
table_data
,
stringid
,
&
data
->
info_strings
[
stringid
]);
if
(
FAILED
(
hr
)
||
!
data
->
info_strings
[
stringid
])
return
hr
;
IDWriteFontFace2_ReleaseFontTable
(
fontface
,
context
);
...
...
@@ -2091,7 +2073,7 @@ HRESULT create_font_collection(IDWriteFactory2* factory, IDWriteFontFileEnumerat
break
;
/* get family name from font file */
hr
=
get_family_names_from_stream
(
stream
,
i
,
face_type
,
&
family_name
);
hr
=
opentype_get_font_familyname
(
stream
,
i
,
face_type
,
&
family_name
);
IDWriteFontFileStream_Release
(
stream
);
if
(
FAILED
(
hr
))
{
WARN
(
"unable to get family name from font
\n
"
);
...
...
dlls/dwrite/gdiinterop.c
View file @
fb013d7a
...
...
@@ -575,7 +575,7 @@ static HRESULT WINAPI gdiinterop_ConvertFontFaceToLOGFONT(IDWriteGdiInterop *ifa
index
=
IDWriteFontFace_GetIndex
(
fontface
);
face_type
=
IDWriteFontFace_GetType
(
fontface
);
opentype_get_font_properties
(
stream
,
face_type
,
index
,
&
props
);
hr
=
get_family_names_from_stream
(
stream
,
index
,
face_type
,
&
familynames
);
hr
=
opentype_get_font_familyname
(
stream
,
index
,
face_type
,
&
familynames
);
IDWriteFontFile_Release
(
file
);
IDWriteFontFileStream_Release
(
stream
);
if
(
FAILED
(
hr
))
...
...
dlls/dwrite/opentype.c
View file @
fb013d7a
...
...
@@ -33,6 +33,7 @@ WINE_DEFAULT_DEBUG_CHANNEL(dwrite);
#define MS_TTCF_TAG DWRITE_MAKE_OPENTYPE_TAG('t','t','c','f')
#define MS_GPOS_TAG DWRITE_MAKE_OPENTYPE_TAG('G','P','O','S')
#define MS_GSUB_TAG DWRITE_MAKE_OPENTYPE_TAG('G','S','U','B')
#define MS_NAME_TAG DWRITE_MAKE_OPENTYPE_TAG('n','a','m','e')
#ifdef WORDS_BIGENDIAN
#define GET_BE_WORD(x) (x)
...
...
@@ -1194,12 +1195,11 @@ static void get_name_record_locale(enum OPENTYPE_PLATFORM_ID platform, USHORT la
}
}
HRESULT
opentype_get_font_strings_from_id
(
const
void
*
table_data
,
DWRITE_INFORMATIONAL
_STRING_ID
id
,
IDWriteLocalizedStrings
**
strings
)
HRESULT
opentype_get_font_strings_from_id
(
const
void
*
table_data
,
enum
OPENTYPE
_STRING_ID
id
,
IDWriteLocalizedStrings
**
strings
)
{
const
TT_NAME_V0
*
header
;
BYTE
*
storage_area
=
0
;
USHORT
count
=
0
;
UINT16
name_id
;
BOOL
exists
;
HRESULT
hr
;
int
i
;
...
...
@@ -1222,14 +1222,12 @@ HRESULT opentype_get_font_strings_from_id(const void *table_data, DWRITE_INFORMA
storage_area
=
(
LPBYTE
)
table_data
+
GET_BE_WORD
(
header
->
stringOffset
);
count
=
GET_BE_WORD
(
header
->
count
);
name_id
=
dwriteid_to_opentypeid
[
id
];
exists
=
FALSE
;
for
(
i
=
0
;
i
<
count
;
i
++
)
{
const
TT_NameRecord
*
record
=
&
header
->
nameRecord
[
i
];
USHORT
lang_id
,
length
,
offset
,
encoding
,
platform
;
if
(
GET_BE_WORD
(
record
->
nameID
)
!=
name_
id
)
if
(
GET_BE_WORD
(
record
->
nameID
)
!=
id
)
continue
;
exists
=
TRUE
;
...
...
@@ -1293,6 +1291,46 @@ HRESULT opentype_get_font_strings_from_id(const void *table_data, DWRITE_INFORMA
*
strings
=
NULL
;
}
return
exists
?
S_OK
:
E_FAIL
;
}
/* Provides a conversion from DWRITE to OpenType name ids, input id be valid, it's not checked. */
HRESULT
opentype_get_font_info_strings
(
const
void
*
table_data
,
DWRITE_INFORMATIONAL_STRING_ID
id
,
IDWriteLocalizedStrings
**
strings
)
{
return
opentype_get_font_strings_from_id
(
table_data
,
dwriteid_to_opentypeid
[
id
],
strings
);
}
/* Name locating order is WWS Family Name -> Preferred Name -> Family Name. If font claims to
have 'Preferred Name' in WWS format, then WWS name is not used. */
HRESULT
opentype_get_font_familyname
(
IDWriteFontFileStream
*
stream
,
UINT32
index
,
DWRITE_FONT_FACE_TYPE
facetype
,
IDWriteLocalizedStrings
**
names
)
{
const
TT_OS2_V2
*
tt_os2
;
void
*
os2_context
,
*
name_context
;
const
void
*
name_table
;
HRESULT
hr
;
opentype_get_font_table
(
stream
,
facetype
,
index
,
MS_OS2_TAG
,
(
const
void
**
)
&
tt_os2
,
&
os2_context
,
NULL
,
NULL
);
opentype_get_font_table
(
stream
,
facetype
,
index
,
MS_NAME_TAG
,
&
name_table
,
&
name_context
,
NULL
,
NULL
);
*
names
=
NULL
;
/* if Preferred Family doesn't conform to WWS model try WWS name */
if
(
tt_os2
&&
!
(
GET_BE_WORD
(
tt_os2
->
fsSelection
)
&
OS2_FSSELECTION_WWS
))
hr
=
opentype_get_font_strings_from_id
(
name_table
,
OPENTYPE_STRING_WWS_FAMILY_NAME
,
names
);
else
hr
=
E_FAIL
;
if
(
FAILED
(
hr
))
hr
=
opentype_get_font_strings_from_id
(
name_table
,
OPENTYPE_STRING_PREFERRED_FAMILY_NAME
,
names
);
if
(
FAILED
(
hr
))
hr
=
opentype_get_font_strings_from_id
(
name_table
,
OPENTYPE_STRING_FAMILY_NAME
,
names
);
if
(
tt_os2
)
IDWriteFontFileStream_ReleaseFileFragment
(
stream
,
os2_context
);
if
(
name_context
)
IDWriteFontFileStream_ReleaseFileFragment
(
stream
,
name_context
);
return
hr
;
}
...
...
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