summaryrefslogtreecommitdiff
path: root/libs/gtkmm2/gtk/gtkmm/widget.h
diff options
context:
space:
mode:
Diffstat (limited to 'libs/gtkmm2/gtk/gtkmm/widget.h')
-rw-r--r--libs/gtkmm2/gtk/gtkmm/widget.h2666
1 files changed, 2666 insertions, 0 deletions
diff --git a/libs/gtkmm2/gtk/gtkmm/widget.h b/libs/gtkmm2/gtk/gtkmm/widget.h
new file mode 100644
index 0000000000..36877d402d
--- /dev/null
+++ b/libs/gtkmm2/gtk/gtkmm/widget.h
@@ -0,0 +1,2666 @@
+// -*- c++ -*-
+// Generated by gtkmmproc -- DO NOT MODIFY!
+#ifndef _GTKMM_WIDGET_H
+#define _GTKMM_WIDGET_H
+
+#include <glibmm.h>
+
+/* $Id$ */
+
+/* Copyright (C) 2002, 2003 The gtkmm Development Team
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Library General Public License for more details.
+ *
+ * You should have received a copy of the GNU Library General Public
+ * License along with this library; if not, write to the Free
+ * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#include <pangomm/context.h>
+#include <pangomm/layout.h>
+#include <atkmm/object.h>
+#include <atkmm/implementor.h>
+#include <gdkmm/event.h>
+#include <gdkmm/types.h>
+#include <gdkmm/window.h>
+#include <gdkmm/dragcontext.h>
+#include <gdkmm/pixbuf.h>
+#include <gdkmm/screen.h>
+#include <gtkmm/enums.h>
+#include <gdkmm/display.h>
+//#include <gtkmm/style.h>
+#include <gtkmm/targetlist.h>
+#include <gtkmm/rc.h>
+#include <gtkmm/object.h>
+#include <gtkmm/clipboard.h>
+
+
+#ifndef DOXYGEN_SHOULD_SKIP_THIS
+extern "C"
+{
+typedef struct _GtkTargetEntry GtkTargetEntry;
+}
+#endif /* DOXYGEN_SHOULD_SKIP_THIS */
+
+#ifndef DOXYGEN_SHOULD_SKIP_THIS
+typedef struct _GtkWidget GtkWidget;
+typedef struct _GtkWidgetClass GtkWidgetClass;
+#endif /* DOXYGEN_SHOULD_SKIP_THIS */
+
+
+namespace Gtk
+{ class Widget_Class; } // namespace Gtk
+namespace Gtk
+{
+
+
+/** @addtogroup gtkmmEnums Enums and Flags */
+
+/**
+ * @ingroup gtkmmEnums
+ * @par Bitwise operators:
+ * <tt>%DestDefaults operator|(DestDefaults, DestDefaults)</tt><br>
+ * <tt>%DestDefaults operator&(DestDefaults, DestDefaults)</tt><br>
+ * <tt>%DestDefaults operator^(DestDefaults, DestDefaults)</tt><br>
+ * <tt>%DestDefaults operator~(DestDefaults)</tt><br>
+ * <tt>%DestDefaults& operator|=(DestDefaults&, DestDefaults)</tt><br>
+ * <tt>%DestDefaults& operator&=(DestDefaults&, DestDefaults)</tt><br>
+ * <tt>%DestDefaults& operator^=(DestDefaults&, DestDefaults)</tt><br>
+ */
+enum DestDefaults
+{
+ DEST_DEFAULT_MOTION = 1 << 0,
+ DEST_DEFAULT_HIGHLIGHT = 1 << 1,
+ DEST_DEFAULT_DROP = 1 << 2,
+ DEST_DEFAULT_ALL = 0x07
+};
+
+/** @ingroup gtkmmEnums */
+inline DestDefaults operator|(DestDefaults lhs, DestDefaults rhs)
+ { return static_cast<DestDefaults>(static_cast<unsigned>(lhs) | static_cast<unsigned>(rhs)); }
+
+/** @ingroup gtkmmEnums */
+inline DestDefaults operator&(DestDefaults lhs, DestDefaults rhs)
+ { return static_cast<DestDefaults>(static_cast<unsigned>(lhs) & static_cast<unsigned>(rhs)); }
+
+/** @ingroup gtkmmEnums */
+inline DestDefaults operator^(DestDefaults lhs, DestDefaults rhs)
+ { return static_cast<DestDefaults>(static_cast<unsigned>(lhs) ^ static_cast<unsigned>(rhs)); }
+
+/** @ingroup gtkmmEnums */
+inline DestDefaults operator~(DestDefaults flags)
+ { return static_cast<DestDefaults>(~static_cast<unsigned>(flags)); }
+
+/** @ingroup gtkmmEnums */
+inline DestDefaults& operator|=(DestDefaults& lhs, DestDefaults rhs)
+ { return (lhs = static_cast<DestDefaults>(static_cast<unsigned>(lhs) | static_cast<unsigned>(rhs))); }
+
+/** @ingroup gtkmmEnums */
+inline DestDefaults& operator&=(DestDefaults& lhs, DestDefaults rhs)
+ { return (lhs = static_cast<DestDefaults>(static_cast<unsigned>(lhs) & static_cast<unsigned>(rhs))); }
+
+/** @ingroup gtkmmEnums */
+inline DestDefaults& operator^=(DestDefaults& lhs, DestDefaults rhs)
+ { return (lhs = static_cast<DestDefaults>(static_cast<unsigned>(lhs) ^ static_cast<unsigned>(rhs))); }
+
+} // namespace Gtk
+
+
+#ifndef DOXYGEN_SHOULD_SKIP_THIS
+namespace Glib
+{
+
+template <>
+class Value<Gtk::DestDefaults> : public Glib::Value_Flags<Gtk::DestDefaults>
+{
+public:
+ static GType value_type() G_GNUC_CONST;
+};
+
+} // namespace Glib
+#endif /* DOXYGEN_SHOULD_SKIP_THIS */
+
+
+namespace Gtk
+{
+
+/**
+ * @ingroup gtkmmEnums
+ * @par Bitwise operators:
+ * <tt>%WidgetFlags operator|(WidgetFlags, WidgetFlags)</tt><br>
+ * <tt>%WidgetFlags operator&(WidgetFlags, WidgetFlags)</tt><br>
+ * <tt>%WidgetFlags operator^(WidgetFlags, WidgetFlags)</tt><br>
+ * <tt>%WidgetFlags operator~(WidgetFlags)</tt><br>
+ * <tt>%WidgetFlags& operator|=(WidgetFlags&, WidgetFlags)</tt><br>
+ * <tt>%WidgetFlags& operator&=(WidgetFlags&, WidgetFlags)</tt><br>
+ * <tt>%WidgetFlags& operator^=(WidgetFlags&, WidgetFlags)</tt><br>
+ */
+enum WidgetFlags
+{
+ TOPLEVEL = 1 << 4,
+ NO_WINDOW = 1 << 5,
+ REALIZED = 1 << 6,
+ MAPPED = 1 << 7,
+ VISIBLE = 1 << 8,
+ SENSITIVE = 1 << 9,
+ PARENT_SENSITIVE = 1 << 10,
+ CAN_FOCUS = 1 << 11,
+ HAS_FOCUS = 1 << 12,
+ CAN_DEFAULT = 1 << 13,
+ HAS_DEFAULT = 1 << 14,
+ HAS_GRAB = 1 << 15,
+ RC_STYLE = 1 << 16,
+ COMPOSITE_CHILD = 1 << 17,
+ NO_REPARENT = 1 << 18,
+ APP_PAINTABLE = 1 << 19,
+ RECEIVES_DEFAULT = 1 << 20,
+ DOUBLE_BUFFERED = 1 << 21,
+ NO_SHOW_ALL = 1 << 22
+};
+
+/** @ingroup gtkmmEnums */
+inline WidgetFlags operator|(WidgetFlags lhs, WidgetFlags rhs)
+ { return static_cast<WidgetFlags>(static_cast<unsigned>(lhs) | static_cast<unsigned>(rhs)); }
+
+/** @ingroup gtkmmEnums */
+inline WidgetFlags operator&(WidgetFlags lhs, WidgetFlags rhs)
+ { return static_cast<WidgetFlags>(static_cast<unsigned>(lhs) & static_cast<unsigned>(rhs)); }
+
+/** @ingroup gtkmmEnums */
+inline WidgetFlags operator^(WidgetFlags lhs, WidgetFlags rhs)
+ { return static_cast<WidgetFlags>(static_cast<unsigned>(lhs) ^ static_cast<unsigned>(rhs)); }
+
+/** @ingroup gtkmmEnums */
+inline WidgetFlags operator~(WidgetFlags flags)
+ { return static_cast<WidgetFlags>(~static_cast<unsigned>(flags)); }
+
+/** @ingroup gtkmmEnums */
+inline WidgetFlags& operator|=(WidgetFlags& lhs, WidgetFlags rhs)
+ { return (lhs = static_cast<WidgetFlags>(static_cast<unsigned>(lhs) | static_cast<unsigned>(rhs))); }
+
+/** @ingroup gtkmmEnums */
+inline WidgetFlags& operator&=(WidgetFlags& lhs, WidgetFlags rhs)
+ { return (lhs = static_cast<WidgetFlags>(static_cast<unsigned>(lhs) & static_cast<unsigned>(rhs))); }
+
+/** @ingroup gtkmmEnums */
+inline WidgetFlags& operator^=(WidgetFlags& lhs, WidgetFlags rhs)
+ { return (lhs = static_cast<WidgetFlags>(static_cast<unsigned>(lhs) ^ static_cast<unsigned>(rhs))); }
+
+} // namespace Gtk
+
+
+#ifndef DOXYGEN_SHOULD_SKIP_THIS
+namespace Glib
+{
+
+template <>
+class Value<Gtk::WidgetFlags> : public Glib::Value_Flags<Gtk::WidgetFlags>
+{
+public:
+ static GType value_type() G_GNUC_CONST;
+};
+
+} // namespace Glib
+#endif /* DOXYGEN_SHOULD_SKIP_THIS */
+
+
+namespace Gtk
+{
+
+/**
+ * @ingroup gtkmmEnums
+ */
+enum WidgetHelpType
+{
+ WIDGET_HELP_TOOLTIP,
+ WIDGET_HELP_WHATS_THIS
+};
+
+} // namespace Gtk
+
+
+#ifndef DOXYGEN_SHOULD_SKIP_THIS
+namespace Glib
+{
+
+template <>
+class Value<Gtk::WidgetHelpType> : public Glib::Value_Enum<Gtk::WidgetHelpType>
+{
+public:
+ static GType value_type() G_GNUC_CONST;
+};
+
+} // namespace Glib
+#endif /* DOXYGEN_SHOULD_SKIP_THIS */
+
+
+namespace Gtk
+{
+
+
+class Style;
+class AccelGroup;
+class Adjustment;
+class Window;
+class Container;
+class Settings;
+
+typedef GtkRequisition Requisition;
+
+// Gtk::Allocation is a typedef of Gdk::Rectangle because GtkAllocation is
+// a typedef of GdkRectangle.
+typedef Gdk::Rectangle Allocation;
+
+
+/** @defgroup Widgets Widgets
+ */
+
+/** Abstract Widget (Base class for all widgets)
+ *
+ * As the base class of all widgets this contains all of the properties
+ * and methods common to all widgets. It is an abstract class that
+ * can not be instantiated.
+ *
+ * Important part of widgets are the *_event signals and virtual methods
+ * that every widget have. Those are events coming directly from gdk and
+ * thus also from XLib. By overriding those virtual methods you can
+ * trap everything a widget can ever do.
+ * In order to capture events from a widget, the event mask must
+ * first be set with ().
+ *
+ * Only widgets with a Gdk::Window on the server side are allowed to
+ * capture events. Widgets in the Gtk::Misc group for example lack
+ * a Gdk::Window.
+ */
+
+class Widget
+: public Object,
+ public Atk::Implementor
+{
+ public:
+#ifndef DOXYGEN_SHOULD_SKIP_THIS
+ typedef Widget CppObjectType;
+ typedef Widget_Class CppClassType;
+ typedef GtkWidget BaseObjectType;
+ typedef GtkWidgetClass BaseClassType;
+#endif /* DOXYGEN_SHOULD_SKIP_THIS */
+
+ virtual ~Widget();
+
+#ifndef DOXYGEN_SHOULD_SKIP_THIS
+
+private:
+ friend class Widget_Class;
+ static CppClassType widget_class_;
+
+ // noncopyable
+ Widget(const Widget&);
+ Widget& operator=(const Widget&);
+
+protected:
+ explicit Widget(const Glib::ConstructParams& construct_params);
+ explicit Widget(GtkWidget* castitem);
+
+#endif /* DOXYGEN_SHOULD_SKIP_THIS */
+
+public:
+#ifndef DOXYGEN_SHOULD_SKIP_THIS
+ static GType get_type() G_GNUC_CONST;
+ static GType get_base_type() G_GNUC_CONST;
+#endif
+
+ ///Provides access to the underlying C GtkObject.
+ GtkWidget* gobj() { return reinterpret_cast<GtkWidget*>(gobject_); }
+
+ ///Provides access to the underlying C GtkObject.
+ const GtkWidget* gobj() const { return reinterpret_cast<GtkWidget*>(gobject_); }
+
+
+public:
+ //C++ methods used to invoke GTK+ virtual functions:
+
+protected:
+ //GTK+ Virtual Functions (override these to change behaviour):
+
+ //Default Signal Handlers::
+ virtual void on_show();
+ virtual void on_hide();
+ virtual void on_map();
+ virtual void on_unmap();
+ virtual void on_realize();
+ virtual void on_unrealize();
+ virtual void on_size_request(Requisition* requisition);
+ virtual void on_size_allocate(Allocation& allocation);
+ virtual void on_state_changed(Gtk::StateType previous_state);
+ virtual void on_parent_changed(Widget* previous_parent);
+ virtual void on_hierarchy_changed(Widget* previous_toplevel);
+ virtual void on_style_changed(const Glib::RefPtr<Style>& previous_style);
+ virtual void on_direction_changed(TextDirection direction);
+ virtual void on_grab_notify(bool was_grabbed);
+ virtual void on_child_notify(GParamSpec* pspec);
+ virtual bool on_mnemonic_activate(bool group_cycling);
+ virtual void on_grab_focus();
+ virtual bool on_focus(DirectionType direction);
+ virtual bool on_event(GdkEvent* event);
+ virtual bool on_button_press_event(GdkEventButton* event);
+ virtual bool on_button_release_event(GdkEventButton* event);
+ virtual bool on_scroll_event(GdkEventScroll* event);
+ virtual bool on_motion_notify_event(GdkEventMotion* event);
+ virtual bool on_delete_event(GdkEventAny* event);
+ virtual bool on_expose_event(GdkEventExpose* event);
+ virtual bool on_key_press_event(GdkEventKey* event);
+ virtual bool on_key_release_event(GdkEventKey* event);
+ virtual bool on_enter_notify_event(GdkEventCrossing* event);
+ virtual bool on_leave_notify_event(GdkEventCrossing* event);
+ virtual bool on_configure_event(GdkEventConfigure* event);
+ virtual bool on_focus_in_event(GdkEventFocus* event);
+ virtual bool on_focus_out_event(GdkEventFocus* event);
+ virtual bool on_map_event(GdkEventAny* event);
+ virtual bool on_unmap_event(GdkEventAny* event);
+ virtual bool on_property_notify_event(GdkEventProperty* event);
+ virtual bool on_selection_clear_event(GdkEventSelection* event);
+ virtual bool on_selection_request_event(GdkEventSelection* event);
+ virtual bool on_selection_notify_event(GdkEventSelection* event);
+ virtual bool on_proximity_in_event(GdkEventProximity* event);
+ virtual bool on_proximity_out_event(GdkEventProximity* event);
+ virtual bool on_visibility_notify_event(GdkEventVisibility* event);
+ virtual bool on_client_event(GdkEventClient* event);
+ virtual bool on_no_expose_event(GdkEventAny* event);
+ virtual bool on_window_state_event(GdkEventWindowState* event);
+ virtual void on_selection_get(SelectionData& selection_data, guint info, guint time);
+ virtual void on_selection_received(const SelectionData& selection_data, guint time);
+ virtual void on_drag_begin(const Glib::RefPtr<Gdk::DragContext>& context);
+ virtual void on_drag_end(const Glib::RefPtr<Gdk::DragContext>& context);
+ virtual void on_drag_data_get(const Glib::RefPtr<Gdk::DragContext>& context, SelectionData& selection_data, guint info, guint time);
+ virtual void on_drag_data_delete(const Glib::RefPtr<Gdk::DragContext>& context);
+ virtual void on_drag_leave(const Glib::RefPtr<Gdk::DragContext>& context, guint time);
+ virtual bool on_drag_motion(const Glib::RefPtr<Gdk::DragContext>& context, int x, int y, guint time);
+ virtual bool on_drag_drop(const Glib::RefPtr<Gdk::DragContext>& context, int x, int y, guint time);
+ virtual void on_drag_data_received(const Glib::RefPtr<Gdk::DragContext>& context, int x, int y, const SelectionData& selection_data, guint info, guint time);
+ virtual Glib::RefPtr<Atk::Object> on_get_accessible();
+ virtual void on_screen_changed(const Glib::RefPtr<Gdk::Screen>& previous_screen);
+
+
+private:
+
+
+public:
+ friend class Main;
+
+
+ /** For widgets that support scrolling, sets the scroll adjustments and
+ * returns <tt>true</tt>. For widgets that don't support scrolling, does
+ * nothing and returns <tt>false</tt>. Widgets that don't support scrolling
+ * can be scrolled by placing them in a Gtk::Viewport, which does
+ * support scrolling.
+ * @param hadjustment An adjustment for horizontal scrolling, or <tt>0</tt>.
+ * @param vadjustment An adjustment for vertical scrolling, or <tt>0</tt>.
+ * @return <tt>true</tt> if the widget supports scrolling.
+ */
+ bool set_scroll_adjustments(Adjustment& hadjustment, Adjustment& vadjustment);
+
+
+ /** Flags a widget to be displayed. Any widget that isn't shown will
+ * not appear on the screen. If you want to show all the widgets in a
+ * container, it's easier to call show_all() on the
+ * container, instead of individually showing the widgets.
+ *
+ * Remember that you have to show the containers containing a widget,
+ * in addition to the widget itself, before it will appear onscreen.
+ *
+ * When a toplevel container is shown, it is immediately realized and
+ * mapped; other shown widgets are realized and mapped when their
+ * toplevel container is realized and mapped.
+ */
+ void show();
+
+ /** Shows a widget. If the widget is an unmapped toplevel widget
+ * (i.e. a Gtk::Window that has not yet been shown), enter the main
+ * loop and wait for the window to actually be mapped. Be careful;
+ * because the main loop is running, anything can happen during
+ * this function.
+ */
+ void show_now();
+
+ /** Reverses the effects of show(), causing the widget to be
+ * hidden (invisible to the user).
+ */
+ void hide();
+
+
+ /** Recursively shows a widget, and any child widgets (if the widget is
+ * a container).
+ */
+ void show_all();
+
+
+ /** Recursively hides a widget and any child widgets.
+ */
+ void hide_all();
+
+
+/* QUEUE DRAWS */
+
+
+ /** Equivalent to calling queue_draw_area() for the
+ * entire area of a widget.
+ */
+ void queue_draw();
+
+ /** Invalidates the rectangular area of @a widget defined by @a x , @a y ,
+ * @a width and @a height by calling gdk_window_invalidate_rect() on the
+ * widget's window and all its child windows. Once the main loop
+ * becomes idle (after the current batch of events has been processed,
+ * roughly), the window will receive expose events for the union of
+ * all regions that have been invalidated.
+ *
+ * Normally you would only use this function in widget
+ * implementations. You might also use it, or
+ * gdk_window_invalidate_rect() directly, to schedule a redraw of a
+ * Gtk::DrawingArea or some portion thereof.
+ *
+ * Frequently you can just call gdk_window_invalidate_rect() or
+ * gdk_window_invalidate_region() instead of this function. Those
+ * functions will invalidate only a single window, instead of the
+ * widget and all its children.
+ *
+ * The advantage of adding to the invalidated region compared to
+ * simply drawing immediately is efficiency; using an invalid region
+ * ensures that you only have to redraw one time.
+ * @param x X coordinate of upper-left corner of rectangle to redraw.
+ * @param y Y coordinate of upper-left corner of rectangle to redraw.
+ * @param width Width of region to draw.
+ * @param height Height of region to draw.
+ */
+ void queue_draw_area(int x, int y, int width, int height);
+
+ /** This function is only for use in widget implementations.
+ * Flags a widget to have its size renegotiated; should
+ * be called when a widget for some reason has a new size request.
+ * For example, when you change the text in a Gtk::Label, Gtk::Label
+ * queues a resize to ensure there's enough space for the new text.
+ */
+ void queue_resize();
+
+ /** This function is typically used when implementing a Gtk::Container
+ * subclass. Obtains the preferred size of a widget. The container
+ * uses this information to arrange its child widgets and decide what
+ * size allocations to give them with size_allocate().
+ *
+ * You can also call this function from an application, with some
+ * caveats. Most notably, getting a size request requires the widget
+ * to be associated with a screen, because font information may be
+ * needed. Multihead-aware applications should keep this in mind.
+ *
+ * Also remember that the size request is not necessarily the size
+ * a widget will actually be allocated.
+ *
+ * See also get_child_requisition().
+ * @result A Gtk::Requisition.
+ */
+ Requisition size_request() const;
+
+
+ //Deprecated, because the Requisition should be an output parameter. This could never have been used.
+
+ /** This function is typically used when implementing a Gtk::Container
+ * subclass. Obtains the preferred size of a widget. The container
+ * uses this information to arrange its child widgets and decide what
+ * size allocations to give them with size_allocate().
+ *
+ * You can also call this function from an application, with some
+ * caveats. Most notably, getting a size request requires the widget
+ * to be associated with a screen, because font information may be
+ * needed. Multihead-aware applications should keep this in mind.
+ *
+ * Also remember that the size request is not necessarily the size
+ * a widget will actually be allocated.
+ *
+ * See also get_child_requisition().
+ * @param requisition A Gtk::Requisition to be filled in.
+ */
+ void size_request(const Requisition& requisition);
+
+
+ /** This function is only used by Gtk::Container subclasses, to assign a size
+ * and position to their child widgets.
+ * @param allocation Position and size to be allocated to @a widget .
+ */
+ void size_allocate(const Allocation& allocation);
+
+
+ /** Installs an accelerator for this @a widget in @a accel_group that causes
+ * @a accel_signal to be emitted if the accelerator is activated.
+ * The @a accel_group needs to be added to the widget's toplevel via
+ * Gtk::Window::add_accel_group(), and the signal must be of type G::RUN_ACTION.
+ * Accelerators added through this function are not user changeable during
+ * runtime. If you want to support accelerators that can be changed by the
+ * user, use gtk_accel_map_add_entry() and set_accel_path() or
+ * Gtk::MenuItem::set_accel_path() instead.
+ * @param accel_signal Widget signal to emit on accelerator activation.
+ * @param accel_group Accel group for this widget, added to its toplevel.
+ * @param accel_key GDK keyval of the accelerator.
+ * @param accel_mods Modifier key combination of the accelerator.
+ * @param accel_flags Flag accelerators, e.g. Gtk::ACCEL_VISIBLE.
+ */
+ void add_accelerator(const Glib::ustring& accel_signal, const Glib::RefPtr<AccelGroup>& accel_group,
+ guint accel_key, Gdk::ModifierType accel_mods, AccelFlags accel_flags);
+
+
+ /** Removes an accelerator from @a widget , previously installed with
+ * add_accelerator().
+ * @param accel_group Accel group for this widget.
+ * @param accel_key GDK keyval of the accelerator.
+ * @param accel_mods Modifier key combination of the accelerator.
+ * @return Whether an accelerator was installed and could be removed.
+ */
+ bool remove_accelerator(const Glib::RefPtr<AccelGroup>& accel_group,
+ guint accel_key, Gdk::ModifierType accel_mods);
+
+ /** Given an accelerator group, @a accel_group , and an accelerator path,
+ * @a accel_path , sets up an accelerator in @a accel_group so whenever the
+ * key binding that is defined for @a accel_path is pressed, @a widget
+ * will be activated. This removes any accelerators (for any
+ * accelerator group) installed by previous calls to
+ * set_accel_path(). Associating accelerators with
+ * paths allows them to be modified by the user and the modifications
+ * to be saved for future use. (See gtk_accel_map_save().)
+ *
+ * This function is a low level function that would most likely
+ * be used by a menu creation system like Gtk::ItemFactory. If you
+ * use Gtk::ItemFactory, setting up accelerator paths will be done
+ * automatically.
+ *
+ * Even when you you aren't using Gtk::ItemFactory, if you only want to
+ * set up accelerators on menu items Gtk::MenuItem::set_accel_path()
+ * provides a somewhat more convenient interface.
+ * @param accel_path Path used to look up the the accelerator.
+ * @param accel_group A Gtk::AccelGroup.
+ */
+ void set_accel_path(const Glib::ustring& accel_path,
+ const Glib::RefPtr<AccelGroup>& accel_group);
+
+ //GList* gtk_widget_list_accel_closures();
+
+ //TODO: Or maybe it is useless: gboolean gtk_widget_can_activate_accel(GtkWidget *widget, guint signal_id)
+
+
+ bool mnemonic_activate(bool group_cycling);
+
+ //TODO: Use C++ type
+
+ /** Rarely-used function. This function is used to emit
+ * the event signals on a widget (those signals should never
+ * be emitted without using this function to do so).
+ * If you want to synthesize an event though, don't use this function;
+ * instead, use gtk_main_do_event() so the event will behave as if
+ * it were in the event queue. Don't synthesize expose events; instead,
+ * use gdk_window_invalidate_rect() to invalidate a region of the
+ * window.
+ * @param event A Gdk::Event.
+ * @return Return from the event signal emission (<tt>true</tt> if the event was handled).
+ */
+ bool event(GdkEvent* event);
+
+ /** Very rarely-used function. This function is used to emit
+ * an expose event signals on a widget. This function is not
+ * normally used directly. The only time it is used is when
+ * propagating an expose event to a child NO_WINDOW widget, and
+ * that is normally done using Gtk::Container::propagate_expose().
+ *
+ * If you want to force an area of a window to be redrawn,
+ * use gdk_window_invalidate_rect() or gdk_window_invalidate_region().
+ * To cause the redraw to be done immediately, follow that call
+ * with a call to gdk_window_process_updates().
+ * @param event A expose Gdk::Event.
+ * @return Return from the event signal emission (<tt>true</tt> if the event was handled).
+ */
+ int send_expose(GdkEvent* event);
+
+ /** For widgets that can be "activated" (buttons, menu items, etc.)
+ * this function activates them. Activation is what happens when you
+ * press Enter on a widget during key navigation. If @a widget isn't
+ * activatable, the function returns <tt>false</tt>.
+ * @return <tt>true</tt> if the widget was activatable.
+ */
+ bool activate();
+
+
+ /** Moves a widget from one Gtk::Container to another, handling reference
+ * count issues to avoid destroying the widget.
+ * @param new_parent A Gtk::Container to move the widget into.
+ */
+ void reparent(Widget & new_parent);
+
+ bool intersect(const Gdk::Rectangle& area) const;
+
+ /** Computes the intersection of a @a widget 's area and @a area , storing
+ * the intersection in @a intersection , and returns <tt>true</tt> if there was
+ * an intersection. @a intersection may be <tt>0</tt> if you're only
+ * interested in whether there was an intersection.
+ * @param area A rectangle.
+ * @param intersection Rectangle to store intersection of @a widget and @a area .
+ * @return <tt>true</tt> if there was an intersection.
+ */
+ bool intersect(const Gdk::Rectangle& area, Gdk::Rectangle& intersection) const;
+
+
+ /** Computes the intersection of a @a widget 's area and @a region , returning
+ * the intersection. The result may be empty, use gdk_region_empty() to
+ * check.
+ * @param region A Gdk::Region, in the same coordinate system as
+ * @a widget -&gt;allocation. That is, relative to @a widget -&gt;window
+ * for NO_WINDOW widgets; relative to the parent window
+ * of @a widget -&gt;window for widgets with their own window.
+ * @return A newly allocated region holding the intersection of @a widget
+ * and @a region . The coordinates of the return value are
+ * relative to @a widget -&gt;window for NO_WINDOW widgets, and
+ * relative to the parent window of @a widget -&gt;window for
+ * widgets with their own window.
+ */
+ Gdk::Region region_intersect(const Gdk::Region& region) const;
+
+
+ /** Stops emission of "child-notify" signals on @a widget . The signals are
+ * queued until thaw_child_notify() is called on @a widget .
+ *
+ * This is the analogue of Glib::object_freeze_notify() for child properties.
+ */
+ void freeze_child_notify();
+
+ /** Emits a "child-notify" signal for the
+ * child property @a child_property
+ * on @a widget .
+ *
+ * This is the analogue of Glib::object_notify() for child properties.
+ * @param child_property The name of a child property installed on the
+ * class of @a widget &lt;!-- --&gt;'s parent.
+ */
+ void child_notify(const Glib::ustring& child_property);
+
+ /** Reverts the effect of a previous call to freeze_child_notify().
+ * This causes all queued "child-notify" signals on @a widget to be emitted.
+ */
+ void thaw_child_notify();
+
+
+ /** Determines if the widget is the focus widget within its
+ * toplevel. (This does not mean that the HAS_FOCUS flag is
+ * necessarily set; HAS_FOCUS will only be set if the
+ * toplevel widget additionally has the global input focus.)
+ * @return <tt>true</tt> if the widget is the focus widget.
+ */
+ bool is_focus() const;
+
+ /** Causes @a widget to have the keyboard focus for the Gtk::Window it's
+ * inside. @a widget must be a focusable widget, such as a Gtk::Entry;
+ * something like Gtk::Frame won't work. (More precisely, it must have the
+ * Gtk::CAN_FOCUS flag set.)
+ */
+ void grab_focus();
+
+ /** Causes @a widget to become the default widget. @a widget must have the
+ * Gtk::CAN_DEFAULT flag set; typically you have to set this flag
+ * yourself by calling <tt>GTK_WIDGET_SET_FLAGS ( @a widget ,
+ * GTK_CAN_DEFAULT)</tt>. The default widget is activated when the user
+ * presses Enter in a window. Default widgets must be activatable,
+ * that is, activate() should affect them.
+ */
+ void grab_default();
+
+ /** Block events to everything else than this widget and its children. This
+ * way you can get modal behaviour (usually not recommended). One practical
+ * example could be when implementing a key-binding widget that needs
+ * exclusive access to the key combination that the user presses next.
+ *
+ * Calls to add_modal_grab should be paired with calls to remove_modal_grab.
+ */
+ void add_modal_grab();
+
+ /** Remove the modal grab of the widget in case it was previously grabbed.
+ */
+ void remove_modal_grab();
+
+ /** Retrieve the widget which is currently grabbing all events.
+ */
+ static Widget* get_current_modal_grab();
+
+
+ /** Widgets can be named, which allows you to refer to them from a
+ * gtkrc file. You can apply a style to widgets with a particular name
+ * in the gtkrc file. See the documentation for gtkrc files (on the
+ * same page as the docs for Gtk::RcStyle).
+ *
+ * Note that widget names are separated by periods in paths (see
+ * path()), so names with embedded periods may cause confusion.
+ * @param name Name for the widget.
+ */
+ void set_name(const Glib::ustring& name);
+ void unset_name();
+
+ /** Retrieves the name of a widget. See set_name() for the
+ * significance of widget names.
+ * @return Name of the widget. This string is owned by GTK+ and
+ * should not be modified or freed.
+ */
+ Glib::ustring get_name() const;
+
+
+ /** This function is for use in widget implementations. Sets the state
+ * of a widget (insensitive, prelighted, etc.) Usually you should set
+ * the state using wrapper functions such as set_sensitive().
+ * @param state New state for @a widget .
+ */
+ void set_state(Gtk::StateType state);
+
+ /** Sets the sensitivity of a widget. A widget is sensitive if the user
+ * can interact with it. Insensitive widgets are "grayed out" and the
+ * user can't interact with them. Insensitive widgets are known as
+ * "inactive", "disabled", or "ghosted" in some other toolkits.
+ * @param sensitive <tt>true</tt> to make the widget sensitive.
+ */
+ void set_sensitive(bool sensitive = true);
+
+ void set_app_paintable(bool app_paintable = true);
+
+ /** Widgets are double buffered by default; you can use this function
+ * to turn off the buffering. "Double buffered" simply means that
+ * gdk_window_begin_paint_region() and gdk_window_end_paint() are called
+ * automatically around expose events sent to the
+ * widget. gdk_window_begin_paint() diverts all drawing to a widget's
+ * window to an offscreen buffer, and gdk_window_end_paint() draws the
+ * buffer to the screen. The result is that users see the window
+ * update in one smooth step, and don't see individual graphics
+ * primitives being rendered.
+ *
+ * In very simple terms, double buffered widgets don't flicker,
+ * so you would only use this function to turn off double buffering
+ * if you had special needs and really knew what you were doing.
+ * @param double_buffered <tt>true</tt> to double-buffer a widget.
+ */
+ void set_double_buffered(bool double_buffered = true);
+
+
+ /** Sets whether a when a widgets size allocation changes, the entire
+ * widget is queued for drawing. By default, this setting is <tt>true</tt> and
+ * the entire widget is redrawn on every size change. If your widget
+ * leaves the upper left unchanged when made bigger, turning this
+ * setting on will improve performance.
+ *
+ * Note that for NO_WINDOW widgets setting this flag to <tt>false</tt> turns
+ * off all allocation on resizing: the widget will not even redraw if
+ * its position changes; this is to allow containers that don't draw
+ * anything to avoid excess invalidations. If you set this flag on a
+ * NO_WINDOW widget that <em>does</em> draw on @a widget -&gt;window,
+ * you are responsible for invalidating both the old and new allocation
+ * of the widget when the widget is moved and responsible for invalidating
+ * regions newly when the widget increases size.
+ * @param redraw_on_allocate If <tt>true</tt>, the entire widget will be redrawn
+ * when it is allocated to a new size. Otherwise, only the
+ * new portion of the widget will be redrawn.
+ */
+ void set_redraw_on_allocate(bool redraw_on_allocate = true);
+
+
+ /** Sets whether @a widget should be mapped along with its when its parent
+ * is mapped and @a widget has been shown with show().
+ *
+ * The child visibility can be set for widget before it is added to
+ * a container with set_parent(), to avoid mapping
+ * children unnecessary before immediately unmapping them. However
+ * it will be reset to its default state of <tt>true</tt> when the widget
+ * is removed from a container.
+ *
+ * Note that changing the child visibility of a widget does not
+ * queue a resize on the widget. Most of the time, the size of
+ * a widget is computed from all visible children, whether or
+ * not they are mapped. If this is not the case, the container
+ * can queue a resize itself.
+ *
+ * This function is only useful for container implementations and
+ * never should be called by an application.
+ * @param is_visible If <tt>true</tt>, @a widget should be mapped along with its parent.
+ */
+ void set_child_visible(bool is_visible = true);
+
+ /** Gets the value set with set_child_visible().
+ * If you feel a need to use this function, your code probably
+ * needs reorganization.
+ *
+ * This function is only useful for container implementations and
+ * never should be called by an application.
+ * @return <tt>true</tt> if the widget is mapped with the parent.
+ */
+ bool get_child_visible() const;
+
+
+ /** Returns the parent container of @a widget .
+ * @return The parent container of @a widget , or <tt>0</tt>.
+ */
+ Container* get_parent();
+
+ /** Returns the parent container of @a widget .
+ * @return The parent container of @a widget , or <tt>0</tt>.
+ */
+ const Container* get_parent() const;
+
+
+ /** Gets @a widget 's parent window.
+ * @return The parent window of @a widget .
+ */
+ Glib::RefPtr<Gdk::Window> get_parent_window();
+
+ /** Gets @a widget 's parent window.
+ * @return The parent window of @a widget .
+ */
+ Glib::RefPtr<const Gdk::Window> get_parent_window() const;
+
+ /** Sets a non default parent window for @a widget .
+ * @param parent_window The new parent window.
+ */
+ void set_parent_window(const Glib::RefPtr<const Gdk::Window>& parent_window);
+
+
+ /** This function is used by custom widget implementations; if you're
+ * writing an app, you'd use grab_focus() to move the focus
+ * to a particular widget, and Gtk::Container::set_focus_chain() to
+ * change the focus tab order. So you may want to investigate those
+ * functions instead.
+ *
+ * child_focus() is called by containers as the user moves
+ * around the window using keyboard shortcuts. @a direction indicates
+ * what kind of motion is taking place (up, down, left, right, tab
+ * forward, tab backward). child_focus() invokes the
+ * "focus" signal on Gtk::Widget; widgets override the default handler
+ * for this signal in order to implement appropriate focus behavior.
+ *
+ * The "focus" default handler for a widget should return <tt>true</tt> if
+ * moving in @a direction left the focus on a focusable location inside
+ * that widget, and <tt>false</tt> if moving in @a direction moved the focus
+ * outside the widget. If returning <tt>true</tt>, widgets normally
+ * call grab_focus() to place the focus accordingly;
+ * if returning <tt>false</tt>, they don't modify the current focus location.
+ *
+ * This function replaces gtk_container_focus() from GTK+ 1.2. It was
+ * necessary to check that the child was visible, sensitive, and
+ * focusable before calling
+ * gtk_container_focus(). child_focus() returns <tt>false</tt> if
+ * the widget is not currently in a focusable state, so there's no
+ * need for those checks.
+ * @param direction Direction of focus movement.
+ * @return <tt>true</tt> if focus ended up inside @a widget .
+ */
+ bool child_focus(DirectionType direction);
+
+
+ /** Sets the minimum size of a widget; that is, the widget's size
+ * request will be @a width by @a height . You can use this function to
+ * force a widget to be either larger or smaller than it normally
+ * would be.
+ *
+ * In most cases, Gtk::Window::set_default_size() is a better choice for
+ * toplevel windows than this function; setting the default size will
+ * still allow users to shrink the window. Setting the size request
+ * will force them to leave the window at least as large as the size
+ * request. When dealing with window sizes,
+ * Gtk::Window::set_geometry_hints() can be a useful function as well.
+ *
+ * Note the inherent danger of setting any fixed size - themes,
+ * translations into other languages, different fonts, and user action
+ * can all change the appropriate size for a given widget. So, it's
+ * basically impossible to hardcode a size that will always be
+ * correct.
+ *
+ * The size request of a widget is the smallest size a widget can
+ * accept while still functioning well and drawing itself correctly.
+ * However in some strange cases a widget may be allocated less than
+ * its requested size, and in many cases a widget may be allocated more
+ * space than it requested.
+ *
+ * If the size request in a given direction is -1 (unset), then
+ * the "natural" size request of the widget will be used instead.
+ *
+ * Widgets can't actually be allocated a size less than 1 by 1, but
+ * you can pass 0,0 to this function to mean "as small as possible."
+ * @param width Width @a widget should request, or -1 to unset.
+ * @param height Height @a widget should request, or -1 to unset.
+ */
+ void set_size_request(int width = -1, int height = -1);
+
+ /** Gets the size request that was explicitly set for the widget using
+ * set_size_request(). A value of -1 stored in @a width or
+ * @a height indicates that that dimension has not been set explicitly
+ * and the natural requisition of the widget will be used intead. See
+ * set_size_request(). To get the size a widget will
+ * actually use, call size_request() instead of
+ * this function.
+ * @param width Return location for width, or <tt>0</tt>.
+ * @param height Return location for height, or <tt>0</tt>.
+ */
+ void get_size_request(int& width, int& height) const;
+
+
+ /** Sets the event mask (see Gdk::EventMask) for a widget. The event
+ * mask determines which events a widget will receive. Keep in mind
+ * that different widgets have different default event masks, and by
+ * changing the event mask you may disrupt a widget's functionality,
+ * so be careful. This function must be called while a widget is
+ * unrealized. Consider add_events() for widgets that are
+ * already realized, or if you want to preserve the existing event
+ * mask. This function can't be used with Gtk::NO_WINDOW widgets;
+ * to get events on those widgets, place them inside a Gtk::EventBox
+ * and receive events on the event box.
+ * @param events Event mask.
+ */
+ void set_events(Gdk::EventMask events);
+
+ /** Adds the events in the bitfield @a events to the event mask for
+ * @a widget . See set_events() for details.
+ * @param events An event mask, see Gdk::EventMask.
+ */
+ void add_events(Gdk::EventMask events);
+
+ /** Sets the extension events mask to @a mode . See Gdk::ExtensionMode
+ * and gdk_input_set_extension_events().
+ * @param mode Bitfield of extension events to receive.
+ */
+ void set_extension_events(Gdk::ExtensionMode mode);
+
+
+ /** Retrieves the extension events the widget will receive; see
+ * gdk_input_set_extension_events().
+ * @return Extension events for @a widget .
+ */
+ Gdk::ExtensionMode get_extension_events() const;
+
+
+ /** This function returns the topmost widget in the container hierarchy
+ * @a widget is a part of. If @a widget has no parent widgets, it will be
+ * returned as the topmost widget. No reference will be added to the
+ * returned widget; it should not be unreferenced.
+ *
+ * Note the difference in behavior vs. get_ancestor();
+ * <tt>gtk_widget_get_ancestor (widget, GTK_TYPE_WINDOW)</tt>
+ * would return
+ * <tt>0</tt> if @a widget wasn't inside a toplevel window, and if the
+ * window was inside a Gtk::Window-derived widget which was in turn
+ * inside the toplevel Gtk::Window. While the second case may
+ * seem unlikely, it actually happens when a Gtk::Plug is embedded
+ * inside a Gtk::Socket within the same application.
+ *
+ * To reliably find the toplevel Gtk::Window, use
+ * get_toplevel() and check if the T::OPLEVEL flags
+ * is set on the result.
+ * @code
+ * GtkWidget *toplevel = gtk_widget_get_toplevel (widget);
+ * if (GTK_WIDGET_TOPLEVEL (toplevel))
+ * {
+ * [ Perform action on toplevel. ]
+ * }
+ * @endcode
+ * @return The topmost ancestor of @a widget , or @a widget itself if there's no ancestor.
+ */
+ Container* get_toplevel();
+
+ /** This function returns the topmost widget in the container hierarchy
+ * @a widget is a part of. If @a widget has no parent widgets, it will be
+ * returned as the topmost widget. No reference will be added to the
+ * returned widget; it should not be unreferenced.
+ *
+ * Note the difference in behavior vs. get_ancestor();
+ * <tt>gtk_widget_get_ancestor (widget, GTK_TYPE_WINDOW)</tt>
+ * would return
+ * <tt>0</tt> if @a widget wasn't inside a toplevel window, and if the
+ * window was inside a Gtk::Window-derived widget which was in turn
+ * inside the toplevel Gtk::Window. While the second case may
+ * seem unlikely, it actually happens when a Gtk::Plug is embedded
+ * inside a Gtk::Socket within the same application.
+ *
+ * To reliably find the toplevel Gtk::Window, use
+ * get_toplevel() and check if the T::OPLEVEL flags
+ * is set on the result.
+ * @code
+ * GtkWidget *toplevel = gtk_widget_get_toplevel (widget);
+ * if (GTK_WIDGET_TOPLEVEL (toplevel))
+ * {
+ * [ Perform action on toplevel. ]
+ * }
+ * @endcode
+ * @return The topmost ancestor of @a widget , or @a widget itself if there's no ancestor.
+ */
+ const Container* get_toplevel() const;
+
+
+ /** Gets the first ancestor of @a widget with type @a widget_type . For example,
+ * <tt>gtk_widget_get_ancestor (widget, GTK_TYPE_BOX)</tt> gets the
+ * first Gtk::Box that's
+ * an ancestor of @a widget . No reference will be added to the returned widget;
+ * it should not be unreferenced. See note about checking for a toplevel
+ * Gtk::Window in the docs for get_toplevel().
+ *
+ * Note that unlike is_ancestor(), get_ancestor()
+ * considers @a widget to be an ancestor of itself.
+ * @param widget_type Ancestor type.
+ * @return The ancestor widget, or <tt>0</tt> if not found.
+ */
+ Widget* get_ancestor(GType widget_type);
+
+ /** Gets the first ancestor of @a widget with type @a widget_type . For example,
+ * <tt>gtk_widget_get_ancestor (widget, GTK_TYPE_BOX)</tt> gets the
+ * first Gtk::Box that's
+ * an ancestor of @a widget . No reference will be added to the returned widget;
+ * it should not be unreferenced. See note about checking for a toplevel
+ * Gtk::Window in the docs for get_toplevel().
+ *
+ * Note that unlike is_ancestor(), get_ancestor()
+ * considers @a widget to be an ancestor of itself.
+ * @param widget_type Ancestor type.
+ * @return The ancestor widget, or <tt>0</tt> if not found.
+ */
+ const Widget* get_ancestor(GType widget_type) const;
+
+
+ /** Gets the colormap that will be used to render @a widget . No reference will
+ * be added to the returned colormap; it should not be unreferenced.
+ * @return The colormap used by @a widget .
+ */
+ Glib::RefPtr<Gdk::Colormap> get_colormap();
+
+
+ /** Gets the visual that will be used to render @a widget .
+ * @return The visual for @a widget .
+ */
+ Glib::RefPtr<Gdk::Visual> get_visual();
+
+
+ /** Get the Gdk::Screen from the toplevel window associated with
+ * this widget. This function can only be called after the widget
+ * has been added to a widget hierarchy with a Gtk::Window
+ * at the top.
+ *
+ * In general, you should only create screen specific
+ * resources when a widget has been realized, and you should
+ * free those resources when the widget is unrealized.
+ * @return The Gdk::Screen for the toplevel for this widget.
+ *
+ * Since: 2.2.
+ */
+ Glib::RefPtr<Gdk::Screen> get_screen();
+
+ /** Get the Gdk::Screen from the toplevel window associated with
+ * this widget. This function can only be called after the widget
+ * has been added to a widget hierarchy with a Gtk::Window
+ * at the top.
+ *
+ * In general, you should only create screen specific
+ * resources when a widget has been realized, and you should
+ * free those resources when the widget is unrealized.
+ * @return The Gdk::Screen for the toplevel for this widget.
+ *
+ * Since: 2.2.
+ */
+ Glib::RefPtr<const Gdk::Screen> get_screen() const;
+
+
+ /** Checks whether there is a Gdk::Screen is associated with
+ * this widget. All toplevel widgets have an associated
+ * screen, and all widgets added into a heirarchy with a toplevel
+ * window at the top.
+ * @return <tt>true</tt> if there is a Gdk::Screen associcated
+ * with the widget.
+ *
+ * Since: 2.2.
+ */
+ bool has_screen() const;
+
+
+ /** Get the Gdk::Display for the toplevel window associated with
+ * this widget. This function can only be called after the widget
+ * has been added to a widget hierarchy with a Gtk::Window at the top.
+ *
+ * In general, you should only create display specific
+ * resources when a widget has been realized, and you should
+ * free those resources when the widget is unrealized.
+ * @return The Gdk::Display for the toplevel for this widget.
+ *
+ * Since: 2.2.
+ */
+ Glib::RefPtr<Gdk::Display> get_display();
+
+ /** Get the Gdk::Display for the toplevel window associated with
+ * this widget. This function can only be called after the widget
+ * has been added to a widget hierarchy with a Gtk::Window at the top.
+ *
+ * In general, you should only create display specific
+ * resources when a widget has been realized, and you should
+ * free those resources when the widget is unrealized.
+ * @return The Gdk::Display for the toplevel for this widget.
+ *
+ * Since: 2.2.
+ */
+ Glib::RefPtr<const Gdk::Display> get_display() const;
+
+
+ /** Get the root window where this widget is located. This function can
+ * only be called after the widget has been added to a widget
+ * heirarchy with Gtk::Window at the top.
+ *
+ * The root window is useful for such purposes as creating a popup
+ * Gdk::Window associated with the window. In general, you should only
+ * create display specific resources when a widget has been realized,
+ * and you should free those resources when the widget is unrealized.
+ * @return The Gdk::Window root window for the toplevel for this widget.
+ *
+ * Since: 2.2.
+ */
+ Glib::RefPtr<Gdk::Window> get_root_window();
+
+ /** Get the root window where this widget is located. This function can
+ * only be called after the widget has been added to a widget
+ * heirarchy with Gtk::Window at the top.
+ *
+ * The root window is useful for such purposes as creating a popup
+ * Gdk::Window associated with the window. In general, you should only
+ * create display specific resources when a widget has been realized,
+ * and you should free those resources when the widget is unrealized.
+ * @return The Gdk::Window root window for the toplevel for this widget.
+ *
+ * Since: 2.2.
+ */
+ Glib::RefPtr<const Gdk::Window> get_root_window() const;
+
+
+ /** Gets the settings object holding the settings (global property
+ * settings, RC file information, etc) used for this widget.
+ *
+ * Note that this function can only be called when the Gtk::Widget
+ * is attached to a toplevel, since the settings object is specific
+ * to a particular Gdk::Screen.
+ * @return The relevant Gtk::Settings object.
+ */
+ Glib::RefPtr<Settings> get_settings();
+
+
+ /** Returns the clipboard object for the given selection to
+ * be used with @a widget . @a widget must have a Gdk::Display
+ * associated with it, so must be attached to a toplevel
+ * window.
+ * @param selection A Gdk::Atom which identifies the clipboard
+ * to use. Gdk::SELECTION_CLIPBOARD gives the
+ * default clipboard. Another common value
+ * is Gdk::SELECTION_PRIMARY, which gives
+ * the primary X selection.
+ * @return The appropriate clipboard object. If no
+ * clipboard already exists, a new one will
+ * be created. Once a clipboard object has
+ * been created, it is persistent for all time.
+ *
+ * Since: 2.2.
+ */
+ Glib::RefPtr<Clipboard> get_clipboard(const Glib::ustring& selection);
+
+ /** Returns the clipboard object for the given selection to
+ * be used with @a widget . @a widget must have a Gdk::Display
+ * associated with it, so must be attached to a toplevel
+ * window.
+ * @param selection A Gdk::Atom which identifies the clipboard
+ * to use. Gdk::SELECTION_CLIPBOARD gives the
+ * default clipboard. Another common value
+ * is Gdk::SELECTION_PRIMARY, which gives
+ * the primary X selection.
+ * @return The appropriate clipboard object. If no
+ * clipboard already exists, a new one will
+ * be created. Once a clipboard object has
+ * been created, it is persistent for all time.
+ *
+ * Since: 2.2.
+ */
+ Glib::RefPtr<const Clipboard> get_clipboard(const Glib::ustring& selection) const;
+
+ //TODO: This probably needs a special conversion to do an extra ref (take_copy=true) for the returned instance:
+
+ Glib::RefPtr<Atk::Object> get_accessible();
+
+
+ /** Sets the colormap for the widget to the given value. Widget must not
+ * have been previously realized. This probably should only be used
+ * from an <tt>init()</tt> function (i.e. from the constructor
+ * for the widget).
+ * @param colormap A colormap.
+ */
+ void set_colormap(const Glib::RefPtr<const Gdk::Colormap> &colormap);
+
+ /** Returns the event mask for the widget (a bitfield containing flags
+ * from the Gdk::EventMask enumeration). These are the events that the widget
+ * will receive.
+ * @return Event mask for @a widget .
+ */
+ Gdk::EventMask get_events() const;
+
+ /** Obtains the location of the mouse pointer in widget coordinates.
+ * Widget coordinates are a bit odd; for historical reasons, they are
+ * defined as @a widget -&gt;window coordinates for widgets that are not
+ * Gtk::NO_WINDOW widgets, and are relative to @a widget -&gt;allocation.x,
+ * @a widget -&gt;allocation.y for widgets that are Gtk::NO_WINDOW widgets.
+ * @param x Return location for the X coordinate, or <tt>0</tt>.
+ * @param y Return location for the Y coordinate, or <tt>0</tt>.
+ */
+ void get_pointer(int &x, int &y) const;
+
+ /** Determines whether @a widget is somewhere inside @a ancestor , possibly with
+ * intermediate containers.
+ * @param ancestor Another Gtk::Widget.
+ * @return <tt>true</tt> if @a ancestor contains @a widget as a child, grandchild, great grandchild, etc.
+ */
+ bool is_ancestor(Widget &ancestor) const;
+
+
+ /** Translate coordinates relative to @a src_widget 's allocation to coordinates
+ * relative to @a dest_widget 's allocations. In order to perform this
+ * operation, both widgets must be realized, and must share a common
+ * toplevel.
+ * @param dest_widget A Gtk::Widget.
+ * @param src_x X position relative to @a src_widget .
+ * @param src_y Y position relative to @a src_widget .
+ * @param dest_x Location to store X position relative to @a dest_widget .
+ * @param dest_y Location to store Y position relative to @a dest_widget .
+ * @return <tt>false</tt> if either widget was not realized, or there
+ * was no common ancestor. In this case, nothing is stored in
+ * * @a dest_x and * @a dest_y . Otherwise <tt>true</tt>.
+ */
+ bool translate_coordinates(Widget& dest_widget,
+ int src_x, int src_y,
+ int& dest_x, int& dest_y);
+
+/* STYLE */
+
+ /** Sets the Gtk::Style for a widget ( @a widget -&gt;style). You probably don't
+ * want to use this function; it interacts badly with themes, because
+ * themes work by replacing the Gtk::Style. Instead, use
+ * modify_style().
+ * @param style A Gtk::Style.
+ */
+ void set_style(const Glib::RefPtr<Style>& style);
+ void unset_style();
+
+
+ /** Ensures that @a widget has a style ( @a widget -&gt;style). Not a very useful
+ * function; most of the time, if you want the style, the widget is
+ * realized, and realized widgets are guaranteed to have a style
+ * already.
+ */
+ void ensure_style();
+
+ /** Simply an accessor function that returns @a widget -&gt;style.
+ * @return The widget's Gtk::Style.
+ */
+ Glib::RefPtr<Style> get_style();
+
+ /** Simply an accessor function that returns @a widget -&gt;style.
+ * @return The widget's Gtk::Style.
+ */
+ Glib::RefPtr<const Style> get_style() const;
+
+ /** Modifies style values on the widget. Modifications made using this
+ * technique take precedence over style values set via an RC file,
+ * however, they will be overriden if a style is explicitely set on
+ * the widget using set_style(). The Gtk::RcStyle structure
+ * is designed so each field can either be set or unset, so it is
+ * possible, using this function, to modify some style values and
+ * leave the others unchanged.
+ *
+ * Note that modifications made with this function are not cumulative
+ * with previous calls to modify_style() or with such
+ * functions as modify_fg(). If you wish to retain
+ * previous values, you must first call get_modifier_style(),
+ * make your modifications to the returned style, then call
+ * modify_style() with that style. On the other hand,
+ * if you first call modify_style(), subsequent calls
+ * to such functions modify_fg() will have a cumulative
+ * effect with the initial modifications.
+ * @param style The Gtk::RcStyle holding the style modifications.
+ */
+ void modify_style(const Glib::RefPtr<RcStyle>& style);
+
+ /** Returns the current modifier style for the widget. (As set by
+ * modify_style().) If no style has previously set, a new
+ * Gtk::RcStyle will be created with all values unset, and set as the
+ * modifier style for the widget. If you make changes to this rc
+ * style, you must call modify_style(), passing in the
+ * returned rc style, to make sure that your changes take effect.
+ *
+ * Caution: passing the style back to modify_style() will
+ * normally end up destroying it, because modify_style() copies
+ * the passed-in style and sets the copy as the new modifier style,
+ * thus dropping any reference to the old modifier style. Add a reference
+ * to the modifier style if you want to keep it alive.
+ * @return The modifier style for the widget. This rc style is
+ * owned by the widget. If you want to keep a pointer to value this
+ * around, you must add a refcount using Gtk::RcStyle::ref().
+ */
+ Glib::RefPtr<RcStyle> get_modifier_style();
+
+ /** Returns the current modifier style for the widget. (As set by
+ * modify_style().) If no style has previously set, a new
+ * Gtk::RcStyle will be created with all values unset, and set as the
+ * modifier style for the widget. If you make changes to this rc
+ * style, you must call modify_style(), passing in the
+ * returned rc style, to make sure that your changes take effect.
+ *
+ * Caution: passing the style back to modify_style() will
+ * normally end up destroying it, because modify_style() copies
+ * the passed-in style and sets the copy as the new modifier style,
+ * thus dropping any reference to the old modifier style. Add a reference
+ * to the modifier style if you want to keep it alive.
+ * @return The modifier style for the widget. This rc style is
+ * owned by the widget. If you want to keep a pointer to value this
+ * around, you must add a refcount using Gtk::RcStyle::ref().
+ */
+ Glib::RefPtr<const RcStyle> get_modifier_style() const;
+
+ // we need custom documentation because modify_* can take a NULL pointer
+ // (which we wrap with unset_*)
+ /** Sets the foreground color for a widget in a particular state.
+ * All other style values are left untouched. See also modify_style() and
+ * unset_fg().
+ *
+ * @param state The state for which to set the foreground color.
+ * @param color The color to assign (does not need to be allocated).
+ */
+
+ /** Sets the foreground color for a widget in a particular state. All
+ * other style values are left untouched. See also
+ * modify_style().
+ * @param state The state for which to set the foreground color.
+ * @param color The color to assign (does not need to be allocated).
+ */
+ void modify_fg(StateType state, const Gdk::Color& color);
+
+
+ /** Sets the background color for a widget in a particular state.
+ * All other style values are left untouched. See also modify_style() and
+ * unset_bg().
+ *
+ * @param state The state for which to set the background color.
+ * @param color The color to assign (does not need to be allocated).
+ */
+
+ /** Sets the background color for a widget in a particular state. All
+ * other style values are left untouched. See also
+ * modify_style().
+ * @param state The state for which to set the background color.
+ * @param color The color to assign (does not need to be allocated).
+ */
+ void modify_bg(StateType state, const Gdk::Color& color);
+
+ // TODO: Document this, and perhaps add unset_bg_pixmap
+ void modify_bg_pixmap(StateType state, const Glib::ustring& pixmap_name);
+
+ /** Sets the text color for a widget in a particular state.
+ * All other style values are left untouched. The text color is the
+ * foreground color used along with the base color (see modify_base() ) for
+ * widgets such as Gtk::Entry and Gtk::TextView. See also modify_style() and
+ * unset_text().
+ *
+ * @param state The state for which to set the text color.
+ * @param color The color to assign (does not need to be allocated).
+ */
+
+ /** Sets the text color for a widget in a particular state. All other
+ * style values are left untouched. The text color is the foreground
+ * color used along with the base color (see modify_base())
+ * for widgets such as Gtk::Entry and Gtk::TextView. See also
+ * modify_style().
+ * @param state The state for which to set the text color.
+ * @param color The color to assign (does not need to be allocated).
+ */
+ void modify_text(StateType state, const Gdk::Color& color);
+
+ /** Sets the base color for a widget in a particular state.
+ * All other style values are left untouched. The base color is the
+ * background color used along with the text color (see modify_text() ) for
+ * widgets such as Gtk::Entry and Gtk::TextView. See also modify_style() and
+ * unset_base().
+ *
+ * @param state The state for which to set the text color.
+ * @param color The color to assign (does not need to be allocated).
+ */
+
+ /** Sets the base color for a widget in a particular state.
+ * All other style values are left untouched. The base color
+ * is the background color used along with the text color
+ * (see modify_text()) for widgets such as Gtk::Entry
+ * and Gtk::TextView. See also modify_style().
+ * @param state The state for which to set the base color.
+ * @param color The color to assign (does not need to be allocated).
+ */
+ void modify_base(StateType state, const Gdk::Color& color);
+
+ /** Sets the font to use for a widget.
+ * All other style values are left untouched. See also modify_style() and
+ * unset_font().
+ */
+
+ /** Sets the font to use for a widget. All other style values are left
+ * untouched. See also modify_style().
+ * @param font_desc The font description to use.
+ */
+ void modify_font(const Pango::FontDescription& font_desc);
+
+ /** Undo the effect of previous calls to modify_fg() for a particular state.
+ * All other style values are left untouched. See also modify_style().
+ */
+ void unset_fg(StateType state);
+
+ /** Undo the effect of previous calls to modify_bg() for a particular state.
+ * All other style values are left untouched. See also modify_style().
+ */
+ void unset_bg(StateType state);
+
+ /** Undo the effect of previous calls to modify_text() for a particular state.
+ * All other style values are left untouched. See also modify_style().
+ */
+ void unset_text(StateType state);
+
+ /** Undo the effect of previous calls to modify_base() for a particular state.
+ * All other style values are left untouched. See also modify_style().
+ */
+ void unset_base(StateType state);
+
+ /** Undo the effect of previous calls to modify_font() for a particular state.
+ * All other style values are left untouched. See also modify_style().
+ */
+ void unset_font();
+
+ //The parameter name is "the_property_name" to avoid a warning because there is a method with the "property_name" name.
+ template <class PropertyType>
+ void get_style_property(const Glib::ustring& the_property_name, PropertyType& value) const;
+
+
+ /** Creates a new Pango::Context with the appropriate colormap,
+ * font description, and base direction for drawing text for
+ * this widget. See also get_pango_context().
+ * @return The new Pango::Context.
+ */
+ Glib::RefPtr<Pango::Context> create_pango_context();
+
+ /** Gets a Pango::Context with the appropriate colormap, font description
+ * and base direction for this widget. Unlike the context returned
+ * by create_pango_context(), this context is owned by
+ * the widget (it can be used until the screen for the widget changes
+ * or the widget is removed from its toplevel), and will be updated to
+ * match any changes to the widget's attributes.
+ *
+ * If you create and keep a Pango::Layout using this context, you must
+ * deal with changes to the context by calling pango_layout_context_changed()
+ * on the layout in response to the ::style-set and ::direction-changed signals
+ * for the widget.
+ * @return The Pango::Context for the widget.
+ */
+ Glib::RefPtr<Pango::Context> get_pango_context();
+
+ /** Creates a new Pango::Layout with the appropriate colormap,
+ * font description, and base direction for drawing text for
+ * this widget.
+ *
+ * If you keep a Pango::Layout created in this way around, in order
+ * notify the layout of changes to the base direction or font of this
+ * widget, you must call pango_layout_context_changed() in response to
+ * the ::style-set and ::direction-changed signals for the widget.
+ * @param text Text to set on the layout (can be <tt>0</tt>).
+ * @return The new Pango::Layout.
+ */
+ Glib::RefPtr<Pango::Layout> create_pango_layout(const Glib::ustring& text);
+
+
+ /** A convenience function that uses the theme engine and RC file
+ * settings for @a widget to look up @a stock_id and render it to
+ * a pixbuf. @a stock_id should be a stock icon ID such as
+ * Gtk::STOCK_OPEN or Gtk::STOCK_OK. @a size should be a size
+ * such as Gtk::ICON_SIZE_MENU. @a detail should be a string that
+ * identifies the widget or code doing the rendering, so that
+ * theme engines can special-case rendering for that widget or code.
+ *
+ * The pixels in the returned Gdk::Pixbuf are shared with the rest of
+ * the application and should not be modified. The pixbuf should be freed
+ * after use with Glib::object_unref().
+ * @param stock_id A stock ID.
+ * @param size A stock size. A size of (GtkIconSize)-1 means render at
+ * the size of the source and don't scale (if there are multiple
+ * source sizes, GTK+ picks one of the available sizes).
+ * @param detail Render detail to pass to theme engine.
+ * @return A new pixbuf, or <tt>0</tt> if the stock ID wasn't known.
+ */
+ Glib::RefPtr<Gdk::Pixbuf> render_icon(const StockID& stock_id, IconSize size, const Glib::ustring& detail = Glib::ustring());
+
+
+ /** Sets a widgets composite name. The widget must be
+ * a composite child of its parent; see push_composite_child().
+ * @param name The name to set.
+ */
+ void set_composite_name(const Glib::ustring& name);
+ void unset_composite_name();
+
+ /** Obtains the composite name of a widget.
+ * @return The composite name of @a widget , or <tt>0</tt> if @a widget is not
+ * a composite child. The string should not be freed when it is no
+ * longer needed.
+ */
+ Glib::ustring get_composite_name() const;
+
+
+ void reset_rc_styles();
+
+
+ // PUSH/POP - these are used to create widgets. Hidden arguments to override the defaults.
+
+ /** Pushes @a cmap onto a global stack of colormaps; the topmost
+ * colormap on the stack will be used to create all widgets.
+ * Remove @a cmap with pop_colormap(). There's little
+ * reason to use this function.
+ * @param cmap A Gdk::Colormap.
+ */
+ static void push_colormap(const Glib::RefPtr<const Gdk::Colormap>& cmap);
+
+ /** Removes a colormap pushed with push_colormap().
+ */
+ static void pop_colormap();
+
+
+ /** Makes all newly-created widgets as composite children until
+ * the corresponding pop_composite_child() call.
+ *
+ * A composite child is a child that's an implementation detail of the
+ * container it's inside and should not be visible to people using the
+ * container. Composite children aren't treated differently by GTK (but
+ * see Gtk::Container::foreach() vs. Gtk::Container::forall()), but e.g. GUI
+ * builders might want to treat them in a different way.
+ *
+ * Here is a simple example:
+ * @code
+ * gtk_widget_push_composite_child (&lt;!-- --&gt;);
+ * scrolled_window->hscrollbar = gtk_hscrollbar_new (hadjustment);
+ * gtk_widget_set_composite_name (scrolled_window->hscrollbar, "hscrollbar");
+ * gtk_widget_pop_composite_child (&lt;!-- --&gt;);
+ * gtk_widget_set_parent (scrolled_window->hscrollbar,
+ * GTK_WIDGET (scrolled_window));
+ * g_object_ref (scrolled_window->hscrollbar);
+ * @endcode
+ */
+ static void push_composite_child();
+
+ /** Cancels the effect of a previous call to push_composite_child().
+ */
+ static void pop_composite_child();
+
+
+/* DEFAULTS */
+
+
+ /** Sets the default colormap to use when creating widgets.
+ * push_colormap() is a better function to use if
+ * you only want to affect a few widgets, rather than all widgets.
+ * @param colormap A Gdk::Colormap.
+ */
+ static void set_default_colormap(const Glib::RefPtr<const Gdk::Colormap>& colormap);
+
+ /** Returns the default style used by all widgets initially.
+ * @return The default style. This Gtk::Style object is owned by GTK+ and
+ * should not be modified or freed.
+ */
+ static Glib::RefPtr<Style> get_default_style();
+
+ /** Obtains the default colormap used to create widgets.
+ * @return Default widget colormap.
+ */
+ static Glib::RefPtr<Gdk::Colormap> get_default_colormap();
+
+ /** Obtains the visual of the default colormap. Not really useful;
+ * used to be useful before gdk_colormap_get_visual() existed.
+ * @return Visual of the default colormap.
+ */
+ static Glib::RefPtr<Gdk::Visual> get_default_visual();
+
+
+/* Directionality of Text */
+
+
+ /** Sets the reading direction on a particular widget. This direction
+ * controls the primary direction for widgets containing text,
+ * and also the direction in which the children of a container are
+ * packed. The ability to set the direction is present in order
+ * so that correct localization into languages with right-to-left
+ * reading directions can be done. Generally, applications will
+ * let the default reading direction present, except for containers
+ * where the containers are arranged in an order that is explicitely
+ * visual rather than logical (such as buttons for text justification).
+ *
+ * If the direction is set to Gtk::TEXT_DIR_NONE, then the value
+ * set by set_default_direction() will be used.
+ * @param dir The new direction.
+ */
+ void set_direction(TextDirection dir);
+
+ /** Gets the reading direction for a particular widget. See
+ * set_direction().
+ * @return The reading direction for the widget.
+ */
+ TextDirection get_direction();
+
+ /** Sets the default reading direction for widgets where the
+ * direction has not been explicitly set by set_direction().
+ * @param dir The new default direction. This cannot be
+ * Gtk::TEXT_DIR_NONE.
+ */
+ static void set_default_direction(TextDirection dir);
+
+ /** Obtains the current default reading direction. See
+ * set_default_direction().
+ * @return The current default direction.
+ */
+ static TextDirection get_default_direction();
+
+
+/* Shape masking */
+
+ /** Sets a shape for this widget's GDK window. This allows for
+ * transparent windows etc., see gdk_window_shape_combine_mask()
+ * for more information.
+ * @param shape_mask Shape to be added.
+ * @param offset_x X position of shape mask with respect to @a window .
+ * @param offset_y Y position of shape mask with respect to @a window .
+ */
+ void shape_combine_mask(const Glib::RefPtr<const Gdk::Bitmap>& shape_mask, int offset_x, int offset_y);
+ void unset_shape_combine_mask();
+
+
+ // must be realized
+
+ /** Recursively resets the shape on this widget and its descendants.
+ */
+ void reset_shapes();
+
+/* Paths */
+ /// Compute a widget's path of the form "GtkWindow.MyLabel"
+ void path(Glib::ustring& path, Glib::ustring& path_reversed);
+ void class_path(Glib::ustring& path, Glib::ustring& path_reversed);
+
+
+ /** Returns a newly allocated list of the widgets, normally labels, for
+ * which this widget is a the target of a mnemonic (see for example,
+ * Gtk::Label::set_mnemonic_widget()).
+ *
+ * The widgets in the list are not individually referenced. If you
+ * want to iterate through the list and perform actions involving
+ * callbacks that might destroy the widgets, you
+ * <em>must</em> call <tt>g_list_foreach (result,
+ * (GFunc)g_object_ref, <tt>0</tt>)</tt> first, and then unref all the
+ * widgets afterwards.
+ * @return The list of mnemonic labels; free this list
+ * with Glib::list_free() when you are done with it.
+ *
+ * Since: 2.4.
+ */
+ Glib::ListHandle<Widget*> list_mnemonic_labels();
+
+ /** Returns a newly allocated list of the widgets, normally labels, for
+ * which this widget is a the target of a mnemonic (see for example,
+ * Gtk::Label::set_mnemonic_widget()).
+ *
+ * The widgets in the list are not individually referenced. If you
+ * want to iterate through the list and perform actions involving
+ * callbacks that might destroy the widgets, you
+ * <em>must</em> call <tt>g_list_foreach (result,
+ * (GFunc)g_object_ref, <tt>0</tt>)</tt> first, and then unref all the
+ * widgets afterwards.
+ * @return The list of mnemonic labels; free this list
+ * with Glib::list_free() when you are done with it.
+ *
+ * Since: 2.4.
+ */
+ Glib::ListHandle<const Widget*> list_mnemonic_labels() const;
+
+ /** Adds a widget to the list of mnemonic labels for
+ * this widget. (See list_mnemonic_labels()). Note the
+ * list of mnemonic labels for the widget is cleared when the
+ * widget is destroyed, so the caller must make sure to update
+ * it's internal state at this point as well, by using a connection
+ * to the ::destroy signal or a weak notifier.
+ *
+ * Since: 2.4
+ * @param label A Gtk::Widget that acts as a mnemonic label for @a widget .
+ */
+ void add_mnemonic_label(Widget& label);
+
+ /** Removes a widget from the list of mnemonic labels for
+ * this widget. (See list_mnemonic_labels()). The widget
+ * must have previously been added to the list with
+ * add_mnemonic_label().
+ *
+ * Since: 2.4
+ * @param label A Gtk::Widget that was previously set as a mnemnic label for
+ * @a widget with add_mnemonic_label().
+ */
+ void remove_mnemonic_label(Widget& label);
+
+
+ //TODO: Should drag_get_data() be const?
+
+ void drag_get_data(const Glib::RefPtr<Gdk::DragContext>& context, Glib::ustring& target, guint32 time);
+
+ void drag_highlight();
+
+ void drag_unhighlight();
+
+ void drag_dest_set(DestDefaults flags = DestDefaults(0), Gdk::DragAction actions = Gdk::DragAction(0));
+ void drag_dest_set(const ArrayHandle_TargetEntry& targets, DestDefaults flags = DEST_DEFAULT_ALL, Gdk::DragAction actions = Gdk::ACTION_COPY);
+
+
+ void drag_dest_set_proxy(const Glib::RefPtr<Gdk::Window>& proxy_window, Gdk::DragProtocol protocol, bool use_coordinates);
+
+ void drag_dest_unset();
+
+ /** Looks for a match between @a context -&gt;targets and the
+ * @a dest_target_list , returning the first matching target, otherwise
+ * returning Gdk::NONE. @a dest_target_list should usually be the return
+ * value from gtk_drag_dest_get_target_list(), but some widgets may
+ * have different valid targets for different parts of the widget; in
+ * that case, they will have to implement a drag_motion handler that
+ * passes the correct target list to this function.
+ * @param context Drag context.
+ * @param target_list List of droppable targets.
+ * @return First target that the source offers and the dest can accept, or Gdk::NONE.
+ */
+ Glib::ustring drag_dest_find_target(const Glib::RefPtr<Gdk::DragContext>& context, const Glib::RefPtr<TargetList>& target_list) const;
+ Glib::ustring drag_dest_find_target(const Glib::RefPtr<Gdk::DragContext>& context) const;
+
+
+ /** Returns the list of targets this widget can accept from
+ * drag-and-drop.
+ * @return The Gtk::TargetList, or <tt>0</tt> if none.
+ */
+ Glib::RefPtr<TargetList> drag_dest_get_target_list();
+
+ /** Returns the list of targets this widget can accept from
+ * drag-and-drop.
+ * @return The Gtk::TargetList, or <tt>0</tt> if none.
+ */
+ Glib::RefPtr<const TargetList> drag_dest_get_target_list() const;
+
+ /** Sets the target types that this widget can accept from drag-and-drop.
+ * The widget must first be made into a drag destination with
+ * gtk_drag_dest_set().
+ * @param target_list List of droppable targets, or <tt>0</tt> for none.
+ */
+ void drag_dest_set_target_list(const Glib::RefPtr<TargetList>& target_list);
+
+
+ /** Add the text targets supported by Gtk::Selection to
+ * the target list of the drag destination. The targets
+ * are added with @a info = 0. If you need another value,
+ * use gtk_target_list_add_text_targets() and
+ * gtk_drag_dest_set_target_list().
+ *
+ * Since: 2.6
+ * @param widget A Gtk::Widget that's a drag destination.
+ */
+ void drag_dest_add_text_targets();
+
+ /** Add the image targets supported by Gtk::Selection to
+ * the target list of the drag destination. The targets
+ * are added with @a info = 0. If you need another value,
+ * use gtk_target_list_add_image_targets() and
+ * gtk_drag_dest_set_target_list().
+ *
+ * Since: 2.6
+ * @param widget A Gtk::Widget that's a drag destination.
+ */
+ void drag_dest_add_image_targets();
+
+ /** Add the URI targets supported by Gtk::Selection to
+ * the target list of the drag destination. The targets
+ * are added with @a info = 0. If you need another value,
+ * use gtk_target_list_add_uri_targets() and
+ * gtk_drag_dest_set_target_list().
+ *
+ * Since: 2.6
+ * @param widget A Gtk::Widget that's a drag destination.
+ */
+ void drag_dest_add_uri_targets();
+
+ void drag_source_set(const ArrayHandle_TargetEntry& targets, Gdk::ModifierType start_button_mask = Gdk::MODIFIER_MASK, Gdk::DragAction actions = Gdk::ACTION_COPY);
+
+
+ void drag_source_unset();
+
+
+ /** Sets the icon that will be used for drags from a particular widget
+ * from a pixmap/mask. GTK+ retains references for the arguments, and
+ * will release them when they are no longer needed.
+ * Use gtk_drag_source_set_icon_pixbuf() instead.
+ * @param colormap The colormap of the icon.
+ * @param pixmap The image data for the icon.
+ * @param mask The transparency mask for an image.
+ */
+ void drag_source_set_icon(const Glib::RefPtr<Gdk::Colormap>& colormap, const Glib::RefPtr<Gdk::Pixmap>& pixmap, const Glib::RefPtr<Gdk::Bitmap>& mask);
+
+ /** Sets the icon that will be used for drags from a particular widget
+ * from a Gdk::Pixbuf. GTK+ retains a reference for @a pixbuf and will
+ * release it when it is no longer needed.
+ * @param pixbuf The Gdk::Pixbuf for the drag icon.
+ */
+ void drag_source_set_icon(const Glib::RefPtr<Gdk::Pixbuf>& pixbuf);
+
+ /** Sets the icon that will be used for drags from a particular source
+ * to a stock icon.
+ * @param stock_id The ID of the stock icon to use.
+ */
+ void drag_source_set_icon(const StockID& stock_id);
+
+
+ /** Add the text targets supported by Gtk::Selection to
+ * the target list of the drag source. The targets
+ * are added with @a info = 0. If you need another value,
+ * use gtk_target_list_add_text_targets() and
+ * gtk_drag_source_set_target_list().
+ *
+ * Since: 2.6
+ * @param widget A Gtk::Widget that's is a drag source.
+ */
+ void drag_source_add_text_targets();
+
+ /** Add the URI targets supported by Gtk::Selection to
+ * the target list of the drag source. The targets
+ * are added with @a info = 0. If you need another value,
+ * use gtk_target_list_add_uri_targets() and
+ * gtk_drag_source_set_target_list().
+ *
+ * Since: 2.6
+ * @param widget A Gtk::Widget that's is a drag source.
+ */
+ void drag_source_add_uri_targets();
+
+ /** Add the writable image targets supported by Gtk::Selection to
+ * the target list of the drag source. The targets
+ * are added with @a info = 0. If you need another value,
+ * use gtk_target_list_add_image_targets() and
+ * gtk_drag_source_set_target_list().
+ *
+ * Since: 2.6
+ * @param widget A Gtk::Widget that's is a drag source.
+ */
+ void drag_source_add_image_targets();
+
+
+ /** Initiates a drag on the source side. The function
+ * only needs to be used when the application is
+ * starting drags itself, and is not needed when
+ * gtk_drag_source_set() is used.
+ * @param targets The targets (data formats) in which the
+ * source can provide the data.
+ * @param actions A bitmask of the allowed drag actions for this drag.
+ * @param button The button the user clicked to start the drag.
+ * @param event The event that triggered the start of the drag.
+ * @return The context for this drag.
+ */
+ Glib::RefPtr<Gdk::DragContext> drag_begin(const Glib::RefPtr<TargetList>& targets, Gdk::DragAction actions, int button, GdkEvent* event);
+
+ /** Checks to see if a mouse drag starting at ( @a start_x , @a start_y ) and ending
+ * at ( @a current_x , @a current_y ) has passed the GTK+ drag threshold, and thus
+ * should trigger the beginning of a drag-and-drop operation.
+ * @param start_x X coordinate of start of drag.
+ * @param start_y Y coordinate of start of drag.
+ * @param current_x Current X coordinate.
+ * @param current_y Current Y coordinate.
+ * @return <tt>true</tt> if the drag threshold has been passed.
+ */
+ bool drag_check_threshold(int start_x, int start_y, int current_x, int current_y);
+
+
+ //These should be a method of Gdk::DragContext, but gdkmm can't depend on gtkmm.
+ static Widget* drag_get_source_widget(const Glib::RefPtr<Gdk::DragContext>& context);
+ void drag_set_as_icon(const Glib::RefPtr<Gdk::DragContext>& context, int hot_x, int hot_y);
+
+
+ /** This function works like queue_resize(), except that the
+ * widget is not invalidated.
+ *
+ * Since: 2.4
+ */
+ void queue_resize_no_redraw();
+
+ /** Returns the current value of the "no_show_all" property, which determines
+ * whether calls to show_all() and hide_all()
+ * will affect this widget.
+ * @return The current value of the "no_show_all" property.
+ *
+ * Since: 2.4.
+ */
+ bool get_no_show_all() const;
+
+ /** Sets the "no_show_all" property, which determines whether calls to
+ * show_all() and hide_all() will affect this widget.
+ *
+ * This is mostly for use in constructing widget hierarchies with externally
+ * controlled visibility, see Gtk::UIManager.
+ *
+ * Since: 2.4
+ * @param no_show_all The new value for the "no_show_all" property.
+ */
+ void set_no_show_all(bool no_show_all = true);
+
+ //Used when implementing containers:
+
+ /** This function is useful only when implementing subclasses of Gtk::Container.
+ * Sets the container as the parent of @a widget , and takes care of
+ * some details such as updating the state and style of the child
+ * to reflect its new location. The opposite function is
+ * unparent().
+ * @param parent Parent container.
+ */
+ void set_parent(Widget& parent);
+
+ /** This function is only for use in widget implementations.
+ * Should be called by implementations of the remove method
+ * on Gtk::Container, to dissociate a child from the container.
+ */
+ void unparent();
+
+ void draw_insertion_cursor(Glib::RefPtr<Gdk::Drawable> drawable, const Gdk::Rectangle& area, const Gdk::Rectangle& location, bool is_primary, TextDirection direction, bool draw_arrow = true);
+
+
+ /* FLAGS */
+
+ //: Returns property {flags.toplevel}.
+ bool is_toplevel() const;
+
+ //: Returns property {flags.nowindow}.
+ bool has_no_window() const;
+
+ //: Returns property {flags.realized}.
+ bool is_realized() const;
+
+ //: Returns property {flags.mapped}.
+ bool is_mapped() const;
+
+ //: Returns property {flags.visible}.
+ bool is_visible() const;
+
+ //: Returns if the widget is ready to be drawn to.
+ // Checks to see if the widget is both visible and mapped which
+ // makes it possible to perform drawing commands on.
+ bool is_drawable() const;
+
+ //: Returns property {flags.sensitive}. You might want to check
+ // is_sensitive instead.
+ bool sensitive() const;
+
+ bool parent_sensitive() const;
+ bool is_sensitive() const;
+ bool can_focus() const;
+ bool has_focus() const;
+ bool can_default() const;
+ bool has_default() const;
+ bool has_grab() const;
+ bool rc_style() const;
+ bool is_composite_child() const;
+ bool app_paintable() const;
+ bool receives_default() const;
+ bool double_buffered() const;
+
+ WidgetFlags get_flags() const;
+ void set_flags(WidgetFlags flags);
+ void unset_flags(WidgetFlags flags);
+
+ int get_width() const;
+ int get_height() const;
+
+ Gtk::StateType get_state() const;
+ Gtk::StateType get_saved_state() const;
+ Requisition get_requisition() const;
+ Allocation get_allocation() const;
+ Glib::RefPtr<Gdk::Window> get_window();
+ Glib::RefPtr<const Gdk::Window> get_window() const;
+
+
+ Glib::SignalProxy0< void > signal_show();
+
+
+ Glib::SignalProxy0< void > signal_hide();
+
+
+ //: Emitted on mapping of a widget to the screen.
+ //- See {flags.mapped}.
+
+
+ Glib::SignalProxy0< void > signal_map();
+
+
+ //- See {flags.mapped}.
+
+
+ Glib::SignalProxy0< void > signal_unmap();
+
+
+ //: Emitted on realization of a widget.
+ //- See {flags.realized}. This is also responsible for
+ //- setting {flags.realized} when it is done. Therefore,
+ //- when overriding the impl method, you should call the
+ //- default realize method.
+
+
+ Glib::SignalProxy0< void > signal_realize();
+
+
+ //- See {flags.realized}. This should not be called by the user.
+ //__WRAP(meth|sig|impl,void unrealize_(),gtk_widget_unrealize,"unrealize")
+
+
+ Glib::SignalProxy0< void > signal_unrealize();
+
+
+ Glib::SignalProxy1< void,Requisition* > signal_size_request();
+
+
+ Glib::SignalProxy1< void,Allocation& > signal_size_allocate();
+
+
+// Changed signals -- inform widget of internal changes.
+// We rename parent_set => parent_changed
+// and style_set => style_changed
+// to avoid confusion with set_parent and set_style.
+
+ //: Informs objects that their state has changed.
+ //- The old state is passed as the argument.
+
+
+ Glib::SignalProxy1< void,Gtk::StateType > signal_state_changed();
+
+
+ //: Informs objects that their parent changed.
+ //- The widget passed is the former parent, which may be 0 if
+ //- there was no parent. (was parent_set in GTK+)
+
+
+ Glib::SignalProxy1< void,Widget* > signal_parent_changed();
+
+
+ Glib::SignalProxy1< void,Widget* > signal_hierarchy_changed();
+
+
+ //: Informs objects that their style has been changed.
+ //- The former style is passed as the argument. (was style_set in gtk+)
+
+
+ Glib::SignalProxy1< void,const Glib::RefPtr<Style>& > signal_style_changed();
+
+
+ Glib::SignalProxy1< void,TextDirection > signal_direction_changed();
+
+
+ Glib::SignalProxy1< void,bool > signal_grab_notify();
+
+
+ Glib::SignalProxy1< void,GParamSpec* > signal_child_notify();
+
+
+ //_WRAP_SIGNAL(void add_accelerator(guint, GtkAccelGroup*, guint accel_key, Gdk::ModifierType, AccelFlags), "add-accelerator")
+ //_WRAP_SIGNAL(void remove_accelerator(GtkAccelGroup* accel_group, guint, Gdk::ModifierType), "remove-accelerator")
+
+
+ Glib::SignalProxy1< bool,bool > signal_mnemonic_activate();
+
+
+ Glib::SignalProxy0< void > signal_grab_focus();
+
+
+ Glib::SignalProxy1< bool,DirectionType > signal_focus();
+
+
+ Glib::SignalProxy1< bool,GdkEvent* > signal_event();
+
+
+ Glib::SignalProxy1< void,GdkEvent* > signal_event_after();
+
+
+ //: Event triggered by user pressing button.
+
+
+ Glib::SignalProxy1< bool,GdkEventButton* > signal_button_press_event();
+
+
+ //: Event triggered by user releasing button.
+
+
+ Glib::SignalProxy1< bool,GdkEventButton* > signal_button_release_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventScroll* > signal_scroll_event();
+
+
+ //: Event triggered by user moving pointer.
+
+
+ Glib::SignalProxy1< bool,GdkEventMotion* > signal_motion_notify_event();
+
+
+ //: Event triggered by window being closed.
+
+
+ Glib::SignalProxy1< bool,GdkEventAny* > signal_delete_event();
+
+
+ //: Event triggered by window requiring a refresh.
+ //- Expose events cover a rectangular area that was covered
+ //- or obscured by another window. That area is now exposed
+ //- and thus is needs to be redrawn.
+ //-
+ //- If the application is not capable of redrawing sections
+ //- it should watch the count field and only draw on the last
+ //- even indicated. This is important for things such as
+ //- Gtk::DrawingArea.
+
+
+ Glib::SignalProxy1< bool,GdkEventExpose* > signal_expose_event();
+
+
+ //: Event triggered by a key press will widget has focus.
+
+
+ Glib::SignalProxy1< bool,GdkEventKey* > signal_key_press_event();
+
+
+ //: Event triggered by a key release will widget has focus.
+
+
+ Glib::SignalProxy1< bool,GdkEventKey* > signal_key_release_event();
+
+
+ //: Event triggered by pointer entering widget area.
+
+
+ Glib::SignalProxy1< bool,GdkEventCrossing* > signal_enter_notify_event();
+
+
+ //: Event triggered by pointer leaving widget area.
+
+
+ Glib::SignalProxy1< bool,GdkEventCrossing* > signal_leave_notify_event();
+
+
+ //: Event triggered by a window resizing.
+
+
+ Glib::SignalProxy1< bool,GdkEventConfigure* > signal_configure_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventFocus* > signal_focus_in_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventFocus* > signal_focus_out_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventAny* > signal_map_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventAny* > signal_unmap_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventProperty* > signal_property_notify_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventSelection* > signal_selection_clear_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventSelection* > signal_selection_request_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventSelection* > signal_selection_notify_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventProximity* > signal_proximity_in_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventProximity* > signal_proximity_out_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventVisibility* > signal_visibility_notify_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventClient* > signal_client_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventAny* > signal_no_expose_event();
+
+
+ Glib::SignalProxy1< bool,GdkEventWindowState* > signal_window_state_event();
+
+
+ //We use the optional custom_c_callback parameter with _WRAP_SIGNAL() for some of these,
+ //so that we can write special code to wrap the non-const SelectioData& output parameters:
+
+
+ Glib::SignalProxy3< void,SelectionData&,guint,guint > signal_selection_get();
+
+
+ Glib::SignalProxy2< void,const SelectionData&,guint > signal_selection_received();
+
+
+ Glib::SignalProxy1< void,const Glib::RefPtr<Gdk::DragContext>& > signal_drag_begin();
+
+
+ Glib::SignalProxy1< void,const Glib::RefPtr<Gdk::DragContext>& > signal_drag_end();
+
+
+ Glib::SignalProxy4< void,const Glib::RefPtr<Gdk::DragContext>&,SelectionData&,guint,guint > signal_drag_data_get();
+
+
+ Glib::SignalProxy1< void,const Glib::RefPtr<Gdk::DragContext>& > signal_drag_data_delete();
+
+
+ Glib::SignalProxy2< void,const Glib::RefPtr<Gdk::DragContext>&,guint > signal_drag_leave();
+
+
+ Glib::SignalProxy4< bool,const Glib::RefPtr<Gdk::DragContext>&,int,int,guint > signal_drag_motion();
+
+
+ Glib::SignalProxy4< bool,const Glib::RefPtr<Gdk::DragContext>&,int,int,guint > signal_drag_drop();
+
+
+ Glib::SignalProxy6< void,const Glib::RefPtr<Gdk::DragContext>&,int,int,const SelectionData&,guint,guint > signal_drag_data_received();
+
+
+ //accessibility signals:
+
+
+ Glib::SignalProxy0< Glib::RefPtr<Atk::Object> > signal_get_accessible();
+
+
+ Glib::SignalProxy1< void,const Glib::RefPtr<Gdk::Screen>& > signal_screen_changed();
+
+
+//TODO: The signal_id is very C-like here:
+ //_WRAP_SIGNAL(bool can_activate_accel(guint signal_id), "can_activate_accel")
+
+ //Keybinding signals:
+
+
+ /** The name of the widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<Glib::ustring> property_name() ;
+
+/** The name of the widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<Glib::ustring> property_name() const;
+
+ /** The parent widget of this widget. Must be a Container widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<Container*> property_parent() ;
+
+/** The parent widget of this widget. Must be a Container widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<Container*> property_parent() const;
+
+ /** Override for width request of the widget
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<int> property_width_request() ;
+
+/** Override for width request of the widget
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<int> property_width_request() const;
+
+ /** Override for height request of the widget
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<int> property_height_request() ;
+
+/** Override for height request of the widget
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<int> property_height_request() const;
+
+ /** Whether the widget is visible.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<bool> property_visible() ;
+
+/** Whether the widget is visible.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<bool> property_visible() const;
+
+ /** Whether the widget responds to input.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<bool> property_sensitive() ;
+
+/** Whether the widget responds to input.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<bool> property_sensitive() const;
+
+ /** Whether the application will paint directly on the widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<bool> property_app_paintable() ;
+
+/** Whether the application will paint directly on the widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<bool> property_app_paintable() const;
+
+ /** Whether the widget can accept the input focus.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<bool> property_can_focus() ;
+
+/** Whether the widget can accept the input focus.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<bool> property_can_focus() const;
+
+ /** Whether the widget has the input focus.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<bool> property_has_focus() ;
+
+/** Whether the widget has the input focus.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<bool> property_has_focus() const;
+
+ /** Whether the widget can be the default widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<bool> property_can_default() ;
+
+/** Whether the widget can be the default widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<bool> property_can_default() const;
+
+ /** Whether the widget is the default widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<bool> property_has_default() ;
+
+/** Whether the widget is the default widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<bool> property_has_default() const;
+
+ /** If TRUE
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<bool> property_receives_default() ;
+
+/** If TRUE
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<bool> property_receives_default() const;
+
+ /** Whether the widget is part of a composite widget.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<bool> property_composite_child() const;
+
+
+ /** The style of the widget
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy< Glib::RefPtr<Style> > property_style() ;
+
+/** The style of the widget
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly< Glib::RefPtr<Style> > property_style() const;
+
+ /** The event mask that decides what kind of GdkEvents this widget gets.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<Gdk::EventMask> property_events() ;
+
+/** The event mask that decides what kind of GdkEvents this widget gets.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<Gdk::EventMask> property_events() const;
+
+ /** The mask that decides what kind of extension events this widget gets.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy<Gdk::ExtensionMode> property_extension_events() ;
+
+/** The mask that decides what kind of extension events this widget gets.
+ *
+ * You rarely need to use properties because there are get_ and set_ methods for almost all of them.
+ * @return A PropertyProxy that allows you to get or set the property of the value, or receive notification when
+ * the value of the property changes.
+ */
+ Glib::PropertyProxy_ReadOnly<Gdk::ExtensionMode> property_extension_events() const;
+
+
+protected:
+ //comment in GTK+ header: "seldomly overidden"
+ virtual void dispatch_child_properties_changed_vfunc(guint p1, GParamSpec** p2);
+
+ virtual void show_all_vfunc();
+ virtual void hide_all_vfunc();
+
+ virtual Glib::RefPtr<Atk::Object> get_accessible_vfunc();
+
+
+protected:
+ Widget();
+
+
+ /** This function is only for use in widget implementations. Causes
+ * a widget to be mapped if it isn't already.
+ */
+ void map();
+
+ /** This function is only for use in widget implementations. Causes
+ * a widget to be unmapped if it's currently mapped.
+ */
+ void unmap();
+
+ /** Creates the GDK (windowing system) resources associated with a
+ * widget. For example, @a widget -&gt;window will be created when a widget
+ * is realized. Normally realization happens implicitly; if you show
+ * a widget and all its parent containers, then the widget will be
+ * realized and mapped automatically.
+ *
+ * Realizing a widget requires all
+ * the widget's parent widgets to be realized; calling
+ * realize() realizes the widget's parents in addition to
+ * @a widget itself. If a widget is not yet inside a toplevel window
+ * when you realize it, bad things will happen.
+ *
+ * This function is primarily used in widget implementations, and
+ * isn't very useful otherwise. Many times when you think you might
+ * need it, a better approach is to connect to a signal that will be
+ * called after the widget is realized automatically, such as
+ * "expose_event". Or simply Glib::signal_connect_after() to the
+ * "realize" signal.
+ */
+ void realize();
+
+ /** This function is only useful in widget implementations.
+ * Causes a widget to be unrealized (frees all GDK resources
+ * associated with the widget, such as @a widget -&gt;window).
+ */
+ void unrealize();
+
+
+ /** This function is only for use in widget implementations. Obtains
+ * @a widget -&gt;requisition, unless someone has forced a particular
+ * geometry on the widget (e.g. with set_usize()), in which
+ * case it returns that geometry instead of the widget's requisition.
+ *
+ * This function differs from size_request() in that
+ * it retrieves the last size request value from @a widget -&gt;requisition,
+ * while size_request() actually calls the "size_request" method
+ * on @a widget to compute the size request and fill in @a widget -&gt;requisition,
+ * and only then returns @a widget -&gt;requisition.
+ *
+ * Because this function does not call the "size_request" method, it
+ * can only be used when you know that @a widget -&gt;requisition is
+ * up-to-date, that is, size_request() has been called
+ * since the last time a resize was queued. In general, only container
+ * implementations have this information; applications should use
+ * size_request().
+ * @param requisition A Gtk::Requisition to be filled in.
+ */
+ void get_child_requisition(Requisition& requisition) const;
+
+ //The parameter name is "the_property_name" to avoid a warning because there is a method with the "property_name" name.
+
+ /** Gets the value of a style property of @a widget .
+ * @param the_property_name The name of a style property.
+ * @param value Location to return the property value.
+ */
+ void get_style_property_value(
+ const Glib::ustring& the_property_name, Glib::ValueBase& value) const;
+
+ void realize_if_needed();
+
+ void set_allocation(const Allocation& value);
+ void set_window(const Glib::RefPtr<Gdk::Window>& value);
+
+
+};
+
+
+#ifndef DOXYGEN_SHOULD_SKIP_THIS
+
+//The parameter name is "the_property_name" to avoid a warning because there is a method with the "property_name" name.
+template <class PropertyType>
+void Widget::get_style_property(const Glib::ustring& the_property_name, PropertyType& value) const
+{
+ Glib::Value<PropertyType> property_value;
+ property_value.init(Glib::Value<PropertyType>::value_type());
+
+ this->get_style_property_value(the_property_name, property_value);
+
+ value = property_value.get();
+}
+
+#endif /* DOXYGEN_SHOULD_SKIP_THIS */
+
+} // namespace Gtk
+
+
+namespace Glib
+{
+ /** @relates Gtk::Widget
+ * @param object The C instance
+ * @param take_copy False if the result should take ownership of the C instance. True if it should take a new copy or ref.
+ * @result A C++ instance that wraps this C instance.
+ */
+ Gtk::Widget* wrap(GtkWidget* object, bool take_copy = false);
+}
+#endif /* _GTKMM_WIDGET_H */
+