Applied patch [ 619705 ] Fixes wxApp::GetComCtl32Version
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@20814 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -1185,6 +1185,17 @@ void wxApp::OnQueryEndSession(wxCloseEvent& event)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
typedef struct _WXADllVersionInfo
|
||||||
|
{
|
||||||
|
DWORD cbSize;
|
||||||
|
DWORD dwMajorVersion; // Major version
|
||||||
|
DWORD dwMinorVersion; // Minor version
|
||||||
|
DWORD dwBuildNumber; // Build number
|
||||||
|
DWORD dwPlatformID; // DLLVER_PLATFORM_*
|
||||||
|
} WXADLLVERSIONINFO;
|
||||||
|
|
||||||
|
typedef HRESULT (CALLBACK* WXADLLGETVERSIONPROC)(WXADLLVERSIONINFO *);
|
||||||
|
|
||||||
/* static */
|
/* static */
|
||||||
int wxApp::GetComCtl32Version()
|
int wxApp::GetComCtl32Version()
|
||||||
{
|
{
|
||||||
@@ -1204,17 +1215,25 @@ int wxApp::GetComCtl32Version()
|
|||||||
|
|
||||||
// do we have it?
|
// do we have it?
|
||||||
HMODULE hModuleComCtl32 = ::GetModuleHandle(wxT("COMCTL32"));
|
HMODULE hModuleComCtl32 = ::GetModuleHandle(wxT("COMCTL32"));
|
||||||
|
BOOL bFreeComCtl32 = FALSE ;
|
||||||
|
if(!hModuleComCtl32)
|
||||||
|
{
|
||||||
|
hModuleComCtl32 = ::LoadLibrary(wxT("COMCTL32.DLL")) ;
|
||||||
|
if(hModuleComCtl32)
|
||||||
|
{
|
||||||
|
bFreeComCtl32 = TRUE ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// if so, then we can check for the version
|
// if so, then we can check for the version
|
||||||
if ( hModuleComCtl32 )
|
if ( hModuleComCtl32 )
|
||||||
{
|
{
|
||||||
// try to use DllGetVersion() if available in _headers_
|
// try to use DllGetVersion() if available in _headers_
|
||||||
#ifdef DLLVER_PLATFORM_WINDOWS // defined in shlwapi.h
|
WXADLLGETVERSIONPROC pfnDllGetVersion = (WXADLLGETVERSIONPROC)
|
||||||
DLLGETVERSIONPROC pfnDllGetVersion = (DLLGETVERSIONPROC)
|
|
||||||
::GetProcAddress(hModuleComCtl32, "DllGetVersion");
|
::GetProcAddress(hModuleComCtl32, "DllGetVersion");
|
||||||
if ( pfnDllGetVersion )
|
if ( pfnDllGetVersion )
|
||||||
{
|
{
|
||||||
DLLVERSIONINFO dvi;
|
WXADLLVERSIONINFO dvi;
|
||||||
dvi.cbSize = sizeof(dvi);
|
dvi.cbSize = sizeof(dvi);
|
||||||
|
|
||||||
HRESULT hr = (*pfnDllGetVersion)(&dvi);
|
HRESULT hr = (*pfnDllGetVersion)(&dvi);
|
||||||
@@ -1231,7 +1250,6 @@ int wxApp::GetComCtl32Version()
|
|||||||
dvi.dwMinorVersion;
|
dvi.dwMinorVersion;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
// DllGetVersion() unavailable either during compile or
|
// DllGetVersion() unavailable either during compile or
|
||||||
// run-time, try to guess the version otherwise
|
// run-time, try to guess the version otherwise
|
||||||
if ( !s_verComCtl32 )
|
if ( !s_verComCtl32 )
|
||||||
@@ -1270,6 +1288,11 @@ int wxApp::GetComCtl32Version()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(bFreeComCtl32)
|
||||||
|
{
|
||||||
|
::FreeLibrary(hModuleComCtl32) ;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return s_verComCtl32;
|
return s_verComCtl32;
|
||||||
|
@@ -468,25 +468,6 @@ bool wxNotebook::InsertPage(int nPage,
|
|||||||
// finally do insert it
|
// finally do insert it
|
||||||
if ( TabCtrl_InsertItem(m_hwnd, nPage, &tcItem) == -1 )
|
if ( TabCtrl_InsertItem(m_hwnd, nPage, &tcItem) == -1 )
|
||||||
{
|
{
|
||||||
// Hit test
|
|
||||||
int wxNotebook::HitTest(const wxPoint& pt, long& flags)
|
|
||||||
{
|
|
||||||
TC_HITTESTINFO hitTestInfo;
|
|
||||||
hitTestInfo.pt.x = pt.x;
|
|
||||||
hitTestInfo.pt.y = pt.y;
|
|
||||||
int item = TabCtrl_HitTest( (HWND) GetHWND(), & hitTestInfo ) ;
|
|
||||||
flags = 0;
|
|
||||||
|
|
||||||
if ((hitTestInfo.flags & TCHT_NOWHERE) == TCHT_NOWHERE)
|
|
||||||
flags |= wxNB_HITTEST_NOWHERE;
|
|
||||||
if ((hitTestInfo.flags & TCHT_ONITEMICON) == TCHT_ONITEMICON)
|
|
||||||
flags |= wxNB_HITTEST_ONICON;
|
|
||||||
if ((hitTestInfo.flags & TCHT_ONITEMLABEL) == TCHT_ONITEMLABEL)
|
|
||||||
flags |= wxNB_HITTEST_ONLABEL;
|
|
||||||
|
|
||||||
return item;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxLogError(wxT("Can't create the notebook page '%s'."), strText.c_str());
|
wxLogError(wxT("Can't create the notebook page '%s'."), strText.c_str());
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@@ -538,6 +519,25 @@ int wxNotebook::HitTest(const wxPoint& pt, long& flags)
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Hit test
|
||||||
|
int wxNotebook::HitTest(const wxPoint& pt, long& flags)
|
||||||
|
{
|
||||||
|
TC_HITTESTINFO hitTestInfo;
|
||||||
|
hitTestInfo.pt.x = pt.x;
|
||||||
|
hitTestInfo.pt.y = pt.y;
|
||||||
|
int item = TabCtrl_HitTest( (HWND) GetHWND(), & hitTestInfo ) ;
|
||||||
|
flags = 0;
|
||||||
|
|
||||||
|
if ((hitTestInfo.flags & TCHT_NOWHERE) == TCHT_NOWHERE)
|
||||||
|
flags |= wxNB_HITTEST_NOWHERE;
|
||||||
|
if ((hitTestInfo.flags & TCHT_ONITEMICON) == TCHT_ONITEMICON)
|
||||||
|
flags |= wxNB_HITTEST_ONICON;
|
||||||
|
if ((hitTestInfo.flags & TCHT_ONITEMLABEL) == TCHT_ONITEMLABEL)
|
||||||
|
flags |= wxNB_HITTEST_ONLABEL;
|
||||||
|
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxNotebook callbacks
|
// wxNotebook callbacks
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
Reference in New Issue
Block a user