summaryrefslogtreecommitdiff
path: root/gtk/gtkuimanager.c
diff options
context:
space:
mode:
authorMatthias Clasen <maclas@gmx.de>2003-09-21 22:04:48 +0000
committerMatthias Clasen <matthiasc@src.gnome.org>2003-09-21 22:04:48 +0000
commitd381967d5ccb39a1b5dc94cbc01379143c917eb8 (patch)
tree8256261a7140d2f49e5c371e6ef613d1f58785a6 /gtk/gtkuimanager.c
parent8be8d7f61dd77ae9331c92ec692350e7947c6340 (diff)
downloadgtk+-d381967d5ccb39a1b5dc94cbc01379143c917eb8.tar.gz
Changes to make cross-process merging feasible:
2003-09-21 Matthias Clasen <maclas@gmx.de> Changes to make cross-process merging feasible: * gtk/gtkuimanager.[hc]: Add a readonly "ui" property which holds the merged UI definition. Remove the "changed" signal, since its role is now filled by "notify::ui". Instead add a "actions-changed" signal which gets emitted when the set of actions changes. * gtk/gtktoggleactionprivate.h: * gtk/gtktoggleaction.[hc] (gtk_toggle_action_[sg]et_draw_as_radio): Add a "draw_as_radio" property to toggle actions so that they can be used as proxies for radio actions much like the "draw_as_radio" property on check menu items enables them to operate as proxies for radio actions. Prevent the "show_all" trap for action-based menus (see http://mail.gnome.org/archives/gtk-devel-list/2003-September/ msg00260.html): * gtk/gtkmenu.c (gtk_menu_{hide,show}_all): Remove g_return_if_fail() calls from static functions. * gtk/gtkuimanager.c (update_node): * gtk/gtkaction.c (connect_proxy): Set "no_show_all" on constructed widgets whose visibility is externally controlled. * gtk/gtkwidget.[hc] (gtk_widget_[gs]et_no_show_all): Add a boolean "no_show_all" property with setter and getter. When TRUE, it keeps gtk_widget_{hide,show}_all() from modifying the visibility of the widget and its children.
Diffstat (limited to 'gtk/gtkuimanager.c')
-rw-r--r--gtk/gtkuimanager.c48
1 files changed, 35 insertions, 13 deletions
diff --git a/gtk/gtkuimanager.c b/gtk/gtkuimanager.c
index 203604712f..bdb68279cc 100644
--- a/gtk/gtkuimanager.c
+++ b/gtk/gtkuimanager.c
@@ -139,14 +139,15 @@ static void node_remove_ui_reference (Node *node,
enum
{
ADD_WIDGET,
- CHANGED,
+ ACTIONS_CHANGED,
LAST_SIGNAL
};
enum
{
PROP_0,
- PROP_ADD_TEAROFFS
+ PROP_ADD_TEAROFFS,
+ PROP_UI
};
static guint merge_signals[LAST_SIGNAL] = { 0 };
@@ -213,8 +214,17 @@ gtk_ui_manager_class_init (GtkUIManagerClass *klass)
_("Add tearoffs to menus"),
_("Whether tearoff menu items should be added to menus"),
FALSE,
- G_PARAM_READABLE | G_PARAM_WRITABLE));
-
+ G_PARAM_READWRITE));
+
+ g_object_class_install_property (gobject_class,
+ PROP_UI,
+ g_param_spec_string ("ui",
+ _("Merged UI definition"),
+ _("An XML string describing the merged UI"),
+ NULL,
+ G_PARAM_READABLE));
+
+
/**
* GtkUIManager::add-widget:
* @merge: a #GtkUIManager
@@ -236,18 +246,20 @@ gtk_ui_manager_class_init (GtkUIManagerClass *klass)
GTK_TYPE_WIDGET);
/**
- * GtkUIManager::changed:
+ * GtkUIManager::actions-changed:
* @merge: a #GtkUIManager
*
- * The "changed" signal is emitted whenever the merged UI changes.
+ * The "actions-changed" signal is emitted whenever the set of actions
+ * changes.
*
* Since: 2.4
*/
- merge_signals[CHANGED] =
- g_signal_new ("changed",
+ merge_signals[ACTIONS_CHANGED] =
+ g_signal_new ("actions_changed",
G_OBJECT_CLASS_TYPE (klass),
G_SIGNAL_RUN_FIRST | G_SIGNAL_NO_RECURSE,
- G_STRUCT_OFFSET (GtkUIManagerClass, changed), NULL, NULL,
+ G_STRUCT_OFFSET (GtkUIManagerClass, actions_changed),
+ NULL, NULL,
g_cclosure_marshal_VOID__VOID,
G_TYPE_NONE, 0);
@@ -335,6 +347,9 @@ gtk_ui_manager_get_property (GObject *object,
case PROP_ADD_TEAROFFS:
g_value_set_boolean (value, self->private_data->add_tearoffs);
break;
+ case PROP_UI:
+ g_value_set_string (value, gtk_ui_manager_get_ui (self));
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -437,6 +452,8 @@ gtk_ui_manager_insert_action_group (GtkUIManager *self,
/* dirty all nodes, as action bindings may change */
dirty_all_nodes (self);
+
+ g_signal_emit (self, merge_signals[ACTIONS_CHANGED], 0);
}
/**
@@ -464,6 +481,8 @@ gtk_ui_manager_remove_action_group (GtkUIManager *self,
/* dirty all nodes, as action bindings may change */
dirty_all_nodes (self);
+
+ g_signal_emit (self, merge_signals[ACTIONS_CHANGED], 0);
}
/**
@@ -1185,7 +1204,7 @@ add_ui_from_string (GtkUIManager *self,
queue_update (self);
- g_signal_emit (self, merge_signals[CHANGED], 0);
+ g_object_notify (G_OBJECT (self), "ui");
return ctx.merge_id;
@@ -1416,7 +1435,7 @@ gtk_ui_manager_add_ui (GtkUIManager *self,
queue_update (self);
- g_signal_emit (self, merge_signals[CHANGED], 0);
+ g_object_notify (G_OBJECT (self), "ui");
}
static gboolean
@@ -1449,7 +1468,7 @@ gtk_ui_manager_remove_ui (GtkUIManager *self,
queue_update (self);
- g_signal_emit (self, merge_signals[CHANGED], 0);
+ g_object_notify (G_OBJECT (self), "ui");
}
/* -------------------- Updates -------------------- */
@@ -1457,7 +1476,7 @@ gtk_ui_manager_remove_ui (GtkUIManager *self,
static GtkAction *
get_action_by_name (GtkUIManager *merge,
- const char *action_name)
+ const gchar *action_name)
{
GList *tmp;
@@ -1826,6 +1845,7 @@ update_node (GtkUIManager *self,
info->proxy = gtk_action_create_menu_item (action);
menu = gtk_menu_new ();
tearoff = gtk_tearoff_menu_item_new ();
+ gtk_widget_set_no_show_all (tearoff, TRUE);
gtk_menu_shell_append (GTK_MENU_SHELL (menu), tearoff);
gtk_menu_item_set_submenu (GTK_MENU_ITEM (info->proxy), menu);
gtk_menu_shell_insert (GTK_MENU_SHELL (menushell), info->proxy, pos);
@@ -2036,6 +2056,7 @@ update_node (GtkUIManager *self,
GtkToolItem *item = gtk_separator_tool_item_new ();
gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, pos);
info->proxy = GTK_WIDGET (item);
+ gtk_widget_set_no_show_all (info->proxy, TRUE);
g_object_set_data (G_OBJECT (info->proxy),
"gtk-separator-mode",
GINT_TO_POINTER (SEPARATOR_MODE_SMART));
@@ -2057,6 +2078,7 @@ update_node (GtkUIManager *self,
if (find_menu_position (node, &menushell, &pos))
{
info->proxy = gtk_separator_menu_item_new ();
+ gtk_widget_set_no_show_all (info->proxy, TRUE);
g_object_set_data (G_OBJECT (info->proxy),
"gtk-separator-mode",
GINT_TO_POINTER (SEPARATOR_MODE_SMART));