wxNode *node = m_clientList.Nth( n );
wxCHECK_RET( node, wxT("invalid index in wxChoice::DoSetItemClientObject") );
- wxClientData *cd = (wxClientData*) node->Data();
- delete cd;
+ // wxItemContainer already deletes data for us
node->SetData( (wxObject*) clientData );
}
wxASSERT_MSG( label != NULL , wxT("wxChoice: invalid label") );
- wxString tmp( wxGTK_CONV_BACK( label->label ) );
+#ifdef __WXGTK20__
+ wxString tmp( wxGTK_CONV_BACK( gtk_label_get_text( label) ) );
+#else
+ wxString tmp( label->label );
+#endif
if (string == tmp)
return count;
int wxChoice::GetSelection() const
{
wxCHECK_MSG( m_widget != NULL, -1, wxT("invalid choice") );
+
+#ifdef __WXGTK20__
+ return gtk_option_menu_get_history( GTK_OPTION_MENU(m_widget) );
+
+#else
GtkMenuShell *menu_shell = GTK_MENU_SHELL( gtk_option_menu_get_menu( GTK_OPTION_MENU(m_widget) ) );
int count = 0;
+
GList *child = menu_shell->children;
while (child)
{
}
return -1;
+#endif
}
void wxChoice::SetString( int WXUNUSED(n), const wxString& WXUNUSED(string) )
wxASSERT_MSG( label != NULL , wxT("wxChoice: invalid label") );
- return wxString( wxGTK_CONV_BACK(label->label) );
+#ifdef __WXGTK20__
+ return wxString( wxGTK_CONV_BACK( gtk_label_get_text( label) ) );
+#else
+ return wxString( label->label );
+#endif
}
child = child->next;
count++;
ret.x = 0;
if ( m_widget )
{
- GdkFont *font = m_font.GetInternalFont();
-
- wxCoord width;
+ int width;
size_t count = GetCount();
for ( size_t n = 0; n < count; n++ )
{
- // FIXME GTK 2.0
- width = (wxCoord)gdk_string_width(font, wxGTK_CONV( GetString(n) ) );
+ GetTextExtent( GetString(n), &width, NULL, NULL, NULL, &m_font );
if ( width > ret.x )
ret.x = width;
}