X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/74f35eea76a446101e129cd7d2c219c3266dcbbf..1bc821059355d60e379c56083013553294df88c1:/include/wx/msw/combobox.h diff --git a/include/wx/msw/combobox.h b/include/wx/msw/combobox.h index 9c5aec679c..0cebad256d 100644 --- a/include/wx/msw/combobox.h +++ b/include/wx/msw/combobox.h @@ -21,7 +21,7 @@ // Combobox control // ---------------------------------------------------------------------------- -class WXDLLEXPORT wxComboBox : public wxChoice, +class WXDLLIMPEXP_CORE wxComboBox : public wxChoice, public wxTextEntry { public: @@ -72,6 +72,8 @@ public: // resolve ambiguities among virtual functions inherited from both base // classes + virtual void Clear(); + virtual wxString GetValue() const; virtual void SetValue(const wxString& value); virtual wxString GetStringSelection() const { return wxChoice::GetStringSelection(); } @@ -80,8 +82,7 @@ public: virtual void SetSelection(long from, long to) { wxTextEntry::SetSelection(from, to); } virtual int GetSelection() const { return wxChoice::GetSelection(); } - virtual void GetSelection(long *from, long *to) const - { wxTextEntry::GetSelection(from, to); } + virtual void GetSelection(long *from, long *to) const; virtual bool IsEditable() const; @@ -108,16 +109,27 @@ public: void OnUpdateDelete(wxUpdateUIEvent& event); void OnUpdateSelectAll(wxUpdateUIEvent& event); -protected: virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const; +protected: #if wxUSE_TOOLTIPS virtual void DoSetToolTip(wxToolTip *tip); #endif - virtual WXHWND GetEditHWND() const; + // this is the implementation of GetEditHWND() which can also be used when + // we don't have the edit control, it simply returns NULL then + // + // try not to use this function unless absolutely necessary (as in the + // message handling code where the edit control might not be created yet + // for the messages we receive during the control creation) as normally + // just testing for IsEditable() and using GetEditHWND() should be enough + WXHWND GetEditHWNDIfAvailable() const; private: + // this is the overridden wxTextEntry method which should only be called + // when we do have an edit control so it asserts if this is not the case + virtual WXHWND GetEditHWND() const; + DECLARE_DYNAMIC_CLASS_NO_COPY(wxComboBox) DECLARE_EVENT_TABLE() };