X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b019151f0b23d0fd97925ae8859bd7d0dfc91b0f..f79fd1e54b4533507c6de798eecfdde765a3fc4e:/src/gtk/radiobut.cpp diff --git a/src/gtk/radiobut.cpp b/src/gtk/radiobut.cpp index 8b93df7380..6b6cd98694 100644 --- a/src/gtk/radiobut.cpp +++ b/src/gtk/radiobut.cpp @@ -13,9 +13,19 @@ #endif #include "wx/radiobut.h" + +#if wxUSE_RADIOBOX + #include "gdk/gdk.h" #include "gtk/gtk.h" +//----------------------------------------------------------------------------- +// idle system +//----------------------------------------------------------------------------- + +extern void wxapp_install_idle_handler(); +extern bool g_isIdle; + //----------------------------------------------------------------------------- // data //----------------------------------------------------------------------------- @@ -29,7 +39,9 @@ extern bool g_blockEventsOnDrag; static void gtk_radiobutton_clicked_callback( GtkWidget *WXUNUSED(widget), wxRadioButton *rb ) { - if (!rb->HasVMT()) return; + if (g_isIdle) wxapp_install_idle_handler(); + + if (!rb->m_hasVMT) return; if (rb->m_blockFirstEvent) { @@ -62,7 +74,9 @@ bool wxRadioButton::Create( wxWindow *parent, wxWindowID id, const wxString& lab PreCreation( parent, id, pos, newSize, style, name ); +#if wxUSE_VALIDATORS SetValidator( validator ); +#endif m_widget = gtk_radio_button_new_with_label( (GSList *) NULL, label.mbc_str() ); @@ -82,9 +96,7 @@ bool wxRadioButton::Create( wxWindow *parent, wxWindowID id, const wxString& lab gtk_signal_connect( GTK_OBJECT(m_widget), "clicked", GTK_SIGNAL_FUNC(gtk_radiobutton_clicked_callback), (gpointer*)this ); - m_parent->AddChild( this ); - - (m_parent->m_insertCallback)( m_parent, this ); + m_parent->DoAddChild( this ); PostCreation(); @@ -122,20 +134,21 @@ void wxRadioButton::SetValue( bool val ) gtk_toggle_button_set_state( GTK_TOGGLE_BUTTON(m_theOtherRadioButtton), TRUE ); } -bool wxRadioButton::GetValue(void) const +bool wxRadioButton::GetValue() const { wxCHECK_MSG( m_widget != NULL, FALSE, _T("invalid radiobutton") ); return GTK_TOGGLE_BUTTON(m_widget)->active; } -void wxRadioButton::Enable( bool enable ) +bool wxRadioButton::Enable( bool enable ) { - wxCHECK_RET( m_widget != NULL, _T("invalid radiobutton") ); - - wxControl::Enable( enable ); + if ( !wxControl::Enable( enable ) ) + return FALSE; gtk_widget_set_sensitive( GTK_BUTTON(m_widget)->child, enable ); + + return TRUE; } void wxRadioButton::ApplyWidgetStyle() @@ -144,3 +157,5 @@ void wxRadioButton::ApplyWidgetStyle() gtk_widget_set_style( m_widget, m_widgetStyle ); gtk_widget_set_style( GTK_BUTTON(m_widget)->child, m_widgetStyle ); } + +#endif