X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c6179a847d8899cceb8880abc2ab2fe9d0244c90..ee1787872dfad4da69b3cc986ee603a345f089ed:/include/wx/cocoa/combobox.h?ds=sidebyside diff --git a/include/wx/cocoa/combobox.h b/include/wx/cocoa/combobox.h index 30dedf5893..d0f1ad8eda 100644 --- a/include/wx/cocoa/combobox.h +++ b/include/wx/cocoa/combobox.h @@ -1,9 +1,9 @@ ///////////////////////////////////////////////////////////////////////////// // Name: wx/cocoa/combobox.h // Purpose: wxComboBox class -// Author: David Elliott +// Author: Ryan Norton // Modified by: -// Created: 2003/07/14 +// Created: 2005/02/16 // RCS-ID: $Id$ // Copyright: (c) 2003 David Elliott // Licence: wxWindows licence @@ -12,16 +12,40 @@ #ifndef __WX_COCOA_COMBOBOX_H__ #define __WX_COCOA_COMBOBOX_H__ -//#include "wx/cocoa/NSTableView.h" +//Begin NSComboBox.h + +#include "wx/hashmap.h" +#include "wx/cocoa/ObjcAssociate.h" + +#include "wx/textctrl.h" + +DECLARE_WXCOCOA_OBJC_CLASS(NSComboBox); + +WX_DECLARE_OBJC_HASHMAP(NSComboBox); +class wxCocoaNSComboBox +{ + WX_DECLARE_OBJC_INTERFACE_HASHMAP(NSComboBox) +public: + void AssociateNSComboBox(WX_NSComboBox cocoaNSComboBox); + void DisassociateNSComboBox(WX_NSComboBox cocoaNSComboBox); + + virtual void doWxEvent(int nEvent) = 0; + virtual ~wxCocoaNSComboBox() { } +}; + +//begin combobox.h + +#include "wx/dynarray.h" // ======================================================================== // wxComboBox // ======================================================================== -class WXDLLEXPORT wxComboBox: public wxTextCtrl, public wxComboBoxBase //, protected wxCocoaNSTableView +class WXDLLIMPEXP_CORE wxComboBox : public wxControl, public wxComboBoxBase, protected wxCocoaNSComboBox, protected wxCocoaNSTextField { DECLARE_DYNAMIC_CLASS(wxComboBox) DECLARE_EVENT_TABLE() -// WX_DECLARE_COCOA_OWNER(NSComboBox,NSTextField,NSView) + WX_DECLARE_COCOA_OWNER(NSComboBox,NSTextField,NSView) + WX_DECLARE_COCOA_OWNER(NSTextField,NSControl,NSView) // ------------------------------------------------------------------------ // initialization // ------------------------------------------------------------------------ @@ -73,68 +97,62 @@ public: // Cocoa callbacks // ------------------------------------------------------------------------ protected: + wxArrayPtrVoid m_Datas; + virtual void doWxEvent(int nEvent); + + virtual void Cocoa_didChangeText() + {} // ------------------------------------------------------------------------ // Implementation // ------------------------------------------------------------------------ public: + void Clear() // HACK + { wxComboBoxBase::Clear(); } + // wxCombobox methods - virtual void SetSelection(int); + virtual void SetSelection(int pos); // Overlapping methods virtual wxString GetStringSelection(); // wxItemContainer - virtual void Clear(); - virtual void Delete(int); - virtual int GetCount() const; - virtual wxString GetString(int) const; - virtual void SetString(int, const wxString&); - virtual int FindString(const wxString&) const; + virtual void DoClear(); + virtual void DoDeleteOneItem(unsigned int n); + virtual unsigned int GetCount() const; + virtual wxString GetString(unsigned int) const; + virtual void SetString(unsigned int pos, const wxString&); + virtual int FindString(const wxString& s, bool bCase = false) const; virtual int GetSelection() const; - virtual int DoAppend(const wxString&); - virtual int DoInsert(const wxString&, int); - virtual void DoSetItemClientData(int, void*); - virtual void* DoGetItemClientData(int) const; - virtual void DoSetItemClientObject(int, wxClientData*); - virtual wxClientData* DoGetItemClientObject(int) const; - // wxComboBoxBase pure virtuals - virtual wxString GetValue() const - { return wxTextCtrl::GetValue(); } - virtual void SetValue(const wxString& value) - { return wxTextCtrl::SetValue(value); } - virtual void Cut() { wxTextCtrl::Cut(); } - virtual void Copy() { wxTextCtrl::Copy(); } - virtual void Paste() { wxTextCtrl::Paste(); } - virtual void SetInsertionPoint(long pos) - { wxTextCtrl::SetInsertionPoint(pos); } - virtual void SetInsertionPointEnd() - { wxTextCtrl::SetInsertionPointEnd(); } - virtual long GetInsertionPoint() const - { return wxTextCtrl::GetInsertionPoint(); } - virtual wxTextPos GetLastPosition() const - { return wxTextCtrl::GetLastPosition(); } - virtual void Replace(long from, long to, const wxString& value) - { wxTextCtrl::Replace(from,to,value); } - virtual void SetSelection(long from, long to) - { wxTextCtrl::SetSelection(from,to); } - virtual void SetEditable(bool editable) - { wxTextCtrl::SetEditable(editable); } - virtual bool IsEditable() const - { return !HasFlag(wxCB_READONLY); } - virtual void Undo() - { wxTextCtrl::Undo(); } - virtual void Redo() - { wxTextCtrl::Redo(); } - virtual void SelectAll() - { wxTextCtrl::SelectAll(); } - virtual bool CanCopy() const - { return wxTextCtrl::CanCopy(); } - virtual bool CanCut() const - { return wxTextCtrl::CanCut(); } - virtual bool CanPaste() const - { return wxTextCtrl::CanPaste(); } - virtual bool CanUndo() const - { return wxTextCtrl::CanUndo(); } - virtual bool CanRedo() const - { return wxTextCtrl::CanRedo(); } + virtual int DoInsertItems(const wxArrayStringsAdapter& items, + unsigned int pos, + void **clientData, wxClientDataType type); + virtual void DoSetItemClientData(unsigned int, void*); + virtual void* DoGetItemClientData(unsigned int) const; + virtual bool IsSorted() const { return HasFlag(wxCB_SORT); } + +// ------------------------------------------------------------------------ +// wxTextEntryBase virtual implementations: +// ------------------------------------------------------------------------ + // FIXME: This needs to be moved to some sort of common code. + virtual void WriteText(const wxString&); + virtual wxString GetValue() const; + virtual void Remove(long, long); + virtual void Cut(); + virtual void Copy(); + virtual void Paste(); + virtual void Undo(); + virtual void Redo(); + virtual bool CanUndo() const; + virtual bool CanRedo() const; + virtual void SetInsertionPoint(long pos); + virtual long GetInsertionPoint() const; + virtual wxTextPos GetLastPosition() const; + virtual void SetSelection(long from, long to); + virtual void GetSelection(long *from, long *to) const; + virtual bool IsEditable() const; + virtual void SetEditable(bool editable); + +private: + // implement wxTextEntry pure virtual method + virtual wxWindow *GetEditableWindow() { return this; } }; #endif // __WX_COCOA_COMBOBOX_H__