]> git.saurik.com Git - wxWidgets.git/blobdiff - src/gtk1/font.cpp
IS_KIND_OF -> wxIS_KIND_OF compilation fix
[wxWidgets.git] / src / gtk1 / font.cpp
index 2152854752a24da066716e1d87d51cafb713cf87..8518877b64e607290a74c632538442c7c0c00df8 100644 (file)
@@ -2,10 +2,9 @@
 // Name:        font.cpp
 // Purpose:
 // Author:      Robert Roebling
-// Created:     01/02/97
-// Id:
+// Id:          $Id$
 // Copyright:   (c) 1998 Robert Roebling, Julian Smart and Markus Holzem
-// Licence:    wxWindows licence
+// Licence:       wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
 #ifdef __GNUG__
 // local data
 //-----------------------------------------------------------------------------
 
-static char *wx_font_family [] = {
-    "wxDEFAULT", "wxDECORATIVE", "wxROMAN", "wxSCRIPT",
-    "wxSWISS", "wxMODERN", "wxTELETYPE",
-};
-
-/*
-static char *wx_font_style [] = {
-    "wxDEFAULT", "wxNORMAL", "wxSLANT", "wxITALIC",
-};
-
-static char *wx_font_weight [] = {
-    "wxDEFAULT", "wxNORMAL", "wxBOLD", "wxLIGHT",
-};
-*/
-
 extern wxFontNameDirectory *wxTheFontNameDirectory;
 
 //-----------------------------------------------------------------------------
@@ -43,53 +27,53 @@ extern wxFontNameDirectory *wxTheFontNameDirectory;
 
 class wxFontRefData: public wxObjectRefData
 {
-  public:
-  
-    wxFontRefData(void);
-    ~wxFontRefData(void);
+public:
+
+    wxFontRefData();
+    ~wxFontRefData();
+
     wxList   m_scaled_xfonts;
     int      m_pointSize;
     int      m_family, m_style, m_weight;
     bool     m_underlined;
     int      m_fontId;
     char*    m_faceName;
-     
+
     bool     m_byXFontName;
     GdkFont *m_font;
-    
+
     friend wxFont;
 };
 
-wxFontRefData::wxFontRefData(void) : m_scaled_xfonts(wxKEY_INTEGER)
-{
-  m_byXFontName = FALSE;
-  m_pointSize = -1;
-  m_family = -1;
-  m_style = -1;
-  m_weight = -1;
-  m_underlined = FALSE;
-  m_fontId = 0;
-  m_faceName = (char *) NULL;
-  m_font = (GdkFont *) NULL;
-}
-
-wxFontRefData::~wxFontRefData(void)
-{
-  wxNode *node = m_scaled_xfonts.First();
-  while (node) 
-  {
-    GdkFont *font = (GdkFont*)node->Data();
-    wxNode *next = node->Next();
-    gdk_font_unref( font );
-    node = next;
-  }
-  if (m_faceName) 
-  {
-    delete m_faceName;
+wxFontRefData::wxFontRefData() : m_scaled_xfonts(wxKEY_INTEGER)
+{
+    m_byXFontName = FALSE;
+    m_pointSize = 12;
+    m_family = wxSWISS;
+    m_style = wxNORMAL;
+    m_weight = wxNORMAL;
+    m_underlined = FALSE;
+    m_fontId = 0;
     m_faceName = (char *) NULL;
-  }
-  if (m_font) gdk_font_unref( m_font );
+    m_font = (GdkFont *) NULL;
+}
+
+wxFontRefData::~wxFontRefData()
+{
+    wxNode *node = m_scaled_xfonts.First();
+    while (node)
+    {
+        GdkFont *font = (GdkFont*)node->Data();
+        wxNode *next = node->Next();
+        gdk_font_unref( font );
+        node = next;
+    }
+    if (m_faceName)
+    {
+        delete m_faceName;
+        m_faceName = (char *) NULL;
+    }
+    if (m_font) gdk_font_unref( m_font );
 }
 
 //-----------------------------------------------------------------------------
@@ -98,198 +82,205 @@ wxFontRefData::~wxFontRefData(void)
 
 IMPLEMENT_DYNAMIC_CLASS(wxFont, wxGDIObject)
 
-wxFont::wxFont(void)
+wxFont::wxFont()
 {
-  if (wxTheFontList) wxTheFontList->Append( this );
+    if (wxTheFontList) wxTheFontList->Append( this );
 }
 
 wxFont::wxFont( char *xFontName )
 {
-  if (!xFontName) return;
-  
-  m_refData = new wxFontRefData();
-  
-  M_FONTDATA->m_byXFontName = TRUE;
-  M_FONTDATA->m_font = gdk_font_load( xFontName );
+    if (!xFontName) return;
+
+    m_refData = new wxFontRefData();
+
+    M_FONTDATA->m_byXFontName = TRUE;
+    M_FONTDATA->m_font = gdk_font_load( xFontName );
 }
 
 wxFont::wxFont(int PointSize, int FontIdOrFamily, int Style, int Weight,
-              bool Underlined, const char* Face)
+        bool Underlined, const char* Face)
 {
-  m_refData = new wxFontRefData();
-  
-  if ((M_FONTDATA->m_faceName = (Face) ? copystring(Face) : (char*)NULL) ) 
-  {
-    M_FONTDATA->m_fontId = wxTheFontNameDirectory->FindOrCreateFontId( Face, FontIdOrFamily );
-    M_FONTDATA->m_family  = wxTheFontNameDirectory->GetFamily( FontIdOrFamily );
-  }
-  else 
-  {
-    M_FONTDATA->m_fontId = FontIdOrFamily;
-    M_FONTDATA->m_family  = wxTheFontNameDirectory->GetFamily( FontIdOrFamily );
-  }
-  M_FONTDATA->m_style = Style;
-  M_FONTDATA->m_weight = Weight;
-  M_FONTDATA->m_pointSize = PointSize;
-  M_FONTDATA->m_underlined = Underlined;
+    m_refData = new wxFontRefData();
 
-  if (wxTheFontList) wxTheFontList->Append( this );
+    if (FontIdOrFamily == wxDEFAULT) FontIdOrFamily = wxSWISS;
+    M_FONTDATA->m_family = FontIdOrFamily;
+
+    if ((M_FONTDATA->m_faceName = (Face) ? copystring(Face) : (char*)NULL) )
+    {
+        M_FONTDATA->m_fontId = wxTheFontNameDirectory->FindOrCreateFontId( Face, FontIdOrFamily );
+        M_FONTDATA->m_family  = wxTheFontNameDirectory->GetFamily( FontIdOrFamily );
+    }
+    else
+    {
+        M_FONTDATA->m_fontId = FontIdOrFamily;
+        M_FONTDATA->m_family  = wxTheFontNameDirectory->GetFamily( FontIdOrFamily );
+    }
+
+    if (Style == wxDEFAULT) Style = wxNORMAL;
+    M_FONTDATA->m_style = Style;
+    if (Weight == wxDEFAULT) Weight = wxNORMAL;
+    M_FONTDATA->m_weight = Weight;
+    if (PointSize == wxDEFAULT) PointSize = 12;
+    M_FONTDATA->m_pointSize = PointSize;
+    M_FONTDATA->m_underlined = Underlined;
+
+    if (wxTheFontList) wxTheFontList->Append( this );
 }
 
