X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/bd866271710b65d219be00f8ad1fbc3e3de47346..ebef1625fa59c555e45d2aa278de0ff5674d6142:/src/msw/app.cpp diff --git a/src/msw/app.cpp b/src/msw/app.cpp index 529d6688c0..b6cbc4c8a8 100644 --- a/src/msw/app.cpp +++ b/src/msw/app.cpp @@ -17,10 +17,6 @@ // headers // --------------------------------------------------------------------------- -#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) - #pragma implementation "app.h" -#endif - // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" @@ -69,7 +65,8 @@ #endif // broken compilers #if defined(__POCKETPC__) || defined(__SMARTPHONE__) -#include + #include + #include #endif #if wxUSE_OLE @@ -86,12 +83,27 @@ #include "wx/msw/wince/missing.h" #endif -// For DLLVER_PLATFORM_WINDOWS -#if (!defined(__MINGW32__) || wxCHECK_W32API_VERSION( 2, 0 )) && \ - !defined(__CYGWIN__) && !defined(__DIGITALMARS__) && !defined(__WXWINCE__) && \ - (!defined(_MSC_VER) || (_MSC_VER > 1100)) - #include -#endif +// instead of including which is not part of the core SDK and not +// shipped at all with other compilers, we always define the parts of it we +// need here ourselves +// +// NB: DLLVER_PLATFORM_WINDOWS will be defined if shlwapi.h had been somehow +// included already +#ifndef DLLVER_PLATFORM_WINDOWS + // hopefully we don't need to change packing as DWORDs should be already + // correctly aligned + struct DLLVERSIONINFO + { + DWORD cbSize; + DWORD dwMajorVersion; // Major version + DWORD dwMinorVersion; // Minor version + DWORD dwBuildNumber; // Build number + DWORD dwPlatformID; // DLLVER_PLATFORM_* + }; + + typedef HRESULT (CALLBACK* DLLGETVERSIONPROC)(DLLVERSIONINFO *); +#endif // defined(DLLVERSIONINFO) + // --------------------------------------------------------------------------- // global variables @@ -292,10 +304,6 @@ bool wxApp::Initialize(int& argc, wxChar **argv) RegisterWindowClasses(); -#if wxUSE_PENWINDOWS - wxRegisterPenWin(); -#endif - wxWinHandleHash = new wxWinHashTable(wxKEY_INTEGER, 100); #if !defined(__WXMICROWIN__) && !defined(__WXWINCE__) @@ -461,10 +469,6 @@ void wxApp::CleanUp() wxSetKeyboardHook(false); #endif -#if wxUSE_PENWINDOWS - wxCleanUpPenWin(); -#endif - wxOleUninitialize(); // for an EXE the classes are unregistered when it terminates but DLL may @@ -591,18 +595,7 @@ int wxApp::GetComCtl32Version() // if so, then we can check for the version if ( dllComCtl32.IsLoaded() ) { -#ifndef DLLVER_PLATFORM_WINDOWS - typedef struct _DllVersionInfo - { - DWORD cbSize; - DWORD dwMajorVersion; // Major version - DWORD dwMinorVersion; // Minor version - DWORD dwBuildNumber; // Build number - DWORD dwPlatformID; // DLLVER_PLATFORM_* - } DLLVERSIONINFO; - typedef HRESULT (CALLBACK* DLLGETVERSIONPROC)(DLLVERSIONINFO *); -#endif - // try to use DllGetVersion() if available in _headers_ + // now check if the function is available during run-time wxDYNLIB_FUNCTION( DLLGETVERSIONPROC, DllGetVersion, dllComCtl32 ); if ( pfnDllGetVersion ) {