projects
/
wxWidgets.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Don't define wxArrayPGProperty as std::vector in STL build.
[wxWidgets.git]
/
src
/
msw
/
settings.cpp
diff --git
a/src/msw/settings.cpp
b/src/msw/settings.cpp
index 76d77a96bfceb083f2d395fa53bd494136ecbdb9..0092138732932c88189ee20c2552e271c8ff2897 100644
(file)
--- a/
src/msw/settings.cpp
+++ b/
src/msw/settings.cpp
@@
-1,5
+1,5
@@
/////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////
-// Name: msw/settings.cpp
+// Name:
src/
msw/settings.cpp
// Purpose: wxSystemSettingsNative implementation for MSW
// Author: Julian Smart
// Modified by:
// Purpose: wxSystemSettingsNative implementation for MSW
// Author: Julian Smart
// Modified by:
@@
-24,25
+24,23
@@
#pragma hdrstop
#endif
#pragma hdrstop
#endif
+#include "wx/settings.h"
+
#ifndef WX_PRECOMP
#include "wx/utils.h"
#include "wx/gdicmn.h"
#ifndef WX_PRECOMP
#include "wx/utils.h"
#include "wx/gdicmn.h"
+ #include "wx/module.h"
#endif
#endif
-#include "wx/settings.h"
-
#include "wx/msw/private.h"
#include "wx/msw/private.h"
+#include "wx/msw/missing.h" // for SM_CXCURSOR, SM_CYCURSOR, SM_TABLETPC
#ifndef SPI_GETFLATMENU
#define SPI_GETFLATMENU 0x1022
#endif
#ifndef SPI_GETFLATMENU
#define SPI_GETFLATMENU 0x1022
#endif
-#include "wx/module.h"
#include "wx/fontutil.h"
#include "wx/fontutil.h"
-
-#ifdef __WXWINCE__ // for SM_CXCURSOR and SM_CYCURSOR
-#include "wx/msw/wince/missing.h"
-#endif // __WXWINCE__
+#include "wx/fontenum.h"
// ----------------------------------------------------------------------------
// private classes
// ----------------------------------------------------------------------------
// private classes
@@
-130,7
+128,12
@@
wxColour wxSystemSettingsNative::GetColour(wxSystemColour index)
0, // MENUBAR (unused)
};
0, // MENUBAR (unused)
};
- if ( index == wxSYS_COLOUR_LISTBOX )
+ if ( index == wxSYS_COLOUR_LISTBOXTEXT)
+ {
+ // there is no standard colour with this index, map to another one
+ index = wxSYS_COLOUR_WINDOWTEXT;
+ }
+ else if ( index == wxSYS_COLOUR_LISTBOX )
{
// there is no standard colour with this index, map to another one
index = wxSYS_COLOUR_WINDOW;
{
// there is no standard colour with this index, map to another one
index = wxSYS_COLOUR_WINDOW;
@@
-189,7
+192,7
@@
wxColour wxSystemSettingsNative::GetColour(wxSystemColour index)
unsigned int n = index - wxSYS_COLOUR_BTNHIGHLIGHT;
wxASSERT_MSG( n < WXSIZEOF(s_defaultSysColors),
unsigned int n = index - wxSYS_COLOUR_BTNHIGHLIGHT;
wxASSERT_MSG( n < WXSIZEOF(s_defaultSysColors),
-
_
T("forgot tp update the default colours array") );
+
wx
T("forgot tp update the default colours array") );
colSys = s_defaultSysColors[n];
hasCol = true;
colSys = s_defaultSysColors[n];
hasCol = true;
@@
-205,8
+208,10
@@
wxColour wxSystemSettingsNative::GetColour(wxSystemColour index)
colSys = ::GetSysColor(index);
#endif
}
colSys = ::GetSysColor(index);
#endif
}
-
- return wxRGBToColour(colSys);
+
+ wxColour ret = wxRGBToColour(colSys);
+ wxASSERT(ret.IsOk());
+ return ret;
}
// ----------------------------------------------------------------------------
}
// ----------------------------------------------------------------------------
@@
-229,7
+234,7
@@
wxFont wxCreateFontFromStockObject(int index)
// We want Windows 2000 or later to have new fonts even MS Shell Dlg
// is returned as default GUI font for compatibility
int verMaj;
// We want Windows 2000 or later to have new fonts even MS Shell Dlg
// is returned as default GUI font for compatibility
int verMaj;
- if(index == DEFAULT_GUI_FONT && wxGetOsVersion(&verMaj) == wxWINDOWS_NT && verMaj >= 5)
+ if(index == DEFAULT_GUI_FONT && wxGetOsVersion(&verMaj) == wx
OS_
WINDOWS_NT && verMaj >= 5)
wxStrcpy(info.lf.lfFaceName, wxT("MS Shell Dlg 2"));
#endif
// Under MicroWindows we pass the HFONT as well
wxStrcpy(info.lf.lfFaceName, wxT("MS Shell Dlg 2"));
#endif
// Under MicroWindows we pass the HFONT as well
@@
-243,12
+248,12
@@
wxFont wxCreateFontFromStockObject(int index)
}
else
{
}
else
{
- wxFAIL_MSG(
_
T("failed to get LOGFONT") );
+ wxFAIL_MSG(
wx
T("failed to get LOGFONT") );
}
}
else // GetStockObject() failed
{
}
}
else // GetStockObject() failed
{
- wxFAIL_MSG(
_
T("stock font not found") );
+ wxFAIL_MSG(
wx
T("stock font not found") );
}
return font;
}
return font;
@@
-265,6
+270,8
@@
wxFont wxSystemSettingsNative::GetFont(wxSystemFont index)
gs_fontDefault = new wxFont(wxCreateFontFromStockObject(SYSTEM_FONT));
}
gs_fontDefault = new wxFont(wxCreateFontFromStockObject(SYSTEM_FONT));
}
+ wxASSERT(gs_fontDefault->IsOk() &&
+ wxFontEnumerator::IsValidFacename(gs_fontDefault->GetFaceName()));
return *gs_fontDefault;
#else // !__WXWINCE__
// wxWindow ctor calls GetFont(wxSYS_DEFAULT_GUI_FONT) so we're
return *gs_fontDefault;
#else // !__WXWINCE__
// wxWindow ctor calls GetFont(wxSYS_DEFAULT_GUI_FONT) so we're
@@
-284,6
+291,12
@@
wxFont wxSystemSettingsNative::GetFont(wxSystemFont index)
gs_fontDefault = new wxFont(font);
}
gs_fontDefault = new wxFont(font);
}
+ wxASSERT(font.IsOk());
+
+#if wxUSE_FONTENUM
+ wxASSERT(wxFontEnumerator::IsValidFacename(font.GetFaceName()));
+#endif // wxUSE_FONTENUM
+
return font;
#endif // __WXWINCE__/!__WXWINCE__
}
return font;
#endif // __WXWINCE__/!__WXWINCE__
}
@@
-310,8
+323,12
@@
static const int gs_metricsMap[] =
SM_CXBORDER,
SM_CYBORDER,
SM_CXBORDER,
SM_CYBORDER,
+#ifdef SM_CXCURSOR
SM_CXCURSOR,
SM_CYCURSOR,
SM_CXCURSOR,
SM_CYCURSOR,
+#else
+ -1, -1,
+#endif
SM_CXDOUBLECLK,
SM_CYDOUBLECLK,
#if defined(__WIN32__) && defined(SM_CXDRAG)
SM_CXDOUBLECLK,
SM_CYDOUBLECLK,
#if defined(__WIN32__) && defined(SM_CXDRAG)
@@
-351,7
+368,7
@@
static const int gs_metricsMap[] =
-1, -1, -1, -1,
#endif
SM_CYHSCROLL,
-1, -1, -1, -1,
#endif
SM_CYHSCROLL,
- SM_CX
V
SCROLL,
+ SM_CX
H
SCROLL,
SM_CXVSCROLL,
SM_CYVSCROLL,
#ifdef SM_CYVTHUMB
SM_CXVSCROLL,
SM_CYVSCROLL,
#ifdef SM_CYVTHUMB
@@
-376,11
+393,14
@@
static const int gs_metricsMap[] =
#else
-1,
#endif
#else
-1,
#endif
+ // SM_SWAPBUTTON is not available under CE and it doesn't make sense to ask
+ // for it there
#ifdef SM_SWAPBUTTON
SM_SWAPBUTTON,
#else
#ifdef SM_SWAPBUTTON
SM_SWAPBUTTON,
#else
- -1
+ -1
,
#endif
#endif
+ -1 // wxSYS_DCLICK_MSEC - not available as system metric
};
// Get a system metric, e.g. scrollbar size
};
// Get a system metric, e.g. scrollbar size
@@
-391,7
+411,13
@@
int wxSystemSettingsNative::GetMetric(wxSystemMetric index, wxWindow* WXUNUSED(w
return 0;
#else // !__WXMICROWIN__
wxCHECK_MSG( index > 0 && (size_t)index < WXSIZEOF(gs_metricsMap), 0,
return 0;
#else // !__WXMICROWIN__
wxCHECK_MSG( index > 0 && (size_t)index < WXSIZEOF(gs_metricsMap), 0,
- _T("invalid metric") );
+ wxT("invalid metric") );
+
+ if ( index == wxSYS_DCLICK_MSEC )
+ {
+ // This one is not a Win32 system metric
+ return ::GetDoubleClickTime();
+ }
int indexMSW = gs_metricsMap[index];
if ( indexMSW == -1 )
int indexMSW = gs_metricsMap[index];
if ( indexMSW == -1 )
@@
-419,8
+445,11
@@
bool wxSystemSettingsNative::HasFeature(wxSystemFeature index)
case wxSYS_CAN_DRAW_FRAME_DECORATIONS:
return true;
case wxSYS_CAN_DRAW_FRAME_DECORATIONS:
return true;
+ case wxSYS_TABLET_PRESENT:
+ return ::GetSystemMetrics(SM_TABLETPC) != 0;
+
default:
default:
- wxFAIL_MSG(
_
T("unknown system feature") );
+ wxFAIL_MSG(
wx
T("unknown system feature") );
return false;
}
return false;
}
@@
-443,12
+472,12
@@
extern wxFont wxGetCCDefaultFont()
int verMaj, verMin;
switch ( wxGetOsVersion(&verMaj, &verMin) )
{
int verMaj, verMin;
switch ( wxGetOsVersion(&verMaj, &verMin) )
{
- case wx
WIN95
:
+ case wx
OS_WINDOWS_9X
:
// 4.10 is Win98
useIconFont = verMaj == 4 && verMin >= 10;
break;
// 4.10 is Win98
useIconFont = verMaj == 4 && verMin >= 10;
break;
- case wxWINDOWS_NT:
+ case wx
OS_
WINDOWS_NT:
// 5.0 is Win2k
useIconFont = verMaj >= 5;
break;
// 5.0 is Win2k
useIconFont = verMaj >= 5;
break;
@@
-472,7
+501,7
@@
extern wxFont wxGetCCDefaultFont()
}
else
{
}
else
{
- wxLogLastError(
_
T("SystemParametersInfo(SPI_GETICONTITLELOGFONT"));
+ wxLogLastError(
wx
T("SystemParametersInfo(SPI_GETICONTITLELOGFONT"));
}
}
#endif // __WXWINCE__
}
}
#endif // __WXWINCE__