changeset 1335:588d96cda850

save and restore toolbar configuration
author nadvornik
date Sat, 28 Feb 2009 12:50:39 +0000
parents f97450e632a1
children 4179d41d1149
files src/layout.c src/layout_util.c src/layout_util.h src/rcfile.c src/typedefs.h
diffstat 5 files changed, 109 insertions(+), 15 deletions(-) [+]
line wrap: on
line diff
--- a/src/layout.c	Sat Feb 28 09:59:27 2009 +0000
+++ b/src/layout.c	Sat Feb 28 12:50:39 2009 +0000
@@ -218,7 +218,7 @@
 	gtk_box_pack_start(GTK_BOX(box), menu_bar, FALSE, FALSE, 0);
 	gtk_widget_show(menu_bar);
 
-	lw->toolbar = layout_button_bar(lw);
+	lw->toolbar = layout_actions_toolbar(lw);
 	gtk_box_pack_start(GTK_BOX(box), lw->toolbar, FALSE, FALSE, 0);
 	if (!lw->options.toolbar_hidden) gtk_widget_show(lw->toolbar);
 
@@ -1971,6 +1971,7 @@
 		file_data_unref(lw->dir_fd);
 		}
 
+	string_list_free(lw->toolbar_actions);
 	free_layout_options_content(&lw->options);
 	g_free(lw);
 }
@@ -2177,6 +2178,8 @@
 	bar_sort_write_config(lw->bar_sort, outstr, indent + 1);
 	bar_write_config(lw->bar, outstr, indent + 1);
 	
+	layout_toolbar_write_config(lw, outstr, indent + 1);
+
 	WRITE_STRING("</layout>\n");
 }
 
--- a/src/layout_util.c	Sat Feb 28 09:59:27 2009 +0000
+++ b/src/layout_util.c	Sat Feb 28 12:50:39 2009 +0000
@@ -43,6 +43,7 @@
 #include "view_dir.h"
 #include "window.h"
 #include "metadata.h"
+#include "rcfile.h"
 
 #include <gdk/gdkkeysyms.h> /* for keyboard values */
 
@@ -1444,17 +1445,6 @@
 "    </menu>"
 "  </menubar>"
 "  <toolbar name='ToolBar'>"
-"    <toolitem action='Thumbnails'/>"
-"    <toolitem action='Back'/>"
-"    <toolitem action='Home'/>"
-"    <toolitem action='Refresh'/>"
-"    <toolitem action='ZoomIn'/>"
-"    <toolitem action='ZoomOut'/>"
-"    <toolitem action='ZoomFit'/>"
-"    <toolitem action='ZoomFit'/>"
-"    <toolitem action='Zoom100'/>"
-"    <toolitem action='Preferences'/>"
-"    <toolitem action='FloatTools'/>"
 "  </toolbar>"
 "<accelerator action='PrevImageAlt1'/>"
 "<accelerator action='PrevImageAlt2'/>"
@@ -1478,7 +1468,6 @@
 "<accelerator action='ConnectZoomFitAlt1'/>"
 "</ui>";
 
-
 static gchar *menu_translate(const gchar *path, gpointer data)
 {
 	return (gchar *)(_(path));
@@ -1727,6 +1716,9 @@
 		exit(EXIT_FAILURE);
 		}
 	
+	layout_toolbar_clear(lw);
+	layout_toolbar_add_default(lw);
+	
 	layout_actions_setup_marks(lw);
 	layout_actions_setup_editors(lw);
 	layout_copy_path_update(lw);
@@ -1747,7 +1739,7 @@
 	return gtk_ui_manager_get_widget(lw->ui_manager, "/MainMenu");
 }
 
-GtkWidget *layout_button_bar(LayoutWindow *lw)
+GtkWidget *layout_actions_toolbar(LayoutWindow *lw)
 {
 	GtkWidget *bar = gtk_ui_manager_get_widget(lw->ui_manager, "/ToolBar");
 	gtk_toolbar_set_icon_size(GTK_TOOLBAR(bar), GTK_ICON_SIZE_SMALL_TOOLBAR);
@@ -1755,6 +1747,77 @@
 	return bar;
 }
 
