Somehow MSVC 9 compiled invalid wxT(__FUNCTION__) expressions but both MinGW
and MSVC 6 (correctly) failed. Don't use this construct at all but instead
call wxLogLastError() with the real function name.
Also refactor the code slightly to avoid having to repeat this fix thrice.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@65557
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
dm.dmDisplayFrequency > 1 ? dm.dmDisplayFrequency : 0);
}
dm.dmDisplayFrequency > 1 ? dm.dmDisplayFrequency : 0);
}
+ // Call GetMonitorInfo() and fill in the provided struct and return true if
+ // it succeeded, otherwise return false.
+ bool GetMonInfo(MONITORINFOEX& monInfo) const;
+
HMONITOR m_hmon;
private:
HMONITOR m_hmon;
private:
// wxDisplayMSW implementation
// ----------------------------------------------------------------------------
// wxDisplayMSW implementation
// ----------------------------------------------------------------------------
-wxRect wxDisplayMSW::GetGeometry() const
+bool wxDisplayMSW::GetMonInfo(MONITORINFOEX& monInfo) const
- WinStruct<MONITORINFOEX> monInfo;
-
- if ( !gs_GetMonitorInfo(m_hmon, (LPMONITORINFO)&monInfo) )
+ if ( !gs_GetMonitorInfo(m_hmon, &monInfo) )
- wxLogLastError(wxT(__FUNCTION__));
- return wxRect();
+ wxLogLastError(wxT("GetMonitorInfo"));
+ return false;
+ return true;
+}
+
+wxRect wxDisplayMSW::GetGeometry() const
+{
+ WinStruct<MONITORINFOEX> monInfo;
+
- wxCopyRECTToRect(monInfo.rcMonitor, rect);
+ if ( GetMonInfo(monInfo) )
+ wxCopyRECTToRect(monInfo.rcMonitor, rect);
{
WinStruct<MONITORINFOEX> monInfo;
{
WinStruct<MONITORINFOEX> monInfo;
- if ( !gs_GetMonitorInfo(m_hmon, (LPMONITORINFO)&monInfo) )
- {
- wxLogLastError(wxT(__FUNCTION__));
- return wxRect();
- }
-
- wxCopyRECTToRect(monInfo.rcWork, rectClient);
+ if ( GetMonInfo(monInfo) )
+ wxCopyRECTToRect(monInfo.rcWork, rectClient);
{
WinStruct<MONITORINFOEX> monInfo;
{
WinStruct<MONITORINFOEX> monInfo;
- if ( !gs_GetMonitorInfo(m_hmon, (LPMONITORINFO)&monInfo) )
- {
- wxLogLastError(wxT(__FUNCTION__));
- return "";
- }
+ wxString name;
+ if ( GetMonInfo(monInfo) )
+ name = monInfo.szDevice;
- return monInfo.szDevice;
}
bool wxDisplayMSW::IsPrimary() const
{
WinStruct<MONITORINFOEX> monInfo;
}
bool wxDisplayMSW::IsPrimary() const
{
WinStruct<MONITORINFOEX> monInfo;
- if ( !gs_GetMonitorInfo(m_hmon, (LPMONITORINFO)&monInfo) )
- {
- wxLogLastError(wxT(__FUNCTION__));
+ if ( !GetMonInfo(monInfo) )
return (monInfo.dwFlags & MONITORINFOF_PRIMARY) != 0;
}
return (monInfo.dwFlags & MONITORINFOF_PRIMARY) != 0;
}