X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2036bdd30368d117918b565ae990a89841281f33..6b9103c67b1901d59ddfbe11bba5af586b0622de:/include/wx/msw/missing.h diff --git a/include/wx/msw/missing.h b/include/wx/msw/missing.h index b13bc7736e..2b6280b287 100644 --- a/include/wx/msw/missing.h +++ b/include/wx/msw/missing.h @@ -29,19 +29,26 @@ #define WM_CONTEXTMENU 0x007B #endif -// Needed by toplevel.cpp +#ifndef WM_CHANGEUISTATE + #define WM_CHANGEUISTATE 0x0127 +#endif + #ifndef WM_UPDATEUISTATE #define WM_UPDATEUISTATE 0x0128 #endif -#ifndef WM_CHANGEUISTATE - #define WM_CHANGEUISTATE 0x0127 +#ifndef WM_QUERYUISTATE + #define WM_QUERYUISTATE 0x0129 #endif #ifndef WM_PRINTCLIENT #define WM_PRINTCLIENT 0x318 #endif +#ifndef DT_HIDEPREFIX + #define DT_HIDEPREFIX 0x00100000 +#endif + // Needed by toplevel.cpp #ifndef UIS_SET #define UIS_SET 1 @@ -211,10 +218,36 @@ typedef struct wxtagNMLVCUSTOMDRAW_ { #endif // defined __VISUALC__ && __VISUALC__ <= 1100 // ---------------------------------------------------------------------------- -// ListView common control -// Needed by listctrl.cpp +// menu stuff +// ---------------------------------------------------------------------------- + +#ifndef MIIM_BITMAP + #define MIIM_STRING 0x00000040 + #define MIIM_BITMAP 0x00000080 + #define MIIM_FTYPE 0x00000100 + #define HBMMENU_CALLBACK ((HBITMAP) -1) + + typedef struct tagMENUINFO + { + DWORD cbSize; + DWORD fMask; + DWORD dwStyle; + UINT cyMax; + HBRUSH hbrBack; + DWORD dwContextHelpID; + DWORD dwMenuData; + } MENUINFO, FAR *LPMENUINFO; +#endif // MIIM_BITMAP &c + +// ---------------------------------------------------------------------------- +// definitions related to ListView and Header common controls, needed by +// msw/listctrl.cpp and msw/headerctrl.cpp // ---------------------------------------------------------------------------- +#ifndef I_IMAGENONE + #define I_IMAGENONE (-2) +#endif + #ifndef LVS_EX_FULLROWSELECT #define LVS_EX_FULLROWSELECT 0x00000020 #endif @@ -235,6 +268,9 @@ typedef struct wxtagNMLVCUSTOMDRAW_ { #ifndef HDS_HOTTRACK #define HDS_HOTTRACK 4 #endif +#ifndef HDS_FLAT + #define HDS_FLAT 0x0200 +#endif #ifndef HDF_SORTUP #define HDF_SORTUP 0x0400 @@ -296,6 +332,7 @@ typedef struct wxtagNMLVCUSTOMDRAW_ { #ifdef __DMC__ +#ifndef VER_NT_WORKSTATION typedef struct _OSVERSIONINFOEX { DWORD dwOSVersionInfoSize; DWORD dwMajorVersion; @@ -309,6 +346,7 @@ typedef struct _OSVERSIONINFOEX { BYTE wProductType; BYTE wReserved; } OSVERSIONINFOEX; +#endif // !defined(VER_NT_WORKSTATION) #ifndef _TrackMouseEvent #define _TrackMouseEvent TrackMouseEvent @@ -359,10 +397,14 @@ typedef struct _OSVERSIONINFOEX { #define NMHEADER HD_NOTIFY #endif +#ifndef HDS_DRAGDROP + #define HDS_DRAGDROP 0x0040 +#endif #ifndef HDS_FULLDRAG - #define HDS_FULLDRAG 128 + #define HDS_FULLDRAG 0x0080 #endif + #ifndef HDN_BEGINDRAG #define HDN_BEGINDRAG (HDN_FIRST - 11) #endif @@ -472,6 +514,182 @@ typedef struct #endif +#endif + +// Various definitions are missing from mingw +// Used by webview_ie.cpp +#ifdef __MINGW32__ +typedef enum CommandStateChangeConstants { + CSC_UPDATECOMMANDS = (int) 0xFFFFFFFF, + CSC_NAVIGATEFORWARD = 0x1, + CSC_NAVIGATEBACK = 0x2 +} CommandStateChangeConstants; + +#define DISPID_COMMANDSTATECHANGE 105 +#define DISPID_NAVIGATECOMPLETE2 252 +#define DISPID_NAVIGATEERROR 271 +#define DISPID_NEWWINDOW3 273 +#define INET_E_ERROR_FIRST 0x800C0002L +#define INET_E_INVALID_URL 0x800C0002L +#define INET_E_NO_SESSION 0x800C0003L +#define INET_E_CANNOT_CONNECT 0x800C0004L +#define INET_E_RESOURCE_NOT_FOUND 0x800C0005L +#define INET_E_OBJECT_NOT_FOUND 0x800C0006L +#define INET_E_DATA_NOT_AVAILABLE 0x800C0007L +#define INET_E_DOWNLOAD_FAILURE 0x800C0008L +#define INET_E_AUTHENTICATION_REQUIRED 0x800C0009L +#define INET_E_NO_VALID_MEDIA 0x800C000AL +#define INET_E_CONNECTION_TIMEOUT 0x800C000BL +#define INET_E_INVALID_REQUEST 0x800C000CL +#define INET_E_UNKNOWN_PROTOCOL 0x800C000DL +#define INET_E_SECURITY_PROBLEM 0x800C000EL +#define INET_E_CANNOT_LOAD_DATA 0x800C000FL +#define INET_E_CANNOT_INSTANTIATE_OBJECT 0x800C0010L +#define INET_E_QUERYOPTION_UNKNOWN 0x800C0013L +#define INET_E_REDIRECT_FAILED 0x800C0014L +#define INET_E_REDIRECT_TO_DIR 0x800C0015L +#define INET_E_CANNOT_LOCK_REQUEST 0x800C0016L +#define INET_E_USE_EXTEND_BINDING 0x800C0017L +#define INET_E_TERMINATED_BIND 0x800C0018L +#define INET_E_INVALID_CERTIFICATE 0x800C0019L +#define INET_E_CODE_DOWNLOAD_DECLINED 0x800C0100L +#define INET_E_RESULT_DISPATCHED 0x800C0200L +#define INET_E_CANNOT_REPLACE_SFP_FILE 0x800C0300L +#define INET_E_CODE_INSTALL_BLOCKED_BY_HASH_POLICY 0x800C0500L +#define INET_E_CODE_INSTALL_SUPPRESSED 0x800C0400L + +#define REFRESH_NORMAL 0 +#define REFRESH_COMPLETELY 3 +#endif + +// For Visual C++ 6 and MinGW32. Used by webview_ie.cpp +#ifndef INET_E_INVALID_CERTIFICATE +#define INET_E_INVALID_CERTIFICATE 0x800C0019L +#endif + +#ifndef INET_E_CODE_INSTALL_BLOCKED_BY_HASH_POLICY +#define INET_E_CODE_INSTALL_BLOCKED_BY_HASH_POLICY 0x800C0500L +#endif + +#ifndef INET_E_CODE_INSTALL_SUPPRESSED +#define INET_E_CODE_INSTALL_SUPPRESSED 0x800C0400L +#endif + +#ifndef DISPID_NEWWINDOW3 +#define DISPID_NEWWINDOW3 273 +#endif + +//As MinGW is missing urlmon we replicate the definitions here for wxWebView +#ifdef __MINGW32__ + +EXTERN_C const IID CLSID_FileProtocol; +EXTERN_C const IID IID_IInternetProtocolRoot; +EXTERN_C const IID IID_IInternetProtocol; + +DEFINE_GUID(IID_IInternetProtocolRoot,0x79eac9e3,0xbaf9,0x11ce,0x8c,0x82,0,0xaa,0,0x4b,0xa9,0xb); +DEFINE_GUID(IID_IInternetProtocol,0x79eac9e4,0xbaf9,0x11ce,0x8c,0x82,0,0xaa,0,0x4b,0xa9,0xb); + +typedef enum __MIDL_IBindStatusCallback_0006 +{ + BSCF_FIRSTDATANOTIFICATION = 0x1, + BSCF_INTERMEDIATEDATANOTIFICATION = 0x2, + BSCF_LASTDATANOTIFICATION = 0x4, + BSCF_DATAFULLYAVAILABLE = 0x8, + BSCF_AVAILABLEDATASIZEUNKNOWN = 0x10 +} BSCF; + +typedef struct _tagPROTOCOLDATA +{ + DWORD grfFlags; + DWORD dwState; + LPVOID pData; + ULONG cbData; +} PROTOCOLDATA; + +typedef struct _tagBINDINFO +{ + ULONG cbSize; + LPWSTR szExtraInfo; + STGMEDIUM stgmedData; + DWORD grfBindInfoF; + DWORD dwBindVerb; + LPWSTR szCustomVerb; + DWORD cbstgmedData; + DWORD dwOptions; + DWORD dwOptionsFlags; + DWORD dwCodePage; + SECURITY_ATTRIBUTES securityAttributes; + IID iid; + IUnknown *pUnk; + DWORD dwReserved; +} BINDINFO; + +class IInternetProtocolSink : public IUnknown +{ +public: + virtual HRESULT STDMETHODCALLTYPE Switch(PROTOCOLDATA*) = 0; + virtual HRESULT STDMETHODCALLTYPE ReportProgress(ULONG, LPCWSTR) = 0; + virtual HRESULT STDMETHODCALLTYPE ReportData(DWORD, ULONG, ULONG) = 0; + virtual HRESULT STDMETHODCALLTYPE ReportResult(HRESULT, DWORD, LPCWSTR) = 0; +}; + +class IInternetBindInfo : public IUnknown +{ +public: + virtual HRESULT STDMETHODCALLTYPE GetBindInfo(DWORD*, BINDINFO*) = 0; + virtual HRESULT STDMETHODCALLTYPE GetBindString(ULONG, LPOLESTR*, ULONG, + ULONG*) = 0; +}; + +class IInternetProtocolRoot : public IUnknown +{ +public: + virtual HRESULT STDMETHODCALLTYPE Start(LPCWSTR, IInternetProtocolSink*, + IInternetBindInfo*, DWORD, + HANDLE_PTR) = 0; + virtual HRESULT STDMETHODCALLTYPE Continue(PROTOCOLDATA*) = 0; + virtual HRESULT STDMETHODCALLTYPE Abort(HRESULT, DWORD) = 0; + virtual HRESULT STDMETHODCALLTYPE Terminate(DWORD) = 0; + virtual HRESULT STDMETHODCALLTYPE Suspend() = 0; + virtual HRESULT STDMETHODCALLTYPE Resume() = 0; +}; + +class IInternetProtocol : public IInternetProtocolRoot +{ +public: + virtual HRESULT STDMETHODCALLTYPE Read(void*, ULONG, ULONG*) = 0; + virtual HRESULT STDMETHODCALLTYPE Seek(LARGE_INTEGER, DWORD, + ULARGE_INTEGER*) = 0; + virtual HRESULT STDMETHODCALLTYPE LockRequest(DWORD) = 0; + virtual HRESULT STDMETHODCALLTYPE UnlockRequest() = 0; +}; + +class IInternetSession : public IUnknown +{ +public: + virtual HRESULT STDMETHODCALLTYPE RegisterNameSpace(IClassFactory*, + REFCLSID, LPCWSTR, + ULONG, const LPCWSTR*, + DWORD) = 0; + virtual HRESULT STDMETHODCALLTYPE UnregisterNameSpace(IClassFactory*, + LPCWSTR) = 0; + virtual HRESULT STDMETHODCALLTYPE RegisterMimeFilter(IClassFactory*, + REFCLSID, + LPCWSTR) = 0; + virtual HRESULT STDMETHODCALLTYPE UnregisterMimeFilter(IClassFactory*, + LPCWSTR) = 0; + virtual HRESULT STDMETHODCALLTYPE CreateBinding(LPBC, LPCWSTR, IUnknown*, + IUnknown**, + IInternetProtocol**, + DWORD) = 0; + virtual HRESULT STDMETHODCALLTYPE SetSessionOption(DWORD, LPVOID, DWORD, + DWORD) = 0; + virtual HRESULT STDMETHODCALLTYPE GetSessionOption(DWORD, LPVOID, DWORD*, + DWORD) = 0; +}; + +STDAPI CoInternetGetSession(DWORD, IInternetSession**, DWORD); + #endif /* @@ -495,5 +713,9 @@ typedef struct #endif #endif // defined __WINE__ +#ifndef INVALID_FILE_ATTRIBUTES + #define INVALID_FILE_ATTRIBUTES ((DWORD)-1) +#endif + #endif // _WX_MISSING_H_