1 ///////////////////////////////////////////////////////////////////////////// 
   2 // Name:        src/common/fontenumcmn.cpp 
   3 // Purpose:     wxFontEnumerator class 
   4 // Author:      Vadim Zeitlin 
   8 // Copyright:   (c) 1999-2003 Vadim Zeitlin <vadim@wxwindows.org> 
   9 // Licence:     wxWindows licence 
  10 ///////////////////////////////////////////////////////////////////////////// 
  12 // ============================================================================ 
  14 // ============================================================================ 
  16 // ---------------------------------------------------------------------------- 
  18 // ---------------------------------------------------------------------------- 
  20 // For compilers that support precompilation, includes "wx.h". 
  21 #include "wx/wxprec.h" 
  27 #include "wx/fontenum.h" 
  29 // ============================================================================ 
  31 // ============================================================================ 
  33 // A simple wxFontEnumerator which doesn't perform any filtering and 
  34 // just returns all facenames and encodings found in the system 
  35 class WXDLLEXPORT wxSimpleFontEnumerator 
: public wxFontEnumerator
 
  38     wxSimpleFontEnumerator() { } 
  40     // called by EnumerateFacenames 
  41     virtual bool OnFacename(const wxString
& facename
) 
  43         m_arrFacenames
.Add(facename
); 
  47     // called by EnumerateEncodings 
  48     virtual bool OnFontEncoding(const wxString
& WXUNUSED(facename
), 
  49                                 const wxString
& encoding
) 
  51         m_arrEncodings
.Add(encoding
); 
  56     wxArrayString m_arrFacenames
, m_arrEncodings
; 
  61 wxArrayString 
wxFontEnumerator::GetFacenames(wxFontEncoding encoding
, bool fixedWidthOnly
) 
  63     wxSimpleFontEnumerator temp
; 
  64     temp
.EnumerateFacenames(encoding
, fixedWidthOnly
); 
  65     return temp
.m_arrFacenames
; 
  69 wxArrayString 
wxFontEnumerator::GetEncodings(const wxString
& facename
) 
  71     wxSimpleFontEnumerator temp
; 
  72     temp
.EnumerateEncodings(facename
); 
  73     return temp
.m_arrEncodings
; 
  77 bool wxFontEnumerator::IsValidFacename(const wxString 
&facename
) 
  79     // we cache the result of wxFontEnumerator::GetFacenames supposing that 
  80     // the array of face names won't change in the session of this program 
  81     static wxArrayString s_arr 
= wxFontEnumerator::GetFacenames(); 
  85     //     "MS Shell Dlg is a mapping mechanism that enables  
  86     //     U.S. English Microsoft Windows NT, and Microsoft Windows 2000 to  
  87     //     support locales that have characters that are not contained in code  
  88     //     page 1252. It is not a font but a face name for a nonexistent font." 
  89     // Thus we need to consider "Ms Shell Dlg" and "Ms Shell Dlg 2" as valid 
  90     // font face names even if they are enumerated by wxFontEnumerator 
  91     if (facename
.IsSameAs(wxT("Ms Shell Dlg"), false) || 
  92         facename
.IsSameAs(wxT("Ms Shell Dlg 2"), false)) 
  96     // is given font face name a valid one ? 
  97     if (s_arr
.Index(facename
, false) == wxNOT_FOUND
) 
 103 #ifdef wxHAS_UTF8_FONTS 
 104 bool wxFontEnumerator::EnumerateEncodingsUTF8(const wxString
& facename
) 
 106     // name of UTF-8 encoding: no need to use wxFontMapper for it as it's 
 107     // unlikely to change 
 108     const wxString 
utf8(_T("UTF-8")); 
 110     // all fonts are in UTF-8 only if this code is used 
 111     if ( !facename
.empty() ) 
 113         OnFontEncoding(facename
, utf8
); 
 117     // so enumerating all facenames supporting this encoding is the same as 
 118     // enumerating all facenames 
 119     const wxArrayString 
facenames(GetFacenames(wxFONTENCODING_UTF8
)); 
 120     const size_t count 
= facenames
.size(); 
 124     for ( size_t n 
= 0; n 
< count
; n
++ ) 
 126         OnFontEncoding(facenames
[n
], utf8
); 
 131 #endif // wxHAS_UTF8_FONTS