X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/d111a89a859456a8649e809eec131f2639907610..08a43154b415a2786c16c4deb7baa7003a27c0ac:/src/unix/fontenum.cpp diff --git a/src/unix/fontenum.cpp b/src/unix/fontenum.cpp index fdc00b9142..bb2dbed789 100644 --- a/src/unix/fontenum.cpp +++ b/src/unix/fontenum.cpp @@ -34,8 +34,9 @@ // private functions // ---------------------------------------------------------------------------- -// create the list of all fonts with the given spacing -static char **CreateFontList(wxChar spacing, int *nFonts); +// create the list of all fonts with the given spacing and encoding +static char **CreateFontList(wxChar spacing, wxFontEncoding encoding, + int *nFonts); // extract all font families from the given font list and call our // OnFontFamily() for each of them @@ -56,13 +57,19 @@ static bool ProcessFamiliesFromFontList(wxFontEnumerator *This, // helpers // ---------------------------------------------------------------------------- -static char **CreateFontList(wxChar spacing, int *nFonts) +static char **CreateFontList(wxChar spacing, + wxFontEncoding encoding, + int *nFonts) { + wxString xencoding, xregistry; + wxGetXFontEncoding(encoding, &xregistry, &xencoding); + wxString pattern; - pattern.Printf(wxT("-*-*-*-*-*-*-*-*-*-*-%c-*-*-*"), spacing); + pattern.Printf(wxT("-*-*-*-*-*-*-*-*-*-*-%c-*-%s-%s"), + spacing, xregistry.c_str(), xencoding.c_str()); // get the list of all fonts - return XListFonts((Display *)wxGetDisplay(), pattern, 32767, nFonts); + return XListFonts((Display *)wxGetDisplay(), pattern.mb_str(), 32767, nFonts); } static bool ProcessFamiliesFromFontList(wxFontEnumerator *This, @@ -74,7 +81,7 @@ static bool ProcessFamiliesFromFontList(wxFontEnumerator *This, for ( int n = 0; n < nFonts; n++ ) { char *font = fonts[n]; - if ( !wxString(font).Matches("-*-*-*-*-*-*-*-*-*-*-*-*-*-*") ) + if ( !wxString(font).Matches(wxT("-*-*-*-*-*-*-*-*-*-*-*-*-*-*")) ) { // it's not a full font name (probably an alias) continue; @@ -84,16 +91,17 @@ static bool ProcessFamiliesFromFontList(wxFontEnumerator *This, char *family = dash + 1; dash = strchr(family, '-'); *dash = '\0'; // !NULL because Matches() above succeeded + wxString fam(family); - if ( families.Index(family) == wxNOT_FOUND ) + if ( families.Index(fam) == wxNOT_FOUND ) { - if ( !This->OnFontFamily(family) ) + if ( !This->OnFontFamily(fam) ) { // stop enumerating return FALSE; } - families.Add(family); + families.Add(fam); } //else: already seen } @@ -105,7 +113,8 @@ static bool ProcessFamiliesFromFontList(wxFontEnumerator *This, // wxFontEnumerator // ---------------------------------------------------------------------------- -bool wxFontEnumerator::EnumerateFamilies(bool fixedWidthOnly) +bool wxFontEnumerator::EnumerateFamilies(wxFontEncoding encoding, + bool fixedWidthOnly) { int nFonts; char **fonts; @@ -113,7 +122,7 @@ bool wxFontEnumerator::EnumerateFamilies(bool fixedWidthOnly) if ( fixedWidthOnly ) { bool cont = TRUE; - fonts = CreateFontList(wxT('m'), &nFonts); + fonts = CreateFontList(wxT('m'), encoding, &nFonts); if ( fonts ) { cont = ProcessFamiliesFromFontList(this, fonts, nFonts); @@ -126,7 +135,7 @@ bool wxFontEnumerator::EnumerateFamilies(bool fixedWidthOnly) return TRUE; } - fonts = CreateFontList(wxT('c'), &nFonts); + fonts = CreateFontList(wxT('c'), encoding, &nFonts); if ( !fonts ) { return TRUE; @@ -134,11 +143,14 @@ bool wxFontEnumerator::EnumerateFamilies(bool fixedWidthOnly) } else { - fonts = CreateFontList(wxT('*'), &nFonts); + fonts = CreateFontList(wxT('*'), encoding, &nFonts); if ( !fonts ) { - wxFAIL_MSG(wxT("No fonts at all on this system?")); + // it's ok if there are no fonts in given encoding - but it's not + // ok if there are no fonts at all + wxASSERT_MSG(encoding != wxFONTENCODING_SYSTEM, + wxT("No fonts at all on this system?")); return FALSE; } @@ -159,7 +171,7 @@ bool wxFontEnumerator::EnumerateEncodings(const wxString& family) // get the list of all fonts int nFonts; - char **fonts = XListFonts((Display *)wxGetDisplay(), pattern, + char **fonts = XListFonts((Display *)wxGetDisplay(), pattern.mb_str(), 32767, &nFonts); if ( !fonts ) @@ -173,7 +185,7 @@ bool wxFontEnumerator::EnumerateEncodings(const wxString& family) for ( int n = 0; n < nFonts; n++ ) { char *font = fonts[n]; - if ( !wxString(font).Matches("-*-*-*-*-*-*-*-*-*-*-*-*-*-*") ) + if ( !wxString(font).Matches(wxT("-*-*-*-*-*-*-*-*-*-*-*-*-*-*")) ) { // it's not a full font name (probably an alias) continue;