X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/3eeefdf9bdc41618a14a8fff96a016004b030e95..a70517e979955e17608126c9d8f7bf57879b5fbe:/src/msw/textentry.cpp diff --git a/src/msw/textentry.cpp b/src/msw/textentry.cpp index 65fbc3031f..b763b5de8e 100644 --- a/src/msw/textentry.cpp +++ b/src/msw/textentry.cpp @@ -41,12 +41,17 @@ // wxIEnumString implements IEnumString interface // ---------------------------------------------------------------------------- -#if wxUSE_OLE +// standard VC6 SDK (WINVER == 0x0400) does not know about IAutoComplete +#if wxUSE_OLE && (WINVER >= 0x0500) + #define HAS_AUTOCOMPLETE +#endif + +#ifdef HAS_AUTOCOMPLETE #include "wx/msw/ole/oleutils.h" #include -#if defined(__MINGW32__) +#if defined(__MINGW32__) || defined (__WATCOMC__) // needed for IID_IAutoComplete, IID_IAutoComplete2 and ACO_AUTOSUGGEST #include #endif @@ -90,7 +95,7 @@ public: if ( m_index == count ) return S_FALSE; - const wxWX2WCbuf wcbuf(m_strings[m_index].wc_str()); + const wxWX2WCbuf wcbuf = m_strings[m_index].wc_str(); const size_t size = (wcslen(wcbuf) + 1)*sizeof(wchar_t); void *olestr = CoTaskMemAlloc(size); if ( !olestr ) @@ -160,7 +165,7 @@ END_IID_TABLE; IMPLEMENT_IUNKNOWN_METHODS(wxIEnumString) -#endif // wxUSE_OLE +#endif // HAS_AUTOCOMPLETE // ============================================================================ // wxTextEntry implementation @@ -282,18 +287,15 @@ void wxTextEntry::GetSelection(long *from, long *to) const // auto-completion // ---------------------------------------------------------------------------- -#if wxUSE_OLE - bool wxTextEntry::AutoCompleteFileNames() { +#ifdef HAS_AUTOCOMPLETE typedef HRESULT (WINAPI *SHAutoComplete_t)(HWND, DWORD); static SHAutoComplete_t s_pfnSHAutoComplete = (SHAutoComplete_t)-1; static wxDynamicLibrary s_dllShlwapi; if ( s_pfnSHAutoComplete == (SHAutoComplete_t)-1 ) { - wxLogNull noLog; - - if ( !s_dllShlwapi.Load(_T("shlwapi.dll"), wxDL_VERBATIM) ) + if ( !s_dllShlwapi.Load(_T("shlwapi.dll"), wxDL_VERBATIM | wxDL_QUIET) ) { s_pfnSHAutoComplete = NULL; } @@ -313,12 +315,15 @@ bool wxTextEntry::AutoCompleteFileNames() return false; } - return true; +#else // !HAS_AUTOCOMPLETE + return false; +#endif // HAS_AUTOCOMPLETE/!HAS_AUTOCOMPLETE } bool wxTextEntry::AutoComplete(const wxArrayString& choices) { +#ifdef HAS_AUTOCOMPLETE // create an object exposing IAutoComplete interface (don't go for // IAutoComplete2 immediately as, presumably, it might be not available on // older systems as otherwise why do we have both -- although in practice I @@ -366,11 +371,13 @@ bool wxTextEntry::AutoComplete(const wxArrayString& choices) // do it immediately, presumably the edit control itself keeps a reference // to the auto completer object pAutoComplete->Release(); - return true; -} +#else // !HAS_AUTOCOMPLETE + wxUnusedVar(choices); -#endif // wxUSE_OLE + return false; +#endif // HAS_AUTOCOMPLETE/!HAS_AUTOCOMPLETE +} // ---------------------------------------------------------------------------- // editable state