From: Vadim Zeitlin Date: Tue, 12 Dec 2000 14:33:15 +0000 (+0000) Subject: merged fix from 2.2 branch X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/6d14cac77d6a33162621dadb318b4548bc711bc0 merged fix from 2.2 branch git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@8914 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/src/msw/combobox.cpp b/src/msw/combobox.cpp index cf839f4748..3caa1b324d 100644 --- a/src/msw/combobox.cpp +++ b/src/msw/combobox.cpp @@ -366,25 +366,31 @@ void wxComboBox::SetEditable(bool editable) void wxComboBox::SetInsertionPoint(long pos) { + if ( GetWindowStyle() & wxCB_READONLY ) + return; + #ifdef __WIN32__ - HWND hWnd = GetHwnd(); - SendMessage(hWnd, CB_SETEDITSEL, 0, MAKELPARAM(pos, pos)); - HWND hEditWnd = (HWND) GetEditHWND() ; - if (hEditWnd) - { - // Scroll insertion point into view - SendMessage(hEditWnd, EM_SCROLLCARET, (WPARAM)0, (LPARAM)0); - // Why is this necessary? (Copied from wxTextCtrl::SetInsertionPoint) - static const wxChar *nothing = _T(""); - SendMessage(hEditWnd, EM_REPLACESEL, 0, (LPARAM)nothing); - } -#endif + HWND hWnd = GetHwnd(); + ::SendMessage(hWnd, CB_SETEDITSEL, 0, MAKELPARAM(pos, pos)); + HWND hEditWnd = (HWND) GetEditHWND() ; + if ( hEditWnd ) + { + // Scroll insertion point into view + SendMessage(hEditWnd, EM_SCROLLCARET, (WPARAM)0, (LPARAM)0); + // Why is this necessary? (Copied from wxTextCtrl::SetInsertionPoint) + SendMessage(hEditWnd, EM_REPLACESEL, 0, (LPARAM)_T("")); + } +#endif // __WIN32__ } void wxComboBox::SetInsertionPointEnd() { - long pos = GetLastPosition(); - SetInsertionPoint(pos); + // setting insertion point doesn't make sense for read only comboboxes + if ( !(GetWindowStyle() & wxCB_READONLY) ) + { + long pos = GetLastPosition(); + SetInsertionPoint(pos); + } } long wxComboBox::GetInsertionPoint() const