+2008-02-14 Tor Lillqvist <tml@novell.com>
+
+ Bug 515484 – Pango on Windows is missing non-TrueType
+ font support
+ Patch from Adrian Johnson.
+
+ * pango/pangowin32-fontmap.c (pango_win32_enum_proc): Accept also
+ OpenType/PS fonts. Interpret the metrics parameter as a
+ NEWTEXTMETRICW struct and check the ntmFlags field.
+
2008-02-13 Sven Neumann <sven@gimp.org>
* pango/pangoft2.c: indentation.
GSList *logfontws;
};
+#if !defined(NTM_PS_OPENTYPE)
+# define NTM_PS_OPENTYPE 0x20000
+#endif
+
#define PANGO_WIN32_TYPE_FAMILY (pango_win32_family_get_type ())
#define PANGO_WIN32_FAMILY(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), PANGO_WIN32_TYPE_FAMILY, PangoWin32Family))
#define PANGO_WIN32_IS_FAMILY(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), PANGO_WIN32_TYPE_FAMILY))
}
static int CALLBACK
-pango_win32_enum_proc (LOGFONTW *lfp,
- TEXTMETRICW *metrics,
- DWORD fontType,
- LPARAM lParam)
+pango_win32_enum_proc (LOGFONTW *lfp,
+ NEWTEXTMETRICW *metrics,
+ DWORD fontType,
+ LPARAM lParam)
{
LOGFONTW lf;
- PING(("%S", lfp->lfFaceName));
-
- if (fontType != TRUETYPE_FONTTYPE)
- return 1;
+ PING(("%S: %lu %lx", lfp->lfFaceName, fontType, metrics->ntmFlags));
- lf = *lfp;
+ if (fontType == TRUETYPE_FONTTYPE ||
+ (_pango_win32_os_version_info.dwMajorVersion >= 5 &&
+ (metrics->ntmFlags & NTM_PS_OPENTYPE)))
+ {
+ lf = *lfp;
- EnumFontFamiliesExW (_pango_win32_hdc, &lf,
- (FONTENUMPROCW) pango_win32_inner_enum_proc,
- lParam, 0);
+ EnumFontFamiliesExW (_pango_win32_hdc, &lf,
+ (FONTENUMPROCW) pango_win32_inner_enum_proc,
+ lParam, 0);
+ }
return 1;
}