X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f1d7cbac4369e180a8d7c19f386b301196d09369..ddfca47f05f821f034514bf5d5cf938d80fa2829:/src/unix/fontenum.cpp diff --git a/src/unix/fontenum.cpp b/src/unix/fontenum.cpp index c68984623b..4c5392c094 100644 --- a/src/unix/fontenum.cpp +++ b/src/unix/fontenum.cpp @@ -23,14 +23,71 @@ #include "wx/defs.h" #include "wx/dynarray.h" -#include "wx/regex.h" #include "wx/string.h" +#include "wx/regex.h" #include "wx/utils.h" #include "wx/fontmap.h" #include "wx/fontenum.h" #include "wx/fontutil.h" +// ---------------------------------------------------------------------------- +// GTK 2.0 +// ---------------------------------------------------------------------------- + +#ifdef __WXGTK20__ + +#include "wx/gtk/private.h" + +extern GtkWidget *wxGetRootWindow(); + +static int +cmp_families (const void *a, const void *b) +{ + const char *a_name = pango_font_family_get_name (*(PangoFontFamily **)a); + const char *b_name = pango_font_family_get_name (*(PangoFontFamily **)b); + + return g_utf8_collate (a_name, b_name); +} + +// I admit I don't yet understand encodings with Pango +bool wxFontEnumerator::EnumerateFacenames(wxFontEncoding encoding, + bool fixedWidthOnly) +{ + if ( fixedWidthOnly ) + { + OnFacename( wxT("monospaced") ); + } + else + { + PangoFontFamily **families = NULL; + gint n_families = 0; + pango_context_list_families ( + gtk_widget_get_pango_context( wxGetRootWindow() ), + &families, &n_families ); + qsort (families, n_families, sizeof (PangoFontFamily *), cmp_families); + + for (int i=0; iGetAltForEncoding(encoding, &info); + (void)wxFontMapper::Get()->GetAltForEncoding(encoding, &info); } #endif // wxUSE_FONTMAP @@ -106,7 +164,7 @@ static bool ProcessFamiliesFromFontList(wxFontEnumerator *This, { char *font = fonts[n]; #if wxUSE_REGEX - if ( re.Matches(font) ) + if ( !re.Matches(font) ) #else // !wxUSE_REGEX if ( !wxString(font).Matches(wxT("-*-*-*-*-*-*-*-*-*-*-*-*-*-*")) ) #endif // wxUSE_REGEX/!wxUSE_REGEX @@ -136,6 +194,8 @@ static bool ProcessFamiliesFromFontList(wxFontEnumerator *This, return TRUE; } +#endif + // wxUSE_NANOX // ---------------------------------------------------------------------------- // wxFontEnumerator @@ -144,6 +204,9 @@ static bool ProcessFamiliesFromFontList(wxFontEnumerator *This, bool wxFontEnumerator::EnumerateFacenames(wxFontEncoding encoding, bool fixedWidthOnly) { +#if wxUSE_NANOX + return FALSE; +#else int nFonts; char **fonts; @@ -187,12 +250,16 @@ bool wxFontEnumerator::EnumerateFacenames(wxFontEncoding encoding, (void)ProcessFamiliesFromFontList(this, fonts, nFonts); XFreeFontNames(fonts); - return TRUE; +#endif + // wxUSE_NANOX } bool wxFontEnumerator::EnumerateEncodings(const wxString& family) { +#if wxUSE_NANOX + return FALSE; +#else wxString pattern; pattern.Printf(wxT("-*-%s-*-*-*-*-*-*-*-*-*-*-*-*"), family.IsEmpty() ? wxT("*") : family.c_str()); @@ -257,4 +324,9 @@ bool wxFontEnumerator::EnumerateEncodings(const wxString& family) XFreeFontNames(fonts); return TRUE; +#endif + // wxUSE_NANOX } + +#endif + // __WXGTK20__