1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     wxFontMapper class 
   4 // Author:      Vadim Zeitlin 
   8 // Copyright:   (c) Vadim Zeitlin 
   9 // Licence:     wxWindows licence 
  10 ///////////////////////////////////////////////////////////////////////////// 
  12 #ifndef _WX_FONTMAPPER_H_ 
  13 #define _WX_FONTMAPPER_H_ 
  15 // ---------------------------------------------------------------------------- 
  17 // ---------------------------------------------------------------------------- 
  21 #include "wx/fontenc.h"         // for wxFontEncoding 
  24     #include "wx/fontutil.h"    // for wxNativeEncodingInfo 
  27 #if wxUSE_CONFIG && wxUSE_FILECONFIG 
  28     class WXDLLIMPEXP_BASE wxConfigBase
; 
  29 #endif // wxUSE_CONFIG 
  31 class WXDLLIMPEXP_CORE wxFontMapper
; 
  34     class WXDLLIMPEXP_CORE wxWindow
; 
  37 // ============================================================================ 
  38 // wxFontMapper manages user-definable correspondence between wxWidgets font 
  39 // encodings and the fonts present on the machine. 
  41 // This is a singleton class, font mapper objects can only be accessed using 
  42 // wxFontMapper::Get(). 
  43 // ============================================================================ 
  45 // ---------------------------------------------------------------------------- 
  46 // wxFontMapperBase: this is a non-interactive class which just uses its built 
  47 //                   in knowledge of the encodings equivalence 
  48 // ---------------------------------------------------------------------------- 
  50 class WXDLLIMPEXP_BASE wxFontMapperBase
 
  52     // For IsWxFontMapper() 
  53     friend class WXDLLIMPEXP_CORE wxFontMapper
; 
  55     // constructtor and such 
  56     // --------------------- 
  61     // virtual dtor for any base class 
  62     virtual ~wxFontMapperBase(); 
  64     // return instance of the wxFontMapper singleton 
  65     // wxBase code only cares that it's a wxFontMapperBase 
  66     // In wxBase, wxFontMapper is only forward declared 
  67     // so one cannot implicitly cast from it to wxFontMapperBase. 
  68     static wxFontMapperBase 
*Get(); 
  70     // set the singleton to 'mapper' instance and return previous one 
  71     static wxFontMapper 
*Set(wxFontMapper 
*mapper
); 
  73     // translates charset strings to encoding 
  74     // -------------------------------------- 
  76     // returns the encoding for the given charset (in the form of RFC 2046) or 
  77     // wxFONTENCODING_SYSTEM if couldn't decode it 
  79     // interactive parameter is ignored in the base class, we behave as if it 
  81     virtual wxFontEncoding 
CharsetToEncoding(const wxString
& charset
, 
  82                                              bool interactive 
= true); 
  84     // information about supported encodings 
  85     // ------------------------------------- 
  87     // get the number of font encodings we know about 
  88     static size_t GetSupportedEncodingsCount(); 
  90     // get the n-th supported encoding 
  91     static wxFontEncoding 
GetEncoding(size_t n
); 
  93     // return internal string identifier for the encoding (see also 
  94     // GetEncodingDescription()) 
  95     static wxString 
GetEncodingName(wxFontEncoding encoding
); 
  97     // return user-readable string describing the given encoding 
  99     // NB: hard-coded now, but might change later (read it from config?) 
 100     static wxString 
GetEncodingDescription(wxFontEncoding encoding
); 
 102     // find the encoding corresponding to the given name, inverse of 
 103     // GetEncodingName() and less general than CharsetToEncoding() 
 105     // returns wxFONTENCODING_MAX if the name is not a supported encoding 
 106     static wxFontEncoding 
GetEncodingFromName(const wxString
& name
); 
 109     // functions which allow to configure the config object used: by default, 
 110     // the global one (from wxConfigBase::Get() will be used) and the default 
 111     // root path for the config settings is the string returned by 
 112     // GetDefaultConfigPath() 
 113     // ---------------------------------------------------------------------- 
 115 #if wxUSE_CONFIG && wxUSE_FILECONFIG 
 116     // set the config object to use (may be NULL to use default) 
 117     void SetConfig(wxConfigBase 
*config
) { m_config 
= config
; } 
 119     // set the root config path to use (should be an absolute path) 
 120     void SetConfigPath(const wxString
& prefix
); 
 122     // return default config path 
 123     static const wxChar 
*GetDefaultConfigPath(); 
 124 #endif // wxUSE_CONFIG 
 128 #if wxUSE_CONFIG && wxUSE_FILECONFIG 
 129     // get the config object we're using -- if it wasn't set explicitly, this 
 130     // function will use wxConfig::Get() to get the global one 
 131     wxConfigBase 
*GetConfig(); 
 133     // gets the root path for our settings -- if it wasn't set explicitly, use 
 134     // GetDefaultConfigPath() 
 135     const wxString
& GetConfigPath(); 
 137     // change to the given (relative) path in the config, return true if ok 
 138     // (then GetConfig() will return something !NULL), false if no config 
 141     // caller should provide a pointer to the string variable which should be 
 142     // later passed to RestorePath() 
 143     bool ChangePath(const wxString
& pathNew
, wxString 
*pathOld
); 
 145     // restore the config path after use 
 146     void RestorePath(const wxString
& pathOld
); 
 148     // config object and path (in it) to use 
 149     wxConfigBase 
