+ virtual wxSize DoGetBestSize() const;
+ void PostCreation(const wxSize& size);
+
+ // sets the label to the given string and also sets it for the given widget
+ void GTKSetLabelForLabel(GtkLabel *w, const wxString& label);
+#if wxUSE_MARKUP
+ void GTKSetLabelWithMarkupForLabel(GtkLabel *w, const wxString& label);
+#endif // wxUSE_MARKUP
+
+ // GtkFrame helpers
+ GtkWidget* GTKCreateFrame(const wxString& label);
+ void GTKSetLabelForFrame(GtkFrame *w, const wxString& label);
+ void GTKFrameApplyWidgetStyle(GtkFrame* w, GtkRcStyle* rc);
+ void GTKFrameSetMnemonicWidget(GtkFrame* w, GtkWidget* widget);
+
+ // remove mnemonics ("&"s) from the label
+ static wxString GTKRemoveMnemonics(const wxString& label);
+
+ // converts wx label to GTK+ label, i.e. basically replace "&"s with "_"s
+ static wxString GTKConvertMnemonics(const wxString &label);
+
+ // converts wx label to GTK+ labels preserving Pango markup
+ static wxString GTKConvertMnemonicsWithMarkup(const wxString& label);
+
+ // These are used by GetDefaultAttributes
+ static wxVisualAttributes
+ GetDefaultAttributesFromGTKWidget(GtkWidget* widget,
+ bool useBase = false,
+ int state = 0);
+ static wxVisualAttributes
+ GetDefaultAttributesFromGTKWidget(wxGtkWidgetNew_t,
+ bool useBase = false,
+ int state = 0);
+ static wxVisualAttributes
+ GetDefaultAttributesFromGTKWidget(wxGtkWidgetNewFromStr_t,
+ bool useBase = false,
+ int state = 0);
+
+ static wxVisualAttributes
+ GetDefaultAttributesFromGTKWidget(wxGtkWidgetNewFromAdj_t,
+ bool useBase = false,
+ int state = 0);
+
+ // Widgets that use the style->base colour for the BG colour should
+ // override this and return true.
+ virtual bool UseGTKStyleBase() const { return false; }
+
+ // Fix sensitivity due to bug in GTK+ < 2.14
+ void GTKFixSensitivity(bool onlyIfUnderMouse = true);
+
+private:
+ DECLARE_DYNAMIC_CLASS(wxControl)