X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ee453a161fcbcbf74c8359d42ca1aaeb2777c9bb..c8b204e6fd541515bead44e1be86ab8cb44a35d3:/src/os2/settings.cpp diff --git a/src/os2/settings.cpp b/src/os2/settings.cpp index c47c24d5c4..6745891e57 100644 --- a/src/os2/settings.cpp +++ b/src/os2/settings.cpp @@ -18,12 +18,60 @@ #include "wx/pen.h" #include "wx/brush.h" #include "wx/gdicmn.h" +#include "wx/module.h" #endif #include "wx/settings.h" #include "wx/window.h" #include "wx/os2/private.h" +// the module which is used to clean up wxSystemSettings data (this is a +// singleton class so it can't be done in the dtor) +class wxSystemSettingsModule : public wxModule +{ + friend class wxSystemSettings; +public: + virtual bool OnInit(); + virtual void OnExit(); + +private: + DECLARE_DYNAMIC_CLASS(wxSystemSettingsModule) + + static wxArrayString sm_optionNames; + static wxArrayString sm_optionValues; +}; + +// ---------------------------------------------------------------------------- +// global data +// ---------------------------------------------------------------------------- + +static wxFont *gs_fontDefault = NULL; + +// ============================================================================ +// implementation +// ============================================================================ + +// ---------------------------------------------------------------------------- +// wxSystemSettingsModule +// ---------------------------------------------------------------------------- + +IMPLEMENT_DYNAMIC_CLASS(wxSystemSettingsModule, wxModule) + +wxArrayString wxSystemSettingsModule::sm_optionNames; +wxArrayString wxSystemSettingsModule::sm_optionValues; + +bool wxSystemSettingsModule::OnInit() +{ + return TRUE; +} + +void wxSystemSettingsModule::OnExit() +{ + sm_optionNames.Clear(); + sm_optionValues.Clear(); + delete gs_fontDefault; +} + wxColour wxSystemSettings::GetSystemColour( int nIndex ) @@ -44,7 +92,6 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; case wxSYS_COLOUR_WINDOWFRAME: @@ -56,7 +103,6 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; case wxSYS_COLOUR_MENUTEXT: @@ -79,7 +125,6 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; case wxSYS_COLOUR_BTNSHADOW: @@ -91,7 +136,6 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; case wxSYS_COLOUR_BTNHIGHLIGHT: @@ -103,7 +147,6 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; // @@ -118,7 +161,7 @@ wxColour wxSystemSettings::GetSystemColour( case wxSYS_COLOUR_INACTIVECAPTIONTEXT: case wxSYS_COLOUR_BTNTEXT: case wxSYS_COLOUR_INFOTEXT: - return(*wxBLACK); + vCol = (*wxBLACK); break; // @@ -128,7 +171,7 @@ wxColour wxSystemSettings::GetSystemColour( case wxSYS_COLOUR_ACTIVECAPTION: case wxSYS_COLOUR_ACTIVEBORDER: case wxSYS_COLOUR_HIGHLIGHT: - return(*wxBLUE); + vCol = (*wxBLUE); break; case wxSYS_COLOUR_SCROLLBAR: @@ -142,7 +185,7 @@ wxColour wxSystemSettings::GetSystemColour( case wxSYS_COLOUR_3DDKSHADOW: case wxSYS_COLOUR_3DLIGHT: case wxSYS_COLOUR_INFOBK: - return(*wxLIGHT_GREY); + vCol = (*wxLIGHT_GREY); break; default: @@ -154,7 +197,6 @@ wxColour wxSystemSettings::GetSystemColour( ,GetGValue(vRef) ,GetBValue(vRef) ); - return vCol; break; } return(vCol); @@ -187,8 +229,10 @@ wxFont wxSystemSettings::GetSystemFont(int index) break; } } + if(wxSWISS_FONT) + return *wxSWISS_FONT; - return *wxSWISS_FONT; + return wxNullFont; } // Get a system metric, e.g. scrollbar size @@ -313,3 +357,15 @@ int wxSystemSettings::GetSystemMetric(int index) return 0; } +bool wxSystemSettings::GetCapability(int index) +{ + switch (index) + { + case wxSYS_CAN_ICONIZE_FRAME: + case wxSYS_CAN_DRAW_FRAME_DECORATIONS: + return TRUE; break; + default: + return FALSE; + } + return FALSE; +}