-wxFont::wxFont(int PointSize, const char *Face, int Family, int Style, 
-              int Weight, bool Underlined)
+wxFont::wxFont(int PointSize, const char *Face, int Family, int Style,
+        int Weight, bool Underlined)
 {
-  m_refData = new wxFontRefData();
+    m_refData = new wxFontRefData();
 
-  M_FONTDATA->m_fontId = wxTheFontNameDirectory->FindOrCreateFontId( Face, Family );
-  M_FONTDATA->m_faceName = (Face) ? copystring(Face) : (char*)NULL;
-  M_FONTDATA->m_family = wxTheFontNameDirectory->GetFamily( M_FONTDATA->m_fontId );
-  M_FONTDATA->m_style = Style;
-  M_FONTDATA->m_weight = Weight;
-  M_FONTDATA->m_pointSize = PointSize;
-  M_FONTDATA->m_underlined = Underlined;
+    M_FONTDATA->m_fontId = wxTheFontNameDirectory->FindOrCreateFontId( Face, Family );
+    M_FONTDATA->m_faceName = (Face) ? copystring(Face) : (char*)NULL;
+    M_FONTDATA->m_family = wxTheFontNameDirectory->GetFamily( M_FONTDATA->m_fontId );
+    M_FONTDATA->m_style = Style;
+    M_FONTDATA->m_weight = Weight;
+    M_FONTDATA->m_pointSize = PointSize;
+    M_FONTDATA->m_underlined = Underlined;
 
-  if (wxTheFontList) wxTheFontList->Append( this );
+    if (wxTheFontList) wxTheFontList->Append( this );
 }
 
 wxFont::wxFont( const wxFont& font )