+void layout_toolbar_clear(LayoutWindow *lw)
+{
+	if (lw->toolbar_merge_id) 
+		{
+		gtk_ui_manager_remove_ui(lw->ui_manager, lw->toolbar_merge_id);
+		gtk_ui_manager_ensure_update(lw->ui_manager);
+		}
+	string_list_free(lw->toolbar_actions);
+	lw->toolbar_actions = NULL;
+	
+	lw->toolbar_merge_id = gtk_ui_manager_new_merge_id(lw->ui_manager);
+}
+	
+
+void layout_toolbar_add(LayoutWindow *lw, const gchar *action)
+{
+	if (!action || !lw->ui_manager) return;
+	gtk_ui_manager_add_ui(lw->ui_manager, lw->toolbar_merge_id, "/ToolBar", action, action, GTK_UI_MANAGER_TOOLITEM, FALSE); 
+	lw->toolbar_actions = g_list_append(lw->toolbar_actions, g_strdup(action));
+}
+
+
+void layout_toolbar_add_default(LayoutWindow *lw)
+{
+	layout_toolbar_add(lw, "Thumbnails");
+	layout_toolbar_add(lw, "Back");
+	layout_toolbar_add(lw, "Home");
+	layout_toolbar_add(lw, "Refresh");
+	layout_toolbar_add(lw, "ZoomIn");
+	layout_toolbar_add(lw, "ZoomOut");
+	layout_toolbar_add(lw, "ZoomFit");
+	layout_toolbar_add(lw, "Zoom100");
+	layout_toolbar_add(lw, "Preferences");
+	layout_toolbar_add(lw, "FloatTools");
+}
+
+void layout_toolbar_write_config(LayoutWindow *lw, GString *outstr, gint indent)
+{
+	GList *work = lw->toolbar_actions;
+	WRITE_STRING("<toolbar>\n");
+	indent++;
+	while (work)
+		{
+		gchar *action = work->data;
+		work = work->next;
+		WRITE_STRING("<toolitem\n");
+		write_char_option(outstr, indent + 1, "action", action);
+		WRITE_STRING("/>\n");
+		}
+	indent--;
+	WRITE_STRING("</toolbar>\n");
+}
+
+void layout_toolbar_add_from_config(LayoutWindow *lw, const gchar **attribute_names, const gchar **attribute_values)
+{
+	gchar *action = NULL;
+	
+	while (*attribute_names)
+		{
+		const gchar *option = *attribute_names++;
+		const gchar *value = *attribute_values++;
+
+		if (READ_CHAR_FULL("action", action)) continue;
+
+		DEBUG_1("unknown attribute %s = %s", option, value);
+		}
+
+	layout_toolbar_add(lw, action);
+	g_free(action);	
+}
+
 /*
  *-----------------------------------------------------------------------------
  * misc
--- a/src/layout_util.h	Sat Feb 28 09:59:27 2009 +0000
+++ b/src/layout_util.h	Sat Feb 28 12:50:39 2009 +0000
@@ -33,9 +33,15 @@
 void layout_actions_setup(LayoutWindow *lw);
 void layout_actions_add_window(LayoutWindow *lw, GtkWidget *window);
 GtkWidget *layout_actions_menu_bar(LayoutWindow *lw);
+void layout_toolbar_add_from_config(LayoutWindow *lw, const gchar **attribute_names, const gchar **attribute_values);
 
+GtkWidget *layout_actions_toolbar(LayoutWindow *lw);
 
-GtkWidget *layout_button_bar(LayoutWindow *lw);
+void layout_toolbar_clear(LayoutWindow *lw);
+void layout_toolbar_add(LayoutWindow *lw, const gchar *action);
+void layout_toolbar_add_default(LayoutWindow *lw);
+void layout_toolbar_write_config(LayoutWindow *lw, GString *outstr, gint indent);
+
 
 void layout_keyboard_init(LayoutWindow *lw, GtkWidget *window);
 
--- a/src/rcfile.c	Sat Feb 28 09:59:27 2009 +0000
+++ b/src/rcfile.c	Sat Feb 28 12:50:39 2009 +0000
@@ -887,6 +887,21 @@
 		}
 }
 
+static void options_parse_toolbar(GQParserData *parser_data, GMarkupParseContext *context, const gchar *element_name, const gchar **attribute_names, const gchar **attribute_values, gpointer data, GError **error)
+{
+	LayoutWindow *lw = data;
+	if (g_ascii_strcasecmp(element_name, "toolitem") == 0)
+		{
+		layout_toolbar_add_from_config(lw, attribute_names, attribute_values);
+		options_parse_func_push(parser_data, options_parse_leaf, NULL, NULL);
+		}
+	else
+		{
+		DEBUG_1("unexpected in <toolbar>: <%s>", element_name);
+		options_parse_func_push(parser_data, options_parse_leaf, NULL, NULL);
+		}
+}
+
 static void options_parse_layout(GQParserData *parser_data, GMarkupParseContext *context, const gchar *element_name, const gchar **attribute_names, const gchar **attribute_values, gpointer data, GError **error)
 {
 	LayoutWindow *lw = data;
@@ -902,6 +917,11 @@
 		layout_bar_sort_set(lw, bar);
 		options_parse_func_push(parser_data, options_parse_leaf, NULL, NULL);
 		}
+	else if (g_ascii_strcasecmp(element_name, "toolbar") == 0)
+		{
+		layout_toolbar_clear(lw);
+		options_parse_func_push(parser_data, options_parse_toolbar, NULL, lw);
+		}
 	else
 		{
 		DEBUG_1("unexpected in <layout>: <%s>", element_name);
--- a/src/typedefs.h	Sat Feb 28 09:59:27 2009 +0000
+++ b/src/typedefs.h	Sat Feb 28 12:50:39 2009 +0000
@@ -551,6 +551,8 @@
 	GtkActionGroup *action_group;
 	GtkActionGroup *action_group_external;
 	GtkUIManager *ui_manager;
+	guint toolbar_merge_id;
+	GList *toolbar_actions;
 
 	GtkWidget *path_entry;