#endif // PCH
#ifdef __X__
-#ifdef __VMS__
-#pragma message disable nosimpint
-#endif
-#include <X11/Xlib.h>
-#ifdef __VMS__
-#pragma message enable nosimpint
-#endif
+ #ifdef __VMS__
+ #pragma message disable nosimpint
+ #endif
+
+ #include <X11/Xlib.h>
+
+ #ifdef __VMS__
+ #pragma message enable nosimpint
+ #endif
#include "wx/utils.h" // for wxGetDisplay()
#elif defined(__WXGTK__)
- #include "gdk/gdk.h"
+ // we have to declare struct tm to avoid problems with first forward
+ // declaring it in C code (glib.h included from gdk.h does it) and then
+ // defining it when time.h is included from the headers below - this is
+ // known not to work at least with Sun CC 6.01
+ #include <time.h>
+
+ #include <gdk/gdk.h>
#endif
#include "wx/fontutil.h"
// encodingid;registry;encoding[;facename]
bool wxNativeEncodingInfo::FromString(const wxString& s)
{
+ // use ";", not "-" because it may be part of encoding name
wxStringTokenizer tokenizer(s, _T(";"));
- // cannot use "-" because it may be part of encoding name
wxString encid = tokenizer.GetNextToken();
long enc;
}
break;
+ case wxFONTENCODING_UTF8:
+ // FIXME: this is probably false, but this is how they are called on
+ // my system and I don't know what the standard XFLD is (VZ)
+ info->xregistry = wxT("iso646.1991");
+ info->xencoding = wxT("*");
+ break;
+
case wxFONTENCODING_KOI8:
info->xregistry = wxT("koi8");
}
}
}
-
+
// OK, we have the correct xregistry/xencoding in info structure
wxNativeFont font = 0;
// if we already have the X font name, try to use it
if( xFontName && !xFontName->IsEmpty() )
- font = wxLoadFont(*xFontName);
+ {
+ //
+ // Make sure point size is correct for scale factor.
+ //
+ wxStringTokenizer tokenizer(*xFontName, _T("-"), wxTOKEN_RET_DELIMS);
+ wxString newFontName;
+
+ for(int i = 0; i < 8; i++)
+ newFontName += tokenizer.NextToken();
+
+ (void) tokenizer.NextToken();
+
+ newFontName += wxString::Format("%d-", pointSize);
+
+ while(tokenizer.HasMoreTokens())
+ newFontName += tokenizer.GetNextToken();
+
+ font = wxLoadFont(newFontName);
+
+ if(font)
+ *xFontName = newFontName;
+ }
if( !font )
font = wxLoadQueryFont( pointSize, family, style, weight,
wxNativeFont test = (wxNativeFont) g_fontHash->Get( fontspec );
if (test)
{
-// printf( "speed up\n" );
return TRUE;
}
test = wxLoadFont(fontspec);
g_fontHash->Put( fontspec, (wxObject*) test );
-
+
if ( test )
{
wxFreeFont(test);