X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/22a70443dbfca84686b01c42c98e7cc61a21f307..0f4930939e18a6c07ef303533329dd5334a65780:/src/mac/combobox.cpp diff --git a/src/mac/combobox.cpp b/src/mac/combobox.cpp index db47c86aaa..a3de1918ca 100644 --- a/src/mac/combobox.cpp +++ b/src/mac/combobox.cpp @@ -51,7 +51,7 @@ class wxComboBoxText : public wxTextCtrl { public: wxComboBoxText( wxComboBox * cb ) - : wxTextCtrl( cb->GetParent(), 1 ) + : wxTextCtrl( cb , 1 ) { m_cb = cb; } @@ -81,7 +81,7 @@ class wxComboBoxChoice : public wxChoice { public: wxComboBoxChoice(wxComboBox *cb, int style) - : wxChoice( cb->GetParent(), 1 ) + : wxChoice( cb , 1 ) { m_cb = cb; } @@ -104,16 +104,19 @@ BEGIN_EVENT_TABLE(wxComboBoxChoice, wxChoice) EVT_CHOICE(-1, wxComboBoxChoice::OnChoice) END_EVENT_TABLE() - - - wxComboBox::~wxComboBox() { - // delete the controls now, don't leave them alive even though they woudl + // delete the controls now, don't leave them alive even though they would // still be eventually deleted by our parent - but it will be too late, the // user code expects them to be gone now - delete m_text; - delete m_choice; + if (m_text != NULL) { + delete m_text; + m_text = NULL; + } + if (m_choice != NULL) { + delete m_choice; + m_choice = NULL; + } } @@ -125,7 +128,7 @@ wxSize wxComboBox::DoGetBestSize() const { wxSize size = m_choice->GetBestSize(); - if ( m_text != 0 ) + if ( m_text != NULL ) { wxSize sizeText = m_text->GetBestSize(); @@ -140,15 +143,15 @@ void wxComboBox::DoMoveWindow(int x, int y, int width, int height) { wxControl::DoMoveWindow(x, y, width, height); - if ( m_text == 0 ) + if ( m_text == NULL ) { - m_choice->SetSize(x, y, width, -1); + m_choice->SetSize(0, 0 , width, -1); } else { wxCoord wText = width - POPUPWIDTH; - m_text->SetSize(x, y, wText, height); - m_choice->SetSize(x + wText + MARGIN, y, POPUPWIDTH, -1); + m_text->SetSize(0, 0, wText, height); + m_choice->SetSize(0 + wText + MARGIN, 0, POPUPWIDTH, -1); } } @@ -163,13 +166,6 @@ bool wxComboBox::Enable(bool enable) if ( !wxControl::Enable(enable) ) return FALSE; - m_choice->Enable(enable); - - if ( m_text != 0 ) - { - m_text->Enable(enable); - } - return TRUE; } @@ -178,27 +174,19 @@ bool wxComboBox::Show(bool show) if ( !wxControl::Show(show) ) return FALSE; - // under GTK Show() is called the first time before we are fully - // constructed - if ( m_choice ) - { - m_choice->Show(show); - if ( m_text != 0 ) - { - m_text->Show(show); - } - } - return TRUE; } - void wxComboBox::SetFocus() - { - m_text->SetFocus(); - } +void wxComboBox::SetFocus() +{ + if ( m_text != NULL) { + m_text->SetFocus(); + } +} -void wxComboBox::DelegateTextChanged( const wxString& value ) { +void wxComboBox::DelegateTextChanged( const wxString& value ) +{ } @@ -221,18 +209,18 @@ bool wxComboBox::Create(wxWindow *parent, wxWindowID id, Rect bounds ; Str255 title ; - if ( !wxControl::Create(parent, id, pos, size, style, + if ( !wxControl::Create(parent, id, wxDefaultPosition, wxDefaultSize, style , wxDefaultValidator, name) ) { return FALSE; } - m_choice = new wxComboBoxChoice(this, style); + m_choice = new wxComboBoxChoice(this, style ); wxSize csize = size; if ( style & wxCB_READONLY ) { - m_text = 0; + m_text = NULL; } else { @@ -243,21 +231,12 @@ bool wxComboBox::Create(wxWindow *parent, wxWindowID id, } DoSetSize(pos.x, pos.y, csize.x, csize.y); + for ( int i = 0 ; i < n ; i++ ) { m_choice->DoAppend( choices[ i ] ); } - // have to disable this window to avoid interfering it with message - // processing to the text and the button... but pretend it is enabled to - // make IsEnabled() return TRUE - wxControl::Enable(FALSE); // don't use non virtual Disable() here! - m_isEnabled = TRUE; - - // we don't even need to show this window itself - and not doing it avoids - // that it overwrites the text control - wxControl::Show(FALSE); - return TRUE; } @@ -265,7 +244,7 @@ wxString wxComboBox::GetValue() const { wxString result; - if ( m_text == 0 ) + if ( m_text == NULL ) { result = m_choice->GetString( m_choice->GetSelection() ); } @@ -285,7 +264,7 @@ void wxComboBox::SetValue(const wxString& value) // Clipboard operations void wxComboBox::Copy() { - if ( m_text != 0 ) + if ( m_text != NULL ) { m_text->Copy(); } @@ -293,7 +272,7 @@ void wxComboBox::Copy() void wxComboBox::Cut() { - if ( m_text != 0 ) + if ( m_text != NULL ) { m_text->Cut(); } @@ -301,7 +280,7 @@ void wxComboBox::Cut() void wxComboBox::Paste() { - if ( m_text != 0 ) + if ( m_text != NULL ) { m_text->Paste(); } @@ -309,14 +288,14 @@ void wxComboBox::Paste() void wxComboBox::SetEditable(bool editable) { - if ( ( m_text == 0 ) && editable ) + if ( ( m_text == NULL ) && editable ) { m_text = new wxComboBoxText( this ); } - else if ( ( m_text != 0 ) && !editable ) + else if ( ( m_text != NULL ) && !editable ) { delete m_text; - m_text = 0; + m_text = NULL; } int currentX, currentY; @@ -393,7 +372,7 @@ void wxComboBox::SetSelection(int n) { m_choice->SetSelection( n ); - if ( m_text != 0 ) + if ( m_text != NULL ) { m_text->SetValue( GetString( n ) ); }