-{ 
-  Ref( font ); 
-  
-  if (wxTheFontList) wxTheFontList->Append( this );
-}
+{
+    Ref( font );
 
-wxFont::wxFont( const wxFont* font ) 
-{ 
-  UnRef(); 
-  if (font) Ref( *font ); 
-  
-  if (wxTheFontList) wxTheFontList->Append( this );
+    if (wxTheFontList) wxTheFontList->Append( this );
 }
 
-wxFont::~wxFont(void)
+wxFont::~wxFont()
 {
-  if (wxTheFontList) wxTheFontList->DeleteObject( this );
+    if (wxTheFontList) wxTheFontList->DeleteObject( this );
 }
 
-wxFont& wxFont::operator = ( const wxFont& font ) 
-{ 
-  if (*this == font) return (*this); 
-  Ref( font ); 
-  return *this; 
+wxFont& wxFont::operator = ( const wxFont& font )
+{
+    if (*this == font) return (*this);
+    Ref( font );
+    return *this;
 }
 
-bool wxFont::operator == ( const wxFont& font ) 
-{ 
-  return m_refData == font.m_refData; 
+bool wxFont::operator == ( const wxFont& font )
+{
+    return m_refData == font.m_refData;
 }
 
-bool wxFont::operator != ( const wxFont& font ) 
-{ 
-  return m_refData != font.m_refData; 
+bool wxFont::operator != ( const wxFont& font )
+{
+    return m_refData != font.m_refData;
 }
 
-bool wxFont::Ok()
+bool wxFont::Ok() const
 {
-  return (m_refData != NULL);
+    return (m_refData != NULL);
 }
 
-int wxFont::GetPointSize(void) const
+int wxFont::GetPointSize() const
 {
-  return M_FONTDATA->m_pointSize;
+    wxCHECK_MSG( Ok(), 0, "invalid font" );
+
+    return M_FONTDATA->m_pointSize;
 }
 
-wxString wxFont::GetFaceString(void) const
+wxString wxFont::GetFaceString() const
 {
-  wxString s = wxTheFontNameDirectory->GetFontName( M_FONTDATA->m_fontId );
-  return s;
+    wxCHECK_MSG( Ok(), "", "invalid font" );
+
+    wxString s = wxTheFontNameDirectory->GetFontName( M_FONTDATA->m_fontId );
+    return s;
 }
 
-wxString wxFont::GetFaceName(void) const
+wxString wxFont::GetFaceName() const
 {
-  wxString s = wxTheFontNameDirectory->GetFontName( M_FONTDATA->m_fontId );
-  return s; 
+    wxCHECK_MSG( Ok(), "", "invalid font" );
+
+    wxString s = wxTheFontNameDirectory->GetFontName( M_FONTDATA->m_fontId );
+    return s;
 }
 
-int wxFont::GetFamily(void) const
+int wxFont::GetFamily() const
 {
-  return M_FONTDATA->m_family;
+    wxCHECK_MSG( Ok(), 0, "invalid font" );
+
+    return M_FONTDATA->m_family;
 }
 
-wxString wxFont::GetFamilyString(void) const
+wxString wxFont::GetFamilyString() const
 {
-  wxString s = wx_font_family[M_FONTDATA->m_family - wxDEFAULT];
-  return s;
+    wxCHECK_MSG( Ok(), "wxDEFAULT", "invalid font" );
+
+    switch (M_FONTDATA->m_family)
+    {
+        case wxDECORATIVE:   return wxString("wxDECORATIVE");
+        case wxROMAN:        return wxString("wxROMAN");
+        case wxSCRIPT:       return wxString("wxSCRIPT");
+        case wxSWISS:        return wxString("wxSWISS");
+        case wxMODERN:       return wxString("wxMODERN");
+        case wxTELETYPE:     return wxString("wxTELETYPE");
+        default:             return "wxDEFAULT";
+    }
+
+    return "wxDEFAULT";
 }
 
-int wxFont::GetFontId(void) const
+int wxFont::GetFontId() const
 {
-  return M_FONTDATA->m_fontId; // stub
+    wxCHECK_MSG( Ok(), 0, "invalid font" );
+
+    return M_FONTDATA->m_fontId; // stub
 }
 
-int wxFont::GetStyle(void) const
+int wxFont::GetStyle() const
 {
-  return M_FONTDATA->m_style;
+    wxCHECK_MSG( Ok(), 0, "invalid font" );
+
+    return M_FONTDATA->m_style;
 }
 
-wxString wxFont::GetStyleString(void) const
+wxString wxFont::GetStyleString() const
 {
+    wxCHECK_MSG( Ok(), "wxDEFAULT", "invalid font" );
+
     switch (M_FONTDATA->m_style)
     {
-        case wxNORMAL:
-        {
-            return wxString("wxNORMAL");
-        }
-        case wxSLANT:
-        {
-            return wxString("wxSLANT");
-        }
-        case wxITALIC:
-        {
-            return wxString("wxITALIC");
-        }
-        case wxDEFAULT:
-        default:
-        {
-            return wxString("wxDEFAULT");
-        }
+        case wxNORMAL:   return wxString("wxNORMAL");
+        case wxSLANT:    return wxString("wxSLANT");
+        case wxITALIC:   return wxString("wxITALIC");
+        default:         return wxString("wxDEFAULT");
     }
+
     return wxString("wxDEFAULT");
 }
 
-int wxFont::GetWeight(void) const
+int wxFont::GetWeight() const
 {
-  return M_FONTDATA->m_weight;
+    wxCHECK_MSG( Ok(), 0, "invalid font" );
+
+    return M_FONTDATA->m_weight;
 }
 
-wxString wxFont::GetWeightString(void) const
+wxString wxFont::GetWeightString() const
 {
+    wxCHECK_MSG( Ok(), "wxDEFAULT", "invalid font" );
+
     switch (M_FONTDATA->m_weight)
     {
-        case wxNORMAL:
-        {
-            return wxString("wxNORMAL");
-        }
-        case wxBOLD:
-        {
-            return wxString("wxBOLD");
-        }
-        case wxLIGHT:
-        {
-            return wxString("wxLIGHT");
-        }
-        case wxDEFAULT:
-        default:
-        {
-            return wxString("wxDEFAULT");
-        }
+        case wxNORMAL:   return wxString("wxNORMAL");
+        case wxBOLD:     return wxString("wxBOLD");
+        case wxLIGHT:    return wxString("wxLIGHT");
+        default:         return wxString("wxDEFAULT");
     }
+
     return wxString("wxDEFAULT");
 }
 
-bool wxFont::GetUnderlined(void) const
+bool wxFont::GetUnderlined() const
 {
-  return M_FONTDATA->m_underlined;
+    wxCHECK_MSG( Ok(), FALSE, "invalid font" );
+
+    return M_FONTDATA->m_underlined;
 }
 
 //-----------------------------------------------------------------------------
@@ -298,32 +289,57 @@ bool wxFont::GetUnderlined(void) const
 
 // local help function
 static GdkFont *wxLoadQueryNearestFont(int point_size, int fontid,
-                                          int style, int weight, 
-                                          bool underlined);
+        int style, int weight,
+        bool underlined);
 
 GdkFont *wxFont::GetInternalFont(float scale) const
 {
-  if (M_FONTDATA->m_byXFontName) return M_FONTDATA->m_font;
-   
-  long int_scale = long(scale * 100.0 + 0.5); // key for fontlist
-  int point_scale = (M_FONTDATA->m_pointSize * 10 * int_scale) / 100;
-  GdkFont *font = (GdkFont *) NULL;
-
-  wxNode *node = M_FONTDATA->m_scaled_xfonts.Find(int_scale);
-  if (node) 
-  {
-    font = (GdkFont*)node->Data(); 
-  } 
-  else 
-  {
-     font = wxLoadQueryNearestFont( point_scale, M_FONTDATA->m_fontId, M_FONTDATA->m_style,
-                                   M_FONTDATA->m_weight, M_FONTDATA->m_underlined );
-     M_FONTDATA->m_scaled_xfonts.Append( int_scale, (wxObject*)font );
-  }
-  if (!font)
-       printf("could not load any font");
-//     wxError("could not load any font", "wxFont");
-  return font;
+    if (!Ok())
+    {
+        wxFAIL_MSG( "invalid font" );
+        return (GdkFont*) NULL;
+    }
+
+    if (M_FONTDATA->m_byXFontName) return M_FONTDATA->m_font;
+
+    long int_scale = long(scale * 100.0 + 0.5); // key for fontlist
+    int point_scale = (M_FONTDATA->m_pointSize * 10 * int_scale) / 100;
+    GdkFont *font = (GdkFont *) NULL;
+
+    wxNode *node = M_FONTDATA->m_scaled_xfonts.Find(int_scale);
+    if (node)
+    {
+        font = (GdkFont*)node->Data();
+    }
+    else
+    {
+        /*
+           if (int_scale == 100) printf( "int_scale.\n" );
+           if (M_FONTDATA->m_style == wxSWISS) printf( "swiss.\n" );
+           if (M_FONTDATA->m_pointSize == 12) printf( "12.\n" );
+           if (M_FONTDATA->m_weight == wxNORMAL) printf( "normal.\n" );
+           if (M_FONTDATA->m_underlined == FALSE) printf( "false.\n" );
+         */
+        if ((int_scale == 100) &&
+                (M_FONTDATA->m_family == wxSWISS) &&
+                (M_FONTDATA->m_style == wxNORMAL) &&
+                (M_FONTDATA->m_pointSize == 12) &&
+                (M_FONTDATA->m_weight == wxNORMAL) &&
+                (M_FONTDATA->m_underlined == FALSE))
+        {
+            font = gdk_font_load( "-adobe-helvetica-medium-r-normal--*-120-*-*-*-*-*-*" );
+        }
+        else
+        {
+            font = wxLoadQueryNearestFont( point_scale, M_FONTDATA->m_fontId, M_FONTDATA->m_style,
+                    M_FONTDATA->m_weight, M_FONTDATA->m_underlined );
+        }
+        M_FONTDATA->m_scaled_xfonts.Append( int_scale, (wxObject*)font );
+    }
+    if (!font)
+        printf("could not load any font");
+    //    wxError("could not load any font", "wxFont");
+    return font;
 }
 
 //-----------------------------------------------------------------------------
@@ -331,46 +347,46 @@ GdkFont *wxFont::GetInternalFont(float scale) const
 //-----------------------------------------------------------------------------
 
 static GdkFont *wxLoadQueryFont(int point_size, int fontid, int style,
-                                   int weight, bool WXUNUSED(underlined))
+        int weight, bool WXUNUSED(underlined))
 {
     char buffer[512];
     char *name = wxTheFontNameDirectory->GetScreenName( fontid, weight, style );
 
     if (!name)
-       name = "-*-*-*-*-*-*-*-%d-*-*-*-*-*-*";
+        name = "-*-*-*-*-*-*-*-%d-*-*-*-*-*-*";
     sprintf(buffer, name, point_size);
 
     return gdk_font_load( buffer );
 }
 
 static GdkFont *wxLoadQueryNearestFont(int point_size, int fontid,
-                                          int style, int weight,
-                                          bool underlined)
+        int style, int weight,
+        bool underlined)
 {
     GdkFont *font;
 
     font = wxLoadQueryFont( point_size, fontid, style, weight, underlined );
 
     if (!font) {
-       // search up and down by stepsize 10
-       int max_size = point_size + 20 * (1 + (point_size/180));
-       int min_size = point_size - 20 * (1 + (point_size/180));
-       int i;
-
-       // Search for smaller size (approx.)
-       for (i=point_size-10; !font && i >= 10 && i >= min_size; i -= 10)
-           font = wxLoadQueryFont(i, fontid, style, weight, underlined);
-       // Search for larger size (approx.)
-       for (i=point_size+10; !font && i <= max_size; i += 10)
-           font = wxLoadQueryFont(i, fontid, style, weight, underlined);
-       // Try default family
-       if (!font && fontid != wxDEFAULT)
-           font = wxLoadQueryFont(point_size, wxDEFAULT, style, 
-                                  weight, underlined);
-       // Bogus font
-       if (!font)
-           font = wxLoadQueryFont(120, wxDEFAULT, wxNORMAL, wxNORMAL,
-                                   underlined);
+        // search up and down by stepsize 10
+        int max_size = point_size + 20 * (1 + (point_size/180));
+        int min_size = point_size - 20 * (1 + (point_size/180));
+        int i;
+
+        // Search for smaller size (approx.)
+        for (i=point_size-10; !font && i >= 10 && i >= min_size; i -= 10)
+            font = wxLoadQueryFont(i, fontid, style, weight, underlined);
+        // Search for larger size (approx.)
+        for (i=point_size+10; !font && i <= max_size; i += 10)
+            font = wxLoadQueryFont(i, fontid, style, weight, underlined);
+        // Try default family
+        if (!font && fontid != wxDEFAULT)
+            font = wxLoadQueryFont(point_size, wxDEFAULT, style,
+                    weight, underlined);
+        // Bogus font
+        if (!font)
+            font = wxLoadQueryFont(120, wxDEFAULT, wxNORMAL, wxNORMAL,
+                    underlined);
     }
     return font;
 }
@@ -398,7 +414,7 @@ static char *font_defaults[] = {
     "AfmTimes", "Times",
     "AfmHelvetica", "Helv",
     "AfmCourier", "Cour",
-    
+
     "Afm___", "${AfmTimes,$[weight],$[style]}",
 
     "AfmTimes__", "${AfmTimes}${Afm$[weight]}${Afm$[style]}",
@@ -421,7 +437,7 @@ static char *font_defaults[] = {
     "PostScriptBoldStraight", "-Bold",
     "PostScriptBoldItalic", "-BoldOblique",
     "PostScriptBoldSlant", "-BoldOblique",
-    
+
 #if WX_NORMALIZED_PS_FONTS
     "PostScript___", "${PostScriptTimes,$[weight],$[style]}",
 #else
@@ -464,7 +480,7 @@ static char *font_defaults[] = {
     "ScreenScriptBase", "*-zapfchancery",
 
     "ScreenStdSuffix", "-${Screen$[weight]}-${Screen$[style]}"
-    "-normal-*-*-%d-*-*-*-*-*-*",
+        "-normal-*-*-%d-*-*-*-*-*-*",
 
     "Screen___",
     "-${ScreenDefaultBase}${ScreenStdSuffix}",
@@ -489,20 +505,20 @@ enum {wxSTYLE_NORMAL,  wxSTYLE_ITALIC, wxSTYLE_SLANT,  wxNUM_STYLES};
 static int WCoordinate(int w)
 {
     switch (w) {
-    case wxBOLD:   return wxWEIGHT_BOLD;
-    case wxLIGHT:  return wxWEIGHT_LIGHT;
-    case wxNORMAL:
-    default:       return wxWEIGHT_NORMAL;
+        case wxBOLD:   return wxWEIGHT_BOLD;
+        case wxLIGHT:  return wxWEIGHT_LIGHT;
+        case wxNORMAL:
+        default:       return wxWEIGHT_NORMAL;
     }
 };
 
 static int SCoordinate(int s)
 {
     switch (s) {
-    case wxITALIC: return wxSTYLE_ITALIC;
-    case wxSLANT:  return wxSTYLE_SLANT;
-    case wxNORMAL:
-    default:       return wxSTYLE_NORMAL;
+        case wxITALIC: return wxSTYLE_ITALIC;
+        case wxSLANT:  return wxSTYLE_SLANT;
+        case wxNORMAL:
+        default:       return wxSTYLE_NORMAL;
     }
 };
 
@@ -512,11 +528,11 @@ static int SCoordinate(int s)
 
 class wxSuffixMap {
 public:
-    ~wxSuffixMap(void);
+    ~wxSuffixMap();
 
     inline char *GetName(int weight, int style)
     {
-       return ( map [WCoordinate(weight)] [SCoordinate(style)] );
+        return ( map [WCoordinate(weight)] [SCoordinate(style)] );
     }
 
     char *map[wxNUM_WEIGHTS][wxNUM_STYLES];
@@ -533,45 +549,45 @@ static void SearchResource(const char *prefix, const char **names, int count, ch
     char resource[1024], **defaults, *internal;
 
     k = 1 << count;
-    
+
     *v = (char *) NULL;
     internal = (char *) NULL;
 
     for (i = 0; i < k; i++) {
-       strcpy(resource, prefix);
-       for (j = 0; j < count; j++) {
-           if (!(i & (1 << j)))
-               strcat(resource, names[j]);
-           else
-               strcat(resource, "_");
-       }
-       if (wxGetResource(wxAPP_CLASS, (char *)resource, v))
-           return;
-       if (!internal) {
-           defaults = font_defaults;
-           while (*defaults) {
-               if (!strcmp(*defaults, resource)) {
-                   internal = defaults[1];
-                   break;
-               }
-               defaults += 2;
-           }
-       }
+        strcpy(resource, prefix);
+        for (j = 0; j < count; j++) {
+            if (!(i & (1 << j)))
+                strcat(resource, names[j]);
+            else
+                strcat(resource, "_");
+        }
+        if (wxGetResource(wxAPP_CLASS, (char *)resource, v))
+            return;
+        if (!internal) {
+            defaults = font_defaults;
+            while (*defaults) {
+                if (!strcmp(*defaults, resource)) {
+                    internal = defaults[1];
+                    break;
+                }
+                defaults += 2;
+            }
+        }
     }
     if (internal)
-       *v = copystring(internal);
+        *v = copystring(internal);
 }
 
-wxSuffixMap::~wxSuffixMap(void)
+wxSuffixMap::~wxSuffixMap()
 {
     int k, j;
 
     for (k = 0; k < wxNUM_WEIGHTS; ++k)
-       for (j = 0; j < wxNUM_STYLES; ++j)
-           if (map[k][j]) {
-               delete[] map[k][j];
-               map[k][j] = (char *) NULL;
-           }
+        for (j = 0; j < wxNUM_STYLES; ++j)
+            if (map[k][j]) {
+                delete[] map[k][j];
+                map[k][j] = (char *) NULL;
+            }
 }
 
 void wxSuffixMap::Initialize(const char *resname, const char *devresname)
@@ -582,100 +598,100 @@ void wxSuffixMap::Initialize(const char *resname, const char *devresname)
     const char *names[3];
 
     for (k = 0; k < wxNUM_WEIGHTS; k++) {
-       switch (k) {
-       case wxWEIGHT_NORMAL: weight = "Medium"; break;
-       case wxWEIGHT_LIGHT:  weight = "Light"; break;
-       case wxWEIGHT_BOLD:
-       default:              weight = "Bold";
-       }
-       for (j = 0; j < wxNUM_STYLES; j++) {
-           switch (j) {
-           case wxSTYLE_NORMAL: style = "Straight"; break;
-           case wxSTYLE_ITALIC: style = "Italic"; break;
-           case wxSTYLE_SLANT:
-           default:             style = "Slant";
-           }
-           names[0] = resname;
-           names[1] = weight;
-           names[2] = style;
-
-           SearchResource(devresname, names, 3, &v);
-
-           /* Expand macros in the found string: */
-       found:
-           int len, closer = 0, startpos = 0;
-           
-           len = (v ? strlen(v) : 0);
-           for (i = 0; i < len; i++) {
-               if (v[i] == '$' && ((v[i+1] == '[') || (v[i+1] == '{'))) {
-                   startpos = i;
-                   closer   = (v[i+1] == '[') ? ']' : '}';
-                   ++i;
-               } else if (v[i] == closer) {
-                   int newstrlen;
-                   const char *r = (char *) NULL; bool delete_r = FALSE;
-                   char *name;
-         
-                   name = v + startpos + 2;
-                   v[i] = 0;
-
-                   if (closer == '}') {
-                       int i, count, len;
-                       char **names;
-
-                       for (i = 0, count = 1; name[i]; i++)
-                           if (name[i] == ',')
-                               count++;
-           
-                       len = i;
-
-                       names = new char*[count];
-                       names[0] = name;
-                       for (i = 0, count = 1; i < len; i++)
-                           if (name[i] == ',') {
-                               names[count++] = name + i + 1;
-                               name[i] = 0;
-                           }
-
-                       SearchResource("", (const char **)names, count, (char **)&r);
-                       delete_r = (r != 0);
-                       delete[] names;
-                       
-                       if (!r) {
-                           for (i = 0; i < len; i++)
-                               if (!name[i])
-                                   name[i] = ',';
-                           r = "";
-                           printf("Bad resource name \"%s\" in font lookup\n", name);
-                       }
-                   } else if (!strcmp(name, "weight")) {
-                       r = weight;
-                   } else if (!strcmp(name, "style")) {
-                       r = style;
-                   } else if (!strcmp(name, "family")) {
-                       r = resname;
-                   } else {
-                       r = "";
-                       printf("Bad font macro name \"%s\"\n", name);
-                   }
-
-                   // add r to v
-                   newstrlen = strlen(r);
-                   char *naya = new char[startpos + newstrlen + len - i];
-                   memcpy(naya, v, startpos);
-                   memcpy(naya + startpos, r, newstrlen);
-                   memcpy(naya + startpos + newstrlen, v + i + 1, len - i);
-                   if (delete_r)
-                     delete[] (char*)r;
-                   delete[] v;
-                   v = naya;
-                   
-                   goto found;
-               }
-           }
-           /* We have a final value: */
-           map[k][j] = v;
-       }
+        switch (k) {
+            case wxWEIGHT_NORMAL: weight = "Medium"; break;
+            case wxWEIGHT_LIGHT:  weight = "Light"; break;
+            case wxWEIGHT_BOLD:
+            default:          weight = "Bold";
+        }
+        for (j = 0; j < wxNUM_STYLES; j++) {
+            switch (j) {
+                case wxSTYLE_NORMAL: style = "Straight"; break;
+                case wxSTYLE_ITALIC: style = "Italic"; break;
+                case wxSTYLE_SLANT:
+                default:         style = "Slant";
+            }
+            names[0] = resname;
+            names[1] = weight;
+            names[2] = style;
+
+            SearchResource(devresname, names, 3, &v);
+
+            /* Expand macros in the found string: */
+found:
+            int len, closer = 0, startpos = 0;
+
+            len = (v ? strlen(v) : 0);
+            for (i = 0; i < len; i++) {
+                if (v[i] == '$' && ((v[i+1] == '[') || (v[i+1] == '{'))) {
+                    startpos = i;
+                    closer   = (v[i+1] == '[') ? ']' : '}';
+                    ++i;
+                } else if (v[i] == closer) {
+                    int newstrlen;
+                    const char *r = (char *) NULL; bool delete_r = FALSE;
+                    char *name;
+
+                    name = v + startpos + 2;
+                    v[i] = 0;
+
+                    if (closer == '}') {
+                        int i, count, len;
+                        char **names;
+
+                        for (i = 0, count = 1; name[i]; i++)
+                            if (name[i] == ',')
+                                count++;
+
+                        len = i;
+
+                        names = new char*[count];
+                        names[0] = name;
+                        for (i = 0, count = 1; i < len; i++)
+                            if (name[i] == ',') {
+                                names[count++] = name + i + 1;
+                                name[i] = 0;
+                            }
+
+                        SearchResource("", (const char **)names, count, (char **)&r);
+                        delete_r = (r != 0);
+                        delete[] names;
+
+                        if (!r) {
+                            for (i = 0; i < len; i++)
+                                if (!name[i])
+                                    name[i] = ',';
+                            r = "";
+                            printf("Bad resource name \"%s\" in font lookup\n", name);
+                        }
+                    } else if (!strcmp(name, "weight")) {
+                        r = weight;
+                    } else if (!strcmp(name, "style")) {
+                        r = style;
+                    } else if (!strcmp(name, "family")) {
+                        r = resname;
+                    } else {
+                        r = "";
+                        printf("Bad font macro name \"%s\"\n", name);
+                    }
+
+                    // add r to v
+                    newstrlen = strlen(r);
+                    char *naya = new char[startpos + newstrlen + len - i];
+                    memcpy(naya, v, startpos);
+                    memcpy(naya + startpos, r, newstrlen);
+                    memcpy(naya + startpos + newstrlen, v + i + 1, len - i);
+                    if (delete_r)
+                        delete[] (char*)r;
+                    delete[] v;
+                    v = naya;
+
+                    goto found;
+                }
+            }
+            /* We have a final value: */
+            map[k][j] = v;
+        }
     }
 }
 
@@ -684,27 +700,27 @@ void wxSuffixMap::Initialize(const char *resname, const char *devresname)
 //-----------------------------------------------------------------------------
 
 class wxFontNameItem : public wxObject {
-DECLARE_DYNAMIC_CLASS(wxFontNameItem)
+    DECLARE_DYNAMIC_CLASS(wxFontNameItem)
 public:
-    wxFontNameItem(const char *name, int id, int family);
-    ~wxFontNameItem();
-
-    inline char* GetScreenName(int w, int s)     {return screen.GetName(w, s);}
-    inline char* GetPostScriptName(int w, int s) {return printing.GetName(w, s);}
-    inline char* GetAFMName(int w, int s)        {return afm.GetName(w, s);}
-    inline char* GetName(void)                   {return name;}
-    inline int   GetFamily(void)                 {return family;}
-    inline int   GetId(void)                     {return id;}
-    inline bool  IsRoman(void)                   {return isroman;}
-#if WXDEBUG
-    void Dump(ostream& str);
+        wxFontNameItem(const char *name, int id, int family);
+        ~wxFontNameItem();
+
+        inline char* GetScreenName(int w, int s)     {return screen.GetName(w, s);}
+        inline char* GetPostScriptName(int w, int s) {return printing.GetName(w, s);}
+        inline char* GetAFMName(int w, int s)        {return afm.GetName(w, s);}
+        inline char* GetName()                   {return name;}
+        inline int   GetFamily()                 {return family;}
+        inline int   GetId()                     {return id;}
+        inline bool  IsRoman()                   {return isroman;}
+#if defined(__WXDEBUG__)
+        void Dump(ostream& str);
 #endif
 
-    int id;
-    int family;
-    char *name;
-    wxSuffixMap screen, printing, afm;
-    bool isroman;
+        int id;
+        int family;
+        char *name;
+        wxSuffixMap screen, printing, afm;
+        bool isroman;
 };
 
 IMPLEMENT_ABSTRACT_CLASS(wxFontNameItem, wxObject)
@@ -720,14 +736,14 @@ wxFontNameItem::wxFontNameItem(const char *Name, int Id, int Family)
     afm.     Initialize(name, "Afm");
 }
 
-wxFontNameItem::~wxFontNameItem(void)
+wxFontNameItem::~wxFontNameItem()
 {
     if (name)
-       delete[] name;
+        delete[] name;
     name = (char *) NULL;
 }
 
-#if WXDEBUG
+#if defined(__WXDEBUG__)
 void wxFontNameItem::Dump(ostream& str)
 {
     str << "wxFontNameItem(" << name << ")";
@@ -740,7 +756,7 @@ void wxFontNameItem::Dump(ostream& str)
 
 IMPLEMENT_DYNAMIC_CLASS(wxFontNameDirectory, wxObject)
 
-wxFontNameDirectory::wxFontNameDirectory(void)
+wxFontNameDirectory::wxFontNameDirectory()
 {
     table = new wxHashTable(wxKEY_INTEGER, 20);
     nextFontId = -1;
@@ -752,14 +768,14 @@ wxFontNameDirectory::~wxFontNameDirectory()
     table->BeginFind();
     wxNode *node = table->Next();
     while (node) {
-       wxFontNameItem *item = (wxFontNameItem*)node->Data();
-       delete item;
-       node = table->Next();
+        wxFontNameItem *item = (wxFontNameItem*)node->Data();
+        delete item;
+        node = table->Next();
     }
     delete table;
 }
 
-int wxFontNameDirectory::GetNewFontId(void)
+int wxFontNameDirectory::GetNewFontId()
 {
     return (nextFontId--);
 }
@@ -778,18 +794,18 @@ void wxFontNameDirectory::Initialize()
 void wxFontNameDirectory::Initialize(int fontid, int family, const char *resname)
 {
     char *fam, resource[256];
-  
+
     sprintf(resource, "Family%s", resname);
     SearchResource((const char *)resource, (const char **) NULL, 0, (char **)&fam);
     if (fam) {
-       if      (!strcmp(fam, "Default"))       family = wxDEFAULT;
-       else if (!strcmp(fam, "Roman"))         family = wxROMAN;
-       else if (!strcmp(fam, "Decorative"))    family = wxDECORATIVE;
-       else if (!strcmp(fam, "Modern"))        family = wxMODERN;
-       else if (!strcmp(fam, "Teletype"))      family = wxTELETYPE;
-       else if (!strcmp(fam, "Swiss"))         family = wxSWISS;
-       else if (!strcmp(fam, "Script"))        family = wxSCRIPT;
-       delete[] fam; // free resource
+        if      (!strcmp(fam, "Default"))    family = wxDEFAULT;
+        else if (!strcmp(fam, "Roman"))        family = wxROMAN;
+        else if (!strcmp(fam, "Decorative"))    family = wxDECORATIVE;
+        else if (!strcmp(fam, "Modern"))    family = wxMODERN;
+        else if (!strcmp(fam, "Teletype"))    family = wxTELETYPE;
+        else if (!strcmp(fam, "Swiss"))        family = wxSWISS;
+        else if (!strcmp(fam, "Script"))    family = wxSCRIPT;
+        delete[] fam; // free resource
     }
     table->Put(fontid, new wxFontNameItem(resname, fontid, family));
 }
@@ -809,7 +825,7 @@ char *wxFontNameDirectory::GetScreenName(int fontid, int weight, int style)
 {
     wxFontNameItem *item = (wxFontNameItem*)table->Get(fontid); // find font
     if (item)
-       return item->GetScreenName(weight, style);
+        return item->GetScreenName(weight, style);
     // font does not exist
     return (char *) NULL;
 }
@@ -818,7 +834,7 @@ char *wxFontNameDirectory::GetPostScriptName(int fontid, int weight, int style)
 {
     wxFontNameItem *item = (wxFontNameItem*)table->Get(fontid); // find font
     if (item)
-       return item->GetPostScriptName(weight, style);
+        return item->GetPostScriptName(weight, style);
     // font does not exist
     return (char *) NULL;
 }
@@ -827,7 +843,7 @@ char *wxFontNameDirectory::GetAFMName(int fontid, int weight, int style)
 {
     wxFontNameItem *item = (wxFontNameItem *)table->Get(fontid); // find font
     if (item)
-       return item->GetAFMName(weight, style);
+        return item->GetAFMName(weight, style);
     // font does not exist
     return (char *) NULL;
 }
@@ -836,7 +852,7 @@ char *wxFontNameDirectory::GetFontName(int fontid)
 {
     wxFontNameItem *item = (wxFontNameItem *)table->Get(fontid); // find font
     if (item)
-       return item->GetName();
+        return item->GetName();
     // font does not exist
     return (char *) NULL;
 }
@@ -848,9 +864,9 @@ int wxFontNameDirectory::GetFontId(const char *name)
     table->BeginFind();
 
     while ( (node = table->Next()) ) {
-       wxFontNameItem *item = (wxFontNameItem*)node->Data();
-       if (!strcmp(name, item->name))
-           return item->id;
+        wxFontNameItem *item = (wxFontNameItem*)node->Data();
+        if (!strcmp(name, item->name))
+            return item->id;
     }
     // font does not exist
     return 0;
@@ -859,9 +875,9 @@ int wxFontNameDirectory::GetFontId(const char *name)
 int wxFontNameDirectory::GetFamily(int fontid)
 {
     wxFontNameItem *item = (wxFontNameItem *)table->Get(fontid);
-  
+
     if (item)
-       return item->family;
+        return item->family;
     // font does not exist
     return wxDEFAULT;
 }