Revision: 1431
http://geeqie.svn.sourceforge.net/geeqie/?rev=1431&view=rev
Author: nadvornik
Date: 2009-02-28 12:50:39 +0000 (Sat, 28 Feb 2009)
Log Message:
-----------
save and restore toolbar configuration
Modified Paths:
--------------
trunk/src/layout.c
trunk/src/layout_util.c
trunk/src/layout_util.h
trunk/src/rcfile.c
trunk/src/typedefs.h
Modified: trunk/src/layout.c
===================================================================
--- trunk/src/layout.c 2009-02-28 09:59:27 UTC (rev 1430)
+++ trunk/src/layout.c 2009-02-28 12:50:39 UTC (rev 1431)
@@ -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");
}
Modified: trunk/src/layout_util.c
===================================================================
--- trunk/src/layout_util.c 2009-02-28 09:59:27 UTC (rev 1430)
+++ trunk/src/layout_util.c 2009-02-28 12:50:39 UTC (rev 1431)
@@ -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
Modified: trunk/src/layout_util.h
===================================================================
--- trunk/src/layout_util.h 2009-02-28 09:59:27 UTC (rev 1430)
+++ trunk/src/layout_util.h 2009-02-28 12:50:39 UTC (rev 1431)
@@ -33,10 +33,16 @@
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);
Modified: trunk/src/rcfile.c
===================================================================
--- trunk/src/rcfile.c 2009-02-28 09:59:27 UTC (rev 1430)
+++ trunk/src/rcfile.c 2009-02-28 12:50:39 UTC (rev 1431)
@@ -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);
Modified: trunk/src/typedefs.h
===================================================================
--- trunk/src/typedefs.h 2009-02-28 09:59:27 UTC (rev 1430)
+++ trunk/src/typedefs.h 2009-02-28 12:50:39 UTC (rev 1431)
@@ -551,6 +551,8 @@
GtkActionGroup *action_group;
GtkActionGroup *action_group_external;
GtkUIManager *ui_manager;
+ guint toolbar_merge_id;
+ GList *toolbar_actions;
GtkWidget *path_entry;
This was sent by the SourceForge.net collaborative development platform, the
world's largest Open Source development site.
------------------------------------------------------------------------------
Open Source Business Conference (OSBC), March 24-25, 2009, San Francisco, CA
-OSBC tackles the biggest issue in open source: Open Sourcing the Enterprise
-Strategies to boost innovation and cut costs with open source participation
-Receive a $600 discount off the registration fee with the source code: SFAD
http://p.sf.net/sfu/XcvMzF8H
_______________________________________________
Geeqie-svn mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/geeqie-svn