X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/fd0eed647daeb257f28699de879d2f4f5aeb7fb6..e14d10b039e68a701a447043a4031cf43e9fa90b:/include/wx/gtk1/combobox.h diff --git a/include/wx/gtk1/combobox.h b/include/wx/gtk1/combobox.h index e4b7d5e610..9dfb9e9c2e 100644 --- a/include/wx/gtk1/combobox.h +++ b/include/wx/gtk1/combobox.h @@ -12,11 +12,14 @@ #ifndef __GTKCOMBOBOXH__ #define __GTKCOMBOBOXH__ -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(__APPLE__) #pragma interface "combobox.h" #endif #include "wx/defs.h" + +#if wxUSE_COMBOBOX + #include "wx/object.h" #include "wx/control.h" @@ -30,8 +33,8 @@ class wxComboBox; // global data //----------------------------------------------------------------------------- -extern const char* wxComboBoxNameStr; -extern const char* wxEmptyString; +extern const wxChar* wxComboBoxNameStr; +extern const wxChar* wxEmptyString; //----------------------------------------------------------------------------- // wxComboBox @@ -39,12 +42,9 @@ extern const char* wxEmptyString; class wxComboBox : public wxControl { - DECLARE_DYNAMIC_CLASS(wxComboBox) - public: - - inline wxComboBox() {} - inline wxComboBox(wxWindow *parent, wxWindowID id, + inline wxComboBox() {} + inline wxComboBox(wxWindow *parent, wxWindowID id, const wxString& value = wxEmptyString, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, @@ -52,11 +52,11 @@ public: long style = 0, const wxValidator& validator = wxDefaultValidator, const wxString& name = wxComboBoxNameStr) - { - Create(parent, id, value, pos, size, n, choices, style, validator, name); - } - ~wxComboBox(); - bool Create(wxWindow *parent, wxWindowID id, + { + Create(parent, id, value, pos, size, n, choices, style, validator, name); + } + ~wxComboBox(); + bool Create(wxWindow *parent, wxWindowID id, const wxString& value = wxEmptyString, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, @@ -65,54 +65,82 @@ public: const wxValidator& validator = wxDefaultValidator, const wxString& name = wxComboBoxNameStr); - void Append( const wxString &item ); - void Append( const wxString &item, void* clientData ); - void Append( const wxString &item, wxClientData* clientData ); - - void SetClientData( int n, void* clientData ); - void* GetClientData( int n ); - void SetClientObject( int n, wxClientData* clientData ); - wxClientData* GetClientObject( int n ); - - void Clear(); - void Delete( int n ); - - int FindString( const wxString &item ); - int GetSelection() const; - wxString GetString( int n ) const; - wxString GetStringSelection() const; - int Number() const; - void SetSelection( int n ); - void SetStringSelection( const wxString &string ); - - wxString GetValue() const; - void SetValue(const wxString& value); - - void Copy(); - void Cut(); - void Paste(); - void SetInsertionPoint( long pos ); - void SetInsertionPointEnd(); - long GetInsertionPoint() const; - long GetLastPosition() const; - void Replace( long from, long to, const wxString& value ); - void Remove( long from, long to ); - void SetSelection( long from, long to ); - void SetEditable( bool editable ); - - void OnSize( wxSizeEvent &event ); - -// implementation - - bool m_alreadySent; - wxList m_clientDataList; - - void AppendCommon( const wxString &item ); - GtkWidget* GetConnectWidget(); - bool IsOwnGtkWindow( GdkWindow *window ); - void ApplyWidgetStyle(); - - DECLARE_EVENT_TABLE() + void Append( const wxString &item ); + void Append( const wxString &item, void* clientData ); + void Append( const wxString &item, wxClientData* clientData ); + + void Insert( const wxString &item, int pos ); + void Insert( const wxString &item, int pos, void* clientData ); + void Insert( const wxString &item, int pos, wxClientData* clientData ); + + void SetClientData( int n, void* clientData ); + void* GetClientData( int n ) const; + void SetClientObject( int n, wxClientData* clientData ); + wxClientData* GetClientObject( int n ) const; + + void SetClientObject( wxClientData *data ) { wxControl::SetClientObject( data ); } + wxClientData *GetClientObject() const { return wxControl::GetClientObject(); } + void SetClientData( void *data ) { wxControl::SetClientData( data ); } + void *GetClientData() const { return wxControl::GetClientData(); } + + void Clear(); + void Delete( int n ); + + int FindString( const wxString &item ); + int GetSelection() const; + wxString GetString( int n ) const; + wxString GetStringSelection() const; + int GetCount() const { return Number(); } + int Number() const; + void SetSelection( int n ); + void SetStringSelection( const wxString &string ); + void SetString(int n, const wxString &text); + + wxString GetValue() const; + void SetValue(const wxString& value); + + void Copy(); + void Cut(); + void Paste(); + void SetInsertionPoint( long pos ); + void SetInsertionPointEnd(); + long GetInsertionPoint() const; + long GetLastPosition() const; + void Replace( long from, long to, const wxString& value ); + void Remove( long from, long to ); + void SetSelection( long from, long to ); + void SetEditable( bool editable ); + + // implementation + + virtual void SetFocus(); + + void OnSize( wxSizeEvent &event ); + void OnChar( wxKeyEvent &event ); + + bool m_alreadySent; + wxList m_clientDataList; + wxList m_clientObjectList; + int m_prevSelection; + + void DisableEvents(); + void EnableEvents(); + void AppendCommon( const wxString &item ); + void InsertCommon( const wxString &item, int pos ); + GtkWidget* GetConnectWidget(); + bool IsOwnGtkWindow( GdkWindow *window ); + void ApplyWidgetStyle(); + +protected: + virtual wxSize DoGetBestSize() const; + +private: + DECLARE_DYNAMIC_CLASS(wxComboBox) + DECLARE_EVENT_TABLE() }; -#endif // __GTKCOMBOBOXH__ +#endif + +#endif + + // __GTKCOMBOBOXH__