Mercurial > geeqie
changeset 1479:d062522699dc
added simple desktop file editor
author | nadvornik |
---|---|
date | Fri, 27 Mar 2009 08:05:14 +0000 |
parents | 3cc98d5c6907 |
children | 077924265c28 |
files | src/Makefile.am src/desktop_file.c src/desktop_file.h src/editors.c src/editors.h src/layout_util.c src/main.h |
diffstat | 7 files changed, 431 insertions(+), 10 deletions(-) [+] |
line wrap: on
line diff
--- a/src/Makefile.am Thu Mar 26 21:49:20 2009 +0000 +++ b/src/Makefile.am Fri Mar 27 08:05:14 2009 +0000 @@ -112,6 +112,8 @@ compat.h \ debug.c \ debug.h \ + desktop_file.c \ + desktop_file.h \ dnd.c \ dnd.h \ dupe.c \
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/desktop_file.c Fri Mar 27 08:05:14 2009 +0000 @@ -0,0 +1,353 @@ +/* + * Geeqie + * (C) 2004 John Ellis + * Copyright (C) 2008 - 2009 The Geeqie Team + * + * Author: Vladimir Nadvornik + * + * This software is released under the GNU General Public License (GNU GPL). + * Please read the included file COPYING for more information. + * This software comes with no warranty of any kind, use at your own risk! + */ + +#include "main.h" +#include "desktop_file.h" + +#include "editors.h" +#include "filedata.h" +#include "misc.h" +#include "ui_misc.h" +#include "ui_fileops.h" +#include "ui_utildlg.h" +#include "pixbuf_util.h" +#include "window.h" +#include "utilops.h" +#include "layout_util.h" + +#define CONFIG_WINDOW_DEF_WIDTH 700 +#define CONFIG_WINDOW_DEF_HEIGHT 400 + + + +typedef struct _EditorWindow EditorWindow; +struct _EditorWindow +{ + GtkWidget *window; + GtkWidget *entry; + GtkTextBuffer *buffer; +}; + + +static GtkWidget *editor_list_window = NULL; +GtkWidget *editor_list_view = NULL; + + +static gboolean editor_window_save(EditorWindow *ew) +{ + gchar *path; + gchar *text; + GtkTextIter start, end; + GError *error = NULL; + gboolean ret = TRUE; + const gchar *name = gtk_entry_get_text(GTK_ENTRY(ew->entry)); + + if (!name || !name[0]) + { + file_util_warning_dialog(_("Can't save"), _("Please specify file name."), GTK_STOCK_DIALOG_ERROR, NULL); + return FALSE; + } + + gtk_text_buffer_get_bounds(ew->buffer, &start, &end); + text = gtk_text_buffer_get_text(ew->buffer, &start, &end, FALSE); + + path = g_build_filename(get_rc_dir(), "applications", name, NULL); + + if (!g_file_set_contents(path, text, -1, &error)) + { + file_util_warning_dialog(_("Can't save"), error->message, GTK_STOCK_DIALOG_ERROR, NULL); + g_error_free(error); + ret = FALSE; + } + + g_free(path); + g_free(text); + layout_editors_reload_all(); + return ret; +} + +static void editor_window_close_cb(GtkWidget *widget, gpointer data) +{ + EditorWindow *ew = data; + + gtk_widget_destroy(ew->window); + g_free(ew); +} + +static gint editor_window_delete_cb(GtkWidget *w, GdkEventAny *event, gpointer data) +{ + editor_window_close_cb(w, data); + return TRUE; +} + +static void editor_window_apply_cb(GtkWidget *widget, gpointer data) +{ + EditorWindow *ew = data; + editor_window_save(ew); +} +static void editor_window_ok_cb(GtkWidget *widget, gpointer data) +{ + EditorWindow *ew = data; + if (!editor_window_save(ew)) return; + editor_window_close_cb(widget, ew); +} + +static void editor_window_new(const gchar *src_path, const gchar *desktop_name) +{ + EditorWindow *ew; + GtkWidget *win_vbox; + GtkWidget *hbox; + GtkWidget *button; + GtkWidget *ct_button; + GtkWidget *button_hbox; + GtkWidget *scrolled; + GtkWidget *text_view; + gchar *text; + gsize size; + + ew = g_new0(EditorWindow, 1); + + + ew->window = window_new(GTK_WINDOW_TOPLEVEL, "Desktop", PIXBUF_INLINE_ICON_CONFIG, NULL, _("Desktop file")); + gtk_window_set_type_hint(GTK_WINDOW(ew->window), GDK_WINDOW_TYPE_HINT_DIALOG); + + g_signal_connect(G_OBJECT(ew->window), "delete_event", + G_CALLBACK(editor_window_delete_cb), ew); + + gtk_window_set_default_size(GTK_WINDOW(ew->window), CONFIG_WINDOW_DEF_WIDTH, CONFIG_WINDOW_DEF_HEIGHT); + gtk_window_set_resizable(GTK_WINDOW(ew->window), TRUE); + gtk_container_set_border_width(GTK_CONTAINER(ew->window), PREF_PAD_BORDER); + + win_vbox = gtk_vbox_new(FALSE, PREF_PAD_SPACE); + gtk_container_add(GTK_CONTAINER(ew->window), win_vbox); + gtk_widget_show(win_vbox); + + hbox = gtk_hbox_new(FALSE, PREF_PAD_SPACE); + gtk_box_pack_end(GTK_BOX(win_vbox), hbox, FALSE, FALSE, 0); + gtk_widget_show(hbox); + + ew->entry = gtk_entry_new(); + gtk_box_pack_start(GTK_BOX(hbox), ew->entry, TRUE, TRUE, 0); + if (desktop_name) + { + gtk_entry_set_text(GTK_ENTRY(ew->entry), desktop_name); + } + gtk_widget_show(ew->entry); + + + button_hbox = gtk_hbutton_box_new(); + gtk_button_box_set_layout(GTK_BUTTON_BOX(button_hbox), GTK_BUTTONBOX_END); + gtk_box_set_spacing(GTK_BOX(button_hbox), PREF_PAD_BUTTON_GAP); + gtk_box_pack_end(GTK_BOX(hbox), button_hbox, FALSE, FALSE, 0); + gtk_widget_show(button_hbox); + + button = pref_button_new(NULL, GTK_STOCK_OK, NULL, FALSE, + G_CALLBACK(editor_window_ok_cb), ew); + gtk_container_add(GTK_CONTAINER(button_hbox), button); + GTK_WIDGET_SET_FLAGS(button, GTK_CAN_DEFAULT); + gtk_widget_grab_default(button); + gtk_widget_show(button); + + ct_button = button; + + button = pref_button_new(NULL, GTK_STOCK_APPLY, NULL, FALSE, + G_CALLBACK(editor_window_apply_cb), ew); + gtk_container_add(GTK_CONTAINER(button_hbox), button); + GTK_WIDGET_SET_FLAGS(button, GTK_CAN_DEFAULT); + gtk_widget_show(button); + + button = pref_button_new(NULL, GTK_STOCK_CANCEL, NULL, FALSE, + G_CALLBACK(editor_window_close_cb), ew); + gtk_container_add(GTK_CONTAINER(button_hbox), button); + GTK_WIDGET_SET_FLAGS(button, GTK_CAN_DEFAULT); + gtk_widget_show(button); + + if (!generic_dialog_get_alternative_button_order(ew->window)) + { + gtk_box_reorder_child(GTK_BOX(button_hbox), ct_button, -1); + } + + + scrolled = gtk_scrolled_window_new(NULL, NULL); + gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(scrolled), GTK_SHADOW_IN); + gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled), + GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); + gtk_box_pack_start(GTK_BOX(win_vbox), scrolled, TRUE, TRUE, 5); + gtk_widget_show(scrolled); + + text_view = gtk_text_view_new(); + gtk_container_add(GTK_CONTAINER(scrolled), text_view); + gtk_widget_show(text_view); + + ew->buffer = gtk_text_view_get_buffer(GTK_TEXT_VIEW(text_view)); + if (g_file_get_contents(src_path, &text, &size, NULL)) + { + gtk_text_buffer_set_text(ew->buffer, text, size); + } + + + gtk_widget_show(ew->window); +} + + +static void editor_list_window_close_cb(GtkWidget *widget, gpointer data) +{ + gtk_widget_destroy(editor_list_window); + editor_list_window = NULL; + editor_list_view = NULL; +} + +static gboolean editor_list_window_delete(GtkWidget *widget, GdkEventAny *event, gpointer data) +{ + editor_list_window_close_cb(NULL, NULL); + return TRUE; +} + +static void editor_list_window_edit_cb(GtkWidget *widget, gpointer data) +{ + GtkTreeSelection *sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(editor_list_view)); + GtkTreeIter iter; + + if (gtk_tree_selection_get_selected(sel, NULL, &iter)) + { + GtkTreeModel *store = gtk_tree_view_get_model(GTK_TREE_VIEW(editor_list_view)); + gchar *path; + gchar *key; + + gtk_tree_model_get(store, &iter, + DESKTOP_FILE_COLUMN_PATH, &path, + DESKTOP_FILE_COLUMN_KEY, &key, -1); + editor_window_new(path, key); + g_free(key); + g_free(path); + } +} + +static void editor_list_window_new_cb(GtkWidget *widget, gpointer data) +{ + editor_window_new(DESKTOP_FILE_TEMPLATE, _("new.desktop")); +} + +static void editor_list_window_create(void) +{ + GtkWidget *win_vbox; + GtkWidget *hbox; + GtkWidget *button; + GtkWidget *scrolled; + GtkCellRenderer *renderer; + GtkTreeSelection *selection; + GtkTreeViewColumn *column; + + editor_list_window = window_new(GTK_WINDOW_TOPLEVEL, "editors", PIXBUF_INLINE_ICON_CONFIG, NULL, _("Editors")); + gtk_window_set_type_hint(GTK_WINDOW(editor_list_window), GDK_WINDOW_TYPE_HINT_DIALOG); + g_signal_connect(G_OBJECT(editor_list_window), "delete_event", + G_CALLBACK(editor_list_window_delete), NULL); + gtk_window_set_default_size(GTK_WINDOW(editor_list_window), CONFIG_WINDOW_DEF_WIDTH, CONFIG_WINDOW_DEF_HEIGHT); + gtk_window_set_resizable(GTK_WINDOW(editor_list_window), TRUE); + gtk_container_set_border_width(GTK_CONTAINER(editor_list_window), PREF_PAD_BORDER); + + win_vbox = gtk_vbox_new(FALSE, PREF_PAD_SPACE); + gtk_container_add(GTK_CONTAINER(editor_list_window), win_vbox); + gtk_widget_show(win_vbox); + + hbox = gtk_hbutton_box_new(); + gtk_button_box_set_layout(GTK_BUTTON_BOX(hbox), GTK_BUTTONBOX_END); + gtk_box_set_spacing(GTK_BOX(hbox), PREF_PAD_BUTTON_GAP); + gtk_box_pack_end(GTK_BOX(win_vbox), hbox, FALSE, FALSE, 0); + gtk_widget_show(hbox); + + + button = pref_button_new(NULL, GTK_STOCK_NEW, NULL, FALSE, + G_CALLBACK(editor_list_window_new_cb), NULL); + gtk_container_add(GTK_CONTAINER(hbox), button); + GTK_WIDGET_SET_FLAGS(button, GTK_CAN_DEFAULT); + gtk_widget_show(button); + + button = pref_button_new(NULL, GTK_STOCK_EDIT, NULL, FALSE, + G_CALLBACK(editor_list_window_edit_cb), NULL); + gtk_container_add(GTK_CONTAINER(hbox), button); + GTK_WIDGET_SET_FLAGS(button, GTK_CAN_DEFAULT); + gtk_widget_show(button); + + button = pref_button_new(NULL, GTK_STOCK_CLOSE, NULL, FALSE, + G_CALLBACK(editor_list_window_close_cb), NULL); + gtk_container_add(GTK_CONTAINER(hbox), button); + GTK_WIDGET_SET_FLAGS(button, GTK_CAN_DEFAULT); + gtk_widget_show(button); + + scrolled = gtk_scrolled_window_new(NULL, NULL); + gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(scrolled), GTK_SHADOW_IN); + gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled), + GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); + gtk_box_pack_start(GTK_BOX(win_vbox), scrolled, TRUE, TRUE, 5); + gtk_widget_show(scrolled); + + editor_list_view = gtk_tree_view_new_with_model(GTK_TREE_MODEL(desktop_file_list)); + selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(editor_list_view)); + gtk_tree_selection_set_mode(GTK_TREE_SELECTION(selection), GTK_SELECTION_SINGLE); + + gtk_tree_view_set_enable_search(GTK_TREE_VIEW(editor_list_view), FALSE); + + column = gtk_tree_view_column_new(); + gtk_tree_view_column_set_title(column, _("Desktop file")); + gtk_tree_view_column_set_resizable(column, TRUE); + renderer = gtk_cell_renderer_text_new(); + gtk_tree_view_column_pack_start(column, renderer, FALSE); + gtk_tree_view_column_add_attribute(column, renderer, "text", DESKTOP_FILE_COLUMN_KEY); + gtk_tree_view_append_column(GTK_TREE_VIEW(editor_list_view), column); + + column = gtk_tree_view_column_new(); + gtk_tree_view_column_set_title(column, _("Hidden")); + gtk_tree_view_column_set_sizing(column, GTK_TREE_VIEW_COLUMN_AUTOSIZE); + renderer = gtk_cell_renderer_toggle_new(); + gtk_tree_view_column_pack_start(column, renderer, FALSE); + gtk_tree_view_column_add_attribute(column, renderer, "active", DESKTOP_FILE_COLUMN_HIDDEN); + gtk_tree_view_append_column(GTK_TREE_VIEW(editor_list_view), column); + + column = gtk_tree_view_column_new(); + gtk_tree_view_column_set_title(column, _("Name")); + gtk_tree_view_column_set_resizable(column, TRUE); + renderer = gtk_cell_renderer_text_new(); + gtk_tree_view_column_pack_start(column, renderer, FALSE); + gtk_tree_view_column_add_attribute(column, renderer, "text", DESKTOP_FILE_COLUMN_NAME); + gtk_tree_view_append_column(GTK_TREE_VIEW(editor_list_view), column); + + column = gtk_tree_view_column_new(); + gtk_tree_view_column_set_title(column, _("Path")); + gtk_tree_view_column_set_resizable(column, TRUE); + renderer = gtk_cell_renderer_text_new(); + gtk_tree_view_column_pack_start(column, renderer, FALSE); + gtk_tree_view_column_add_attribute(column, renderer, "text", DESKTOP_FILE_COLUMN_PATH); + gtk_tree_view_append_column(GTK_TREE_VIEW(editor_list_view), column); + + gtk_container_add(GTK_CONTAINER(scrolled), editor_list_view); + gtk_widget_show(editor_list_view); + + gtk_widget_show(editor_list_window); +} + +/* + *----------------------------------------------------------------------------- + * config window show (public) + *----------------------------------------------------------------------------- + */ + +void show_editor_list_window(void) +{ + if (editor_list_window) + { + gtk_window_present(GTK_WINDOW(editor_list_window)); + return; + } + + editor_list_window_create(); +}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/desktop_file.h Fri Mar 27 08:05:14 2009 +0000 @@ -0,0 +1,20 @@ +/* + * Geeqie + * (C) 2004 John Ellis + * Copyright (C) 2008 - 2009 The Geeqie Team + * + * Author: Vladimir Nadvornik + * + * This software is released under the GNU General Public License (GNU GPL). + * Please read the included file COPYING for more information. + * This software comes with no warranty of any kind, use at your own risk! + */ + + +#ifndef DESKTOP_FILE_H +#define DESKTOP_FILE_H + +void show_editor_list_window(void); + +#endif +/* vim: set shiftwidth=8 softtabstop=0 cindent cinoptions={1s: */
--- a/src/editors.c Thu Mar 26 21:49:20 2009 +0000 +++ b/src/editors.c Fri Mar 27 08:05:14 2009 +0000 @@ -67,6 +67,8 @@ */ GHashTable *editors = NULL; +GtkListStore *desktop_file_list; + #ifdef G_KEY_FILE_DESKTOP_GROUP #define DESKTOP_GROUP G_KEY_FILE_DESKTOP_GROUP @@ -183,6 +185,7 @@ const gchar *key = filename_from_path(path); gchar **categories, **only_show_in, **not_show_in; gchar *try_exec; + GtkTreeIter iter; if (g_hash_table_lookup(editors, key)) return FALSE; /* the file found earlier wins */ @@ -229,12 +232,12 @@ found = TRUE; break; } - if (!found) editor->hidden = TRUE; + if (!found) editor->ignored = TRUE; g_strfreev(categories); } else { - editor->hidden = TRUE; + editor->ignored = TRUE; } only_show_in = g_key_file_get_string_list(key_file, DESKTOP_GROUP, "OnlyShowIn", NULL, NULL); @@ -248,7 +251,7 @@ found = TRUE; break; } - if (!found) editor->hidden = TRUE; + if (!found) editor->ignored = TRUE; g_strfreev(only_show_in); } @@ -263,23 +266,23 @@ found = TRUE; break; } - if (found) editor->hidden = TRUE; + if (found) editor->ignored = TRUE; g_strfreev(not_show_in); } try_exec = g_key_file_get_string(key_file, DESKTOP_GROUP, "TryExec", NULL); - if (try_exec && !editor->hidden) + if (try_exec && !editor->hidden && !editor->ignored) { gchar *try_exec_res = g_find_program_in_path(try_exec); if (!try_exec_res) editor->hidden = TRUE; g_free(try_exec_res); g_free(try_exec); } - - if (editor->hidden) + + if (editor->ignored) { - /* hidden editors will be deleted, no need to parse the rest */ + /* ignored editors will be deleted, no need to parse the rest */ g_key_file_free(key_file); return TRUE; } @@ -337,6 +340,16 @@ editor->flags |= editor_command_parse(editor, NULL, NULL); g_key_file_free(key_file); + + if (editor->ignored) return TRUE; + + gtk_list_store_append(desktop_file_list, &iter); + gtk_list_store_set(desktop_file_list, &iter, + DESKTOP_FILE_COLUMN_KEY, key, + DESKTOP_FILE_COLUMN_NAME, editor->name, + DESKTOP_FILE_COLUMN_HIDDEN, editor->hidden, + DESKTOP_FILE_COLUMN_WRITABLE, access_file(path, W_OK), + DESKTOP_FILE_COLUMN_PATH, path, -1); return TRUE; } @@ -344,7 +357,7 @@ static gboolean editor_remove_desktop_file_cb(gpointer key, gpointer value, gpointer user_data) { EditorDescription *editor = value; - return editor->hidden; + return editor->hidden || editor->ignored; } static void editor_read_desktop_dir(const gchar *path) @@ -385,6 +398,14 @@ gchar **split_dirs; gint i; + if (desktop_file_list) + { + gtk_list_store_clear(desktop_file_list); + } + else + { + desktop_file_list = gtk_list_store_new(DESKTOP_FILE_COLUMN_COUNT, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_BOOLEAN, G_TYPE_BOOLEAN, G_TYPE_STRING); + } if (editors) { g_hash_table_destroy(editors);
--- a/src/editors.h Thu Mar 26 21:49:20 2009 +0000 +++ b/src/editors.h Fri Mar 27 08:05:14 2009 +0000 @@ -47,7 +47,8 @@ gchar *file; gchar *comment; /* .desktop Comment key, used to show a tooltip */ EditorFlags flags; - gboolean hidden; + gboolean hidden; /* explicitly hidden, shown in configuration dialog */ + gboolean ignored; /* not interesting, do not show at all */ }; #define EDITOR_ERRORS(flags) ((flags) & EDITOR_ERROR_MASK) @@ -62,6 +63,18 @@ must be called later */ }; +enum { + DESKTOP_FILE_COLUMN_KEY, + DESKTOP_FILE_COLUMN_NAME, + DESKTOP_FILE_COLUMN_HIDDEN, + DESKTOP_FILE_COLUMN_WRITABLE, + DESKTOP_FILE_COLUMN_PATH, + DESKTOP_FILE_COLUMN_COUNT +}; + +extern GtkListStore *desktop_file_list; + + extern GHashTable *editors; void editor_load_descriptions(void);
--- a/src/layout_util.c Thu Mar 26 21:49:20 2009 +0000 +++ b/src/layout_util.c Fri Mar 27 08:05:14 2009 +0000 @@ -44,6 +44,7 @@ #include "window.h" #include "metadata.h" #include "rcfile.h" +#include "desktop_file.h" #include <gdk/gdkkeysyms.h> /* for keyboard values */ @@ -369,6 +370,14 @@ show_config_window(); } +static void layout_menu_editors_cb(GtkAction *action, gpointer data) +{ + LayoutWindow *lw = data; + + layout_exit_fullscreen(lw); + show_editor_list_window(); +} + static void layout_menu_layout_config_cb(GtkAction *action, gpointer data) { LayoutWindow *lw = data; @@ -1221,6 +1230,7 @@ { "SelectInvert", NULL, N_("_Invert Selection"), "<control><shift>I", NULL, CB(layout_menu_invert_selection_cb) }, { "Preferences",GTK_STOCK_PREFERENCES,N_("P_references..."), "<control>O", NULL, CB(layout_menu_config_cb) }, + { "Editors",GTK_STOCK_PREFERENCES,N_("Configure _Editors..."), NULL, NULL, CB(layout_menu_editors_cb) }, { "LayoutConfig",GTK_STOCK_PREFERENCES,N_("_Configure this window..."), NULL, NULL, CB(layout_menu_layout_config_cb) }, { "Maintenance", NULL, N_("_Thumbnail maintenance..."),NULL, NULL, CB(layout_menu_remove_thumb_cb) }, { "Wallpaper", NULL, N_("Set as _wallpaper"),NULL, NULL, CB(layout_menu_wallpaper_cb) }, @@ -1379,6 +1389,7 @@ " <placeholder name='PropertiesSection'/>" " <separator/>" " <menuitem action='Preferences'/>" +" <menuitem action='Editors'/>" " <menuitem action='LayoutConfig'/>" " <menuitem action='Maintenance'/>" " <placeholder name='PreferencesSection'/>"
--- a/src/main.h Thu Mar 26 21:49:20 2009 +0000 +++ b/src/main.h Fri Mar 27 08:05:14 2009 +0000 @@ -121,6 +121,7 @@ #include "debug.h" #include "options.h" +#define DESKTOP_FILE_TEMPLATE GQ_APP_DIR "/template.desktop" /* *---------------------------------------------------------------------------- * main.c