*m_config
; 
 150     bool m_configIsDummy
; 
 152     wxString m_configRootPath
; 
 153 #endif // wxUSE_CONFIG 
 155     // the real implementation of the base class version of CharsetToEncoding() 
 157     // returns wxFONTENCODING_UNKNOWN if encoding is unknown and we shouldn't 
 158     // ask the user about it, wxFONTENCODING_SYSTEM if it is unknown but we 
 159     // should/could ask the user 
 160     int NonInteractiveCharsetToEncoding(const wxString
& charset
); 
 163     // pseudo-RTTI since we aren't a wxObject. 
 164     virtual bool IsWxFontMapper(); 
 166     // the global fontmapper object or NULL 
 167     static wxFontMapper 
*sm_instance
; 
 169     friend class wxFontMapperPathChanger
; 
 171     DECLARE_NO_COPY_CLASS(wxFontMapperBase
) 
 174 // ---------------------------------------------------------------------------- 
 175 // wxFontMapper: interactive extension of wxFontMapperBase 
 177 // The default implementations of all functions will ask the user if they are 
 178 // not capable of finding the answer themselves and store the answer in a 
 179 // config file (configurable via SetConfigXXX functions). This behaviour may 
 180 // be disabled by giving the value of false to "interactive" parameter. 
 181 // However, the functions will always consult the config file to allow the 
 182 // user-defined values override the default logic and there is no way to 
 183 // disable this -- which shouldn't be ever needed because if "interactive" was 
 184 // never true, the config file is never created anyhow. 
 185 // ---------------------------------------------------------------------------- 
 189 class WXDLLIMPEXP_CORE wxFontMapper 
: public wxFontMapperBase
 
 195     // virtual dtor for a base class 
 196     virtual ~wxFontMapper(); 
 198     // working with the encodings 
 199     // -------------------------- 
 201     // returns the encoding for the given charset (in the form of RFC 2046) or 
 202     // wxFONTENCODING_SYSTEM if couldn't decode it 
 203     virtual wxFontEncoding 
CharsetToEncoding(const wxString
& charset
, 
 204                                              bool interactive 
= true); 
 206     // find an alternative for the given encoding (which is supposed to not be 
 207     // available on this system). If successful, return true and fill info 
 208     // structure with the parameters required to create the font, otherwise 
 210     virtual bool GetAltForEncoding(wxFontEncoding encoding
, 
 211                                    wxNativeEncodingInfo 
*info
, 
 212                                    const wxString
& facename 
= wxEmptyString
, 
 213                                    bool interactive 
= true); 
 215     // version better suitable for 'public' use. Returns wxFontEcoding 
 216     // that can be used it wxFont ctor 
 217     bool GetAltForEncoding(wxFontEncoding encoding
, 
 218                            wxFontEncoding 
*alt_encoding
, 
 219                            const wxString
& facename 
= wxEmptyString
, 
 220                            bool interactive 
= true); 
 222     // checks whether given encoding is available in given face or not. 
 224     // if no facename is given (default), return true if it's available in any 
 226     virtual bool IsEncodingAvailable(wxFontEncoding encoding
, 
 227                                      const wxString
& facename 
= wxEmptyString
); 
 230     // configure the appearance of the dialogs we may popup 
 231     // ---------------------------------------------------- 
 233     // the parent window for modal dialogs 
 234     void SetDialogParent(wxWindow 
*parent
) { m_windowParent 
= parent
; } 
 236     // the title for the dialogs (note that default is quite reasonable) 
 237     void SetDialogTitle(const wxString
& title
) { m_titleDialog 
= title
; } 
 239     // GUI code needs to know it's a wxFontMapper because there 
 240     // are additional methods in the subclass. 
 241     static wxFontMapper 
*Get(); 
 244     // GetAltForEncoding() helper: tests for the existence of the given 
 245     // encoding and saves the result in config if ok - this results in the 
 246     // following (desired) behaviour: when an unknown/unavailable encoding is 
 247     // requested for the first time, the user is asked about a replacement, 
 248     // but if he doesn't choose any and the default logic finds one, it will 
 249     // be saved in the config so that the user won't be asked about it any 
 251     bool TestAltEncoding(const wxString
& configEntry
, 
 252                          wxFontEncoding encReplacement
, 
 253                          wxNativeEncodingInfo 
*info
); 
 255     // the title for our dialogs 
 256     wxString m_titleDialog
; 
 258     // the parent window for our dialogs 
 259     wxWindow 
*m_windowParent
; 
 262     // pseudo-RTTI since we aren't a wxObject. 
 263     virtual bool IsWxFontMapper(); 
 265     DECLARE_NO_COPY_CLASS(wxFontMapper
) 
 270 // ---------------------------------------------------------------------------- 
 272 // ---------------------------------------------------------------------------- 
 274 // the default font mapper for wxWidgets programs do NOT use! This is for 
 275 // backward compatibility, use wxFontMapper::Get() instead 
 276 #define wxTheFontMapper (wxFontMapper::Get()) 
 278 #else // !wxUSE_FONTMAP 
 281     // wxEncodingToCodepage (utils.cpp) needs wxGetNativeFontEncoding 
 282     #include "wx/fontutil.h" 
 285 #endif // wxUSE_FONTMAP/!wxUSE_FONTMAP 
 287 #endif // _WX_FONTMAPPER_H_