// Created: ??/??/98
// RCS-ID: $Id$
// Copyright: (c) AUTHOR
-// Licence: wxWindows licence
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifdef __GNUG__
void OnTextChange( wxCommandEvent& event )
{
wxString s = GetValue();
-
- m_cb->DelegateTextChanged( s );
+
+ if (!s.IsEmpty())
+ m_cb->DelegateTextChanged( s );
event.Skip();
}
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;
+ }
}
return TRUE;
}
+ void wxComboBox::SetFocus()
+ {
+ m_text->SetFocus();
+ }
+
void wxComboBox::DelegateTextChanged( const wxString& value ) {
}
const wxString& value,
const wxPoint& pos,
const wxSize& size,
- int n, const wxString choices[],
- long style,
+ int n, const wxString choices[],
+ long style,
const wxValidator& validator,
const wxString& name)
{
DoSetSize(pos.x, pos.y, csize.x, csize.y);
for ( int i = 0 ; i < n ; i++ )
{
- m_choice->DoAppend( choices[ i ] );
+ m_choice->DoAppend( choices[ i ] );
}
// have to disable this window to avoid interfering it with message
void wxComboBox::Append(const wxString& item)
{
- m_choice->DoAppend( item );
+ // I am not sure what other ports do,
+ // but wxMac chokes on empty entries.
+
+ if (!item.IsEmpty())
+ m_choice->DoAppend( item );
}
void wxComboBox::Delete(int n)
void wxComboBox::MacHandleControlClick( WXWidget control , wxInt16 controlpart )
{
wxCommandEvent event(wxEVT_COMMAND_COMBOBOX_SELECTED, m_windowId );
- event.SetInt(GetSelection());
+ event.SetInt(GetSelection());
event.SetEventObject(this);
event.SetString(GetStringSelection());
ProcessCommand(event);