/* * xedit-file-browser-plugin.c - Xedit plugin providing easy file access * from the sidepanel * * Copyright (C) 2006 - Jesse van den Kieboom * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifdef HAVE_CONFIG_H #include #endif #include #include #include #include #include #include #include #include "xedit-file-browser-enum-types.h" #include "xedit-file-browser-plugin.h" #include "xedit-file-browser-utils.h" #include "xedit-file-browser-error.h" #include "xedit-file-browser-widget.h" #include "xedit-file-browser-messages.h" #define WINDOW_DATA_KEY "XeditFileBrowserPluginWindowData" #define FILE_BROWSER_SCHEMA "org.x.editor.plugins.filebrowser" #define FILE_BROWSER_ONLOAD_SCHEMA "org.x.editor.plugins.filebrowser.on-load" #define XEDIT_FILE_BROWSER_PLUGIN_GET_PRIVATE(object) (G_TYPE_INSTANCE_GET_PRIVATE ((object), XEDIT_TYPE_FILE_BROWSER_PLUGIN, XeditFileBrowserPluginPrivate)) struct _XeditFileBrowserPluginPrivate { gpointer *dummy; }; typedef struct _XeditFileBrowserPluginData { XeditFileBrowserWidget * tree_widget; gulong merge_id; GtkActionGroup * action_group; GtkActionGroup * single_selection_action_group; gboolean auto_root; gulong end_loading_handle; GSettings *settings; GSettings *onload_settings; GSettings *terminal_settings; } XeditFileBrowserPluginData; static void on_uri_activated_cb (XeditFileBrowserWidget * widget, gchar const *uri, XeditWindow * window); static void on_error_cb (XeditFileBrowserWidget * widget, guint code, gchar const *message, XeditWindow * window); static void on_model_set_cb (XeditFileBrowserView * widget, GParamSpec *arg1, XeditWindow * window); static void on_virtual_root_changed_cb (XeditFileBrowserStore * model, GParamSpec * param, XeditWindow * window); static void on_filter_mode_changed_cb (XeditFileBrowserStore * model, GParamSpec * param, XeditWindow * window); static void on_rename_cb (XeditFileBrowserStore * model, const gchar * olduri, const gchar * newuri, XeditWindow * window); static void on_filter_pattern_changed_cb (XeditFileBrowserWidget * widget, GParamSpec * param, XeditWindow * window); static void on_tab_added_cb (XeditWindow * window, XeditTab * tab, XeditFileBrowserPluginData * data); static gboolean on_confirm_delete_cb (XeditFileBrowserWidget * widget, XeditFileBrowserStore * store, GList * rows, XeditWindow * window); static gboolean on_confirm_no_trash_cb (XeditFileBrowserWidget * widget, GList * files, XeditWindow * window); XEDIT_PLUGIN_REGISTER_TYPE_WITH_CODE (XeditFileBrowserPlugin, filetree_plugin, \ xedit_file_browser_enum_and_flag_register_type (type_module); \ xedit_file_browser_store_register_type (type_module); \ xedit_file_bookmarks_store_register_type (type_module); \ xedit_file_browser_view_register_type (type_module); \ xedit_file_browser_widget_register_type (type_module); \ ) static void filetree_plugin_init (XeditFileBrowserPlugin * plugin) { plugin->priv = XEDIT_FILE_BROWSER_PLUGIN_GET_PRIVATE (plugin); } static void filetree_plugin_finalize (GObject * object) { //XeditFileBrowserPlugin * plugin = XEDIT_FILE_BROWSER_PLUGIN (object); G_OBJECT_CLASS (filetree_plugin_parent_class)->finalize (object); } static XeditFileBrowserPluginData * get_plugin_data (XeditWindow * window) { return (XeditFileBrowserPluginData *) (g_object_get_data (G_OBJECT (window), WINDOW_DATA_KEY)); } static void on_end_loading_cb (XeditFileBrowserStore * store, GtkTreeIter * iter, XeditFileBrowserPluginData * data) { /* Disconnect the signal */ g_signal_handler_disconnect (store, data->end_loading_handle); data->end_loading_handle = 0; data->auto_root = FALSE; } static void prepare_auto_root (XeditFileBrowserPluginData *data) { XeditFileBrowserStore *store; data->auto_root = TRUE; store = xedit_file_browser_widget_get_browser_store (data->tree_widget); if (data->end_loading_handle != 0) { g_signal_handler_disconnect (store, data->end_loading_handle); data->end_loading_handle = 0; } data->end_loading_handle = g_signal_connect (store, "end-loading", G_CALLBACK (on_end_loading_cb), data); } static void restore_default_location (XeditFileBrowserPluginData *data) { gchar * root; gchar * virtual_root; gboolean bookmarks; gboolean remote; bookmarks = !g_settings_get_boolean (data->onload_settings, "tree-view"); if (bookmarks) { xedit_file_browser_widget_show_bookmarks (data->tree_widget); return; } root = g_settings_get_string (data->onload_settings, "root"); virtual_root = g_settings_get_string (data->onload_settings, "virtual-root"); remote = g_settings_get_boolean (data->onload_settings, "enable-remote"); if (root != NULL && *root != '\0') { GFile *file; file = g_file_new_for_uri (root); if (remote || g_file_is_native (file)) { if (virtual_root != NULL && *virtual_root != '\0') { prepare_auto_root (data); xedit_file_browser_widget_set_root_and_virtual_root (data->tree_widget, root, virtual_root); } else { prepare_auto_root (data); xedit_file_browser_widget_set_root (data->tree_widget, root, TRUE); } } g_object_unref (file); } g_free (root); g_free (virtual_root); } static void restore_filter (XeditFileBrowserPluginData * data) { gchar *filter_mode; XeditFileBrowserStoreFilterMode mode; gchar *pattern; /* Get filter_mode */ filter_mode = g_settings_get_string (data->settings, "filter-mode"); /* Filter mode */ mode = xedit_file_browser_store_filter_mode_get_default (); if (filter_mode != NULL) { if (strcmp (filter_mode, "hidden") == 0) { mode = XEDIT_FILE_BROWSER_STORE_FILTER_MODE_HIDE_HIDDEN; } else if (strcmp (filter_mode, "binary") == 0) { mode = XEDIT_FILE_BROWSER_STORE_FILTER_MODE_HIDE_BINARY; } else if (strcmp (filter_mode, "hidden_and_binary") == 0 || strcmp (filter_mode, "binary_and_hidden") == 0) { mode = XEDIT_FILE_BROWSER_STORE_FILTER_MODE_HIDE_HIDDEN | XEDIT_FILE_BROWSER_STORE_FILTER_MODE_HIDE_BINARY; } else if (strcmp (filter_mode, "none") == 0 || *filter_mode == '\0') { mode = XEDIT_FILE_BROWSER_STORE_FILTER_MODE_NONE; } } /* Set the filter mode */ xedit_file_browser_store_set_filter_mode ( xedit_file_browser_widget_get_browser_store (data->tree_widget), mode); pattern = g_settings_get_string (data->settings, "filter-pattern"); xedit_file_browser_widget_set_filter_pattern (data->tree_widget, pattern); g_free (filter_mode); g_free (pattern); } static void set_root_from_doc (XeditFileBrowserPluginData * data, XeditDocument * doc) { GFile *file; GFile *parent; if (doc == NULL) return; file = xedit_document_get_location (doc); if (file == NULL) return; parent = g_file_get_parent (file); if (parent != NULL) { gchar * root; root = g_file_get_uri (parent); xedit_file_browser_widget_set_root (data->tree_widget, root, TRUE); g_object_unref (parent); g_free (root); } g_object_unref (file); } static void on_action_set_active_root (GtkAction * action, XeditWindow * window) { XeditFileBrowserPluginData *data; data = get_plugin_data (window); set_root_from_doc (data, xedit_window_get_active_document (window)); } static gchar * get_terminal (XeditFileBrowserPluginData * data) { // TODO : Identify the DE, find the preferred terminal application (xterminal shouldn't be hardcoded here, it should be set as default in the DE prefs) return g_strdup ("xterminal"); } static void on_action_open_terminal (GtkAction * action, XeditWindow * window) { XeditFileBrowserPluginData * data; gchar * terminal; gchar * wd = NULL; gchar * local; gchar * argv[2]; GFile * file; GtkTreeIter iter; XeditFileBrowserStore * store; data = get_plugin_data (window); /* Get the current directory */ if (!xedit_file_browser_widget_get_selected_directory (data->tree_widget, &iter)) return; store = xedit_file_browser_widget_get_browser_store (data->tree_widget); gtk_tree_model_get (GTK_TREE_MODEL (store), &iter, XEDIT_FILE_BROWSER_STORE_COLUMN_URI, &wd, -1); if (wd == NULL) return; terminal = get_terminal (data); file = g_file_new_for_uri (wd); local = g_file_get_path (file); g_object_unref (file); argv[0] = terminal; argv[1] = NULL; g_spawn_async (local, argv, NULL, G_SPAWN_SEARCH_PATH, NULL, NULL, NULL, NULL); g_free (terminal); g_free (wd); g_free (local); } static void on_selection_changed_cb (GtkTreeSelection *selection, XeditWindow *window) { XeditFileBrowserPluginData * data; GtkTreeView * tree_view; GtkTreeModel * model; GtkTreeIter iter; gboolean sensitive; gchar * uri; data = get_plugin_data (window); tree_view = GTK_TREE_VIEW (xedit_file_browser_widget_get_browser_view (data->tree_widget)); model = gtk_tree_view_get_model (tree_view); if (!XEDIT_IS_FILE_BROWSER_STORE (model)) return; sensitive = xedit_file_browser_widget_get_selected_directory (data->tree_widget, &iter); if (sensitive) { gtk_tree_model_get (model, &iter, XEDIT_FILE_BROWSER_STORE_COLUMN_URI, &uri, -1); sensitive = xedit_utils_uri_has_file_scheme (uri); g_free (uri); } gtk_action_set_sensitive ( gtk_action_group_get_action (data->single_selection_action_group, "OpenTerminal"), sensitive); } #define POPUP_UI "" \ "" \ " " \ " " \ " " \ " " \ " " \ " " \ " " \ " " \ " " \ " " \ " " \ " " \ " " \ "" static GtkActionEntry extra_actions[] = { {"SetActiveRoot", GTK_STOCK_JUMP_TO, N_("_Set root to active document"), NULL, N_("Set the root to the active document location"), G_CALLBACK (on_action_set_active_root)} }; static GtkActionEntry extra_single_selection_actions[] = { {"OpenTerminal", "utilities-terminal", N_("_Open terminal here"), NULL, N_("Open a terminal at the currently opened directory"), G_CALLBACK (on_action_open_terminal)} }; static void add_popup_ui (XeditWindow * window) { XeditFileBrowserPluginData * data; GtkUIManager * manager; GtkActionGroup * action_group; GError * error = NULL; data = get_plugin_data (window); manager = xedit_file_browser_widget_get_ui_manager (data->tree_widget); action_group = gtk_action_group_new ("FileBrowserPluginExtra"); gtk_action_group_set_translation_domain (action_group, NULL); gtk_action_group_add_actions (action_group, extra_actions, G_N_ELEMENTS (extra_actions), window); gtk_ui_manager_insert_action_group (manager, action_group, 0); data->action_group = action_group; action_group = gtk_action_group_new ("FileBrowserPluginSingleSelectionExtra"); gtk_action_group_set_translation_domain (action_group, NULL); gtk_action_group_add_actions (action_group, extra_single_selection_actions, G_N_ELEMENTS (extra_single_selection_actions), window); gtk_ui_manager_insert_action_group (manager, action_group, 0); data->single_selection_action_group = action_group; data->merge_id = gtk_ui_manager_add_ui_from_string (manager, POPUP_UI, -1, &error); if (data->merge_id == 0) { g_warning("Unable to merge UI: %s", error->message); g_error_free(error); } } static void remove_popup_ui (XeditWindow * window) { XeditFileBrowserPluginData * data; GtkUIManager * manager; data = get_plugin_data (window); manager = xedit_file_browser_widget_get_ui_manager (data->tree_widget); gtk_ui_manager_remove_ui (manager, data->merge_id); gtk_ui_manager_remove_action_group (manager, data->action_group); g_object_unref (data->action_group); gtk_ui_manager_remove_action_group (manager, data->single_selection_action_group); g_object_unref (data->single_selection_action_group); } static void impl_updateui (XeditPlugin * plugin, XeditWindow * window) { XeditFileBrowserPluginData * data; XeditDocument * doc; data = get_plugin_data (window); doc = xedit_window_get_active_document (window); gtk_action_set_sensitive (gtk_action_group_get_action (data->action_group, "SetActiveRoot"), doc != NULL && !xedit_document_is_untitled (doc)); } static void impl_activate (XeditPlugin * plugin, XeditWindow * window) { XeditPanel * panel; XeditFileBrowserPluginData * data; GtkWidget * image; GdkPixbuf * pixbuf; XeditFileBrowserStore * store; gchar *data_dir; GSettingsSchemaSource *schema_source; GSettingsSchema *schema; data = g_new0 (XeditFileBrowserPluginData, 1); data_dir = xedit_plugin_get_data_dir (plugin); data->tree_widget = XEDIT_FILE_BROWSER_WIDGET (xedit_file_browser_widget_new (data_dir)); g_free (data_dir); data->settings = g_settings_new (FILE_BROWSER_SCHEMA); data->onload_settings = g_settings_new (FILE_BROWSER_ONLOAD_SCHEMA); data->terminal_settings = g_settings_new (TERMINAL_SCHEMA); g_signal_connect (data->tree_widget, "uri-activated", G_CALLBACK (on_uri_activated_cb), window); g_signal_connect (data->tree_widget, "error", G_CALLBACK (on_error_cb), window); g_signal_connect (data->tree_widget, "notify::filter-pattern", G_CALLBACK (on_filter_pattern_changed_cb), window); g_signal_connect (data->tree_widget, "confirm-delete", G_CALLBACK (on_confirm_delete_cb), window); g_signal_connect (data->tree_widget, "confirm-no-trash", G_CALLBACK (on_confirm_no_trash_cb), window); g_signal_connect (gtk_tree_view_get_selection (GTK_TREE_VIEW (xedit_file_browser_widget_get_browser_view (data->tree_widget))), "changed", G_CALLBACK (on_selection_changed_cb), window); panel = xedit_window_get_side_panel (window); pixbuf = xedit_file_browser_utils_pixbuf_from_theme("system-file-manager", GTK_ICON_SIZE_MENU); if (pixbuf) { image = gtk_image_new_from_pixbuf(pixbuf); g_object_unref(pixbuf); } else { image = gtk_image_new_from_stock(GTK_STOCK_INDEX, GTK_ICON_SIZE_MENU); } gtk_widget_show(image); xedit_panel_add_item (panel, GTK_WIDGET (data->tree_widget), _("File Browser"), image); gtk_widget_show (GTK_WIDGET (data->tree_widget)); g_object_set_data (G_OBJECT (window), WINDOW_DATA_KEY, data); add_popup_ui (window); /* Restore filter options */ restore_filter (data); /* Connect signals to store the last visited location */ g_signal_connect (xedit_file_browser_widget_get_browser_view (data->tree_widget), "notify::model", G_CALLBACK (on_model_set_cb), window); store = xedit_file_browser_widget_get_browser_store (data->tree_widget); g_signal_connect (store, "notify::virtual-root", G_CALLBACK (on_virtual_root_changed_cb), window); g_signal_connect (store, "notify::filter-mode", G_CALLBACK (on_filter_mode_changed_cb), window); g_signal_connect (store, "rename", G_CALLBACK (on_rename_cb), window); g_signal_connect (window, "tab-added", G_CALLBACK (on_tab_added_cb), data); /* Register messages on the bus */ xedit_file_browser_messages_register (window, data->tree_widget); impl_updateui (plugin, window); } static void impl_deactivate (XeditPlugin * plugin, XeditWindow * window) { XeditFileBrowserPluginData * data; XeditPanel * panel; data = get_plugin_data (window); /* Unregister messages from the bus */ xedit_file_browser_messages_unregister (window); /* Disconnect signals */ g_signal_handlers_disconnect_by_func (window, G_CALLBACK (on_tab_added_cb), data); g_object_unref (data->settings); g_object_unref (data->onload_settings); g_object_unref (data->terminal_settings); remove_popup_ui (window); panel = xedit_window_get_side_panel (window); xedit_panel_remove_item (panel, GTK_WIDGET (data->tree_widget)); g_free (data); g_object_set_data (G_OBJECT (window), WINDOW_DATA_KEY, NULL); } static void filetree_plugin_class_init (XeditFileBrowserPluginClass * klass) { GObjectClass *object_class = G_OBJECT_CLASS (klass); XeditPluginClass * plugin_class = XEDIT_PLUGIN_CLASS (klass); object_class->finalize = filetree_plugin_finalize; plugin_class->activate = impl_activate; plugin_class->deactivate = impl_deactivate; plugin_class->update_ui = impl_updateui; g_type_class_add_private (object_class, sizeof (XeditFileBrowserPluginPrivate)); } /* Callbacks */ static void on_uri_activated_cb (XeditFileBrowserWidget * tree_widget, gchar const *uri, XeditWindow * window) { xedit_commands_load_uri (window, uri, NULL, 0); } static void on_error_cb (XeditFileBrowserWidget * tree_widget, guint code, gchar const *message, XeditWindow * window) { gchar * title; GtkWidget * dlg; XeditFileBrowserPluginData * data; data = get_plugin_data (window); /* Do not show the error when the root has been set automatically */ if (data->auto_root && (code == XEDIT_FILE_BROWSER_ERROR_SET_ROOT || code == XEDIT_FILE_BROWSER_ERROR_LOAD_DIRECTORY)) { /* Show bookmarks */ xedit_file_browser_widget_show_bookmarks (data->tree_widget); return; } switch (code) { case XEDIT_FILE_BROWSER_ERROR_NEW_DIRECTORY: title = _("An error occurred while creating a new directory"); break; case XEDIT_FILE_BROWSER_ERROR_NEW_FILE: title = _("An error occurred while creating a new file"); break; case XEDIT_FILE_BROWSER_ERROR_RENAME: title = _ ("An error occurred while renaming a file or directory"); break; case XEDIT_FILE_BROWSER_ERROR_DELETE: title = _ ("An error occurred while deleting a file or directory"); break; case XEDIT_FILE_BROWSER_ERROR_OPEN_DIRECTORY: title = _ ("An error occurred while opening a directory in the file manager"); break; case XEDIT_FILE_BROWSER_ERROR_SET_ROOT: title = _("An error occurred while setting a root directory"); break; case XEDIT_FILE_BROWSER_ERROR_LOAD_DIRECTORY: title = _("An error occurred while loading a directory"); break; default: title = _("An error occurred"); break; } dlg = gtk_message_dialog_new (GTK_WINDOW (window), GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK, "%s", title); gtk_message_dialog_format_secondary_text (GTK_MESSAGE_DIALOG (dlg), "%s", message); gtk_dialog_run (GTK_DIALOG (dlg)); gtk_widget_destroy (dlg); } static void on_model_set_cb (XeditFileBrowserView * widget, GParamSpec *arg1, XeditWindow * window) { XeditFileBrowserPluginData * data = get_plugin_data (window); GtkTreeModel * model; model = gtk_tree_view_get_model (GTK_TREE_VIEW (xedit_file_browser_widget_get_browser_view (data->tree_widget))); if (model == NULL) return; g_settings_set_boolean (data->onload_settings, "tree-view", XEDIT_IS_FILE_BROWSER_STORE (model)); } static void on_filter_mode_changed_cb (XeditFileBrowserStore * model, GParamSpec * param, XeditWindow * window) { XeditFileBrowserPluginData * data = get_plugin_data (window); XeditFileBrowserStoreFilterMode mode; mode = xedit_file_browser_store_get_filter_mode (model); if ((mode & XEDIT_FILE_BROWSER_STORE_FILTER_MODE_HIDE_HIDDEN) && (mode & XEDIT_FILE_BROWSER_STORE_FILTER_MODE_HIDE_BINARY)) { g_settings_set_string (data->settings, "filter-mode", "hidden_and_binary"); } else if (mode & XEDIT_FILE_BROWSER_STORE_FILTER_MODE_HIDE_HIDDEN) { g_settings_set_string (data->settings, "filter-mode", "hidden"); } else if (mode & XEDIT_FILE_BROWSER_STORE_FILTER_MODE_HIDE_BINARY) { g_settings_set_string (data->settings, "filter-mode", "binary"); } else { g_settings_set_string (data->settings, "filter-mode", "none"); } } static void on_rename_cb (XeditFileBrowserStore * store, const gchar * olduri, const gchar * newuri, XeditWindow * window) { XeditApp * app; GList * documents; GList * item; XeditDocument * doc; GFile * docfile; GFile * oldfile; GFile * newfile; gchar * uri; /* Find all documents and set its uri to newuri where it matches olduri */ app = xedit_app_get_default (); documents = xedit_app_get_documents (app); oldfile = g_file_new_for_uri (olduri); newfile = g_file_new_for_uri (newuri); for (item = documents; item; item = item->next) { doc = XEDIT_DOCUMENT (item->data); uri = xedit_document_get_uri (doc); if (!uri) continue; docfile = g_file_new_for_uri (uri); if (g_file_equal (docfile, oldfile)) { xedit_document_set_uri (doc, newuri); } else { gchar *relative; relative = g_file_get_relative_path (oldfile, docfile); if (relative) { /* relative now contains the part in docfile without the prefix oldfile */ g_object_unref (docfile); g_free (uri); docfile = g_file_get_child (newfile, relative); uri = g_file_get_uri (docfile); xedit_document_set_uri (doc, uri); } g_free (relative); } g_free (uri); g_object_unref (docfile); } g_object_unref (oldfile); g_object_unref (newfile); g_list_free (documents); } static void on_filter_pattern_changed_cb (XeditFileBrowserWidget * widget, GParamSpec * param, XeditWindow * window) { XeditFileBrowserPluginData * data = get_plugin_data (window); gchar * pattern; g_object_get (G_OBJECT (widget), "filter-pattern", &pattern, NULL); if (pattern == NULL) g_settings_set_string (data->settings, "filter-pattern", ""); else g_settings_set_string (data->settings, "filter-pattern", pattern); g_free (pattern); } static void on_virtual_root_changed_cb (XeditFileBrowserStore * store, GParamSpec * param, XeditWindow * window) { XeditFileBrowserPluginData * data = get_plugin_data (window); gchar * root; gchar * virtual_root; root = xedit_file_browser_store_get_root (store); if (!root) return; g_settings_set_string (data->onload_settings, "root", root); virtual_root = xedit_file_browser_store_get_virtual_root (store); if (!virtual_root) { /* Set virtual to same as root then */ g_settings_set_string (data->onload_settings, "virtual-root", root); } else { g_settings_set_string (data->onload_settings, "virtual-root", virtual_root); } g_signal_handlers_disconnect_by_func (window, G_CALLBACK (on_tab_added_cb), data); g_free (root); g_free (virtual_root); } static void on_tab_added_cb (XeditWindow * window, XeditTab * tab, XeditFileBrowserPluginData * data) { gboolean open; gboolean load_default = TRUE; open = g_settings_get_boolean (data->settings, "open-at-first-doc"); if (open) { XeditDocument *doc; gchar *uri; doc = xedit_tab_get_document (tab); uri = xedit_document_get_uri (doc); if (uri != NULL && xedit_utils_uri_has_file_scheme (uri)) { prepare_auto_root (data); set_root_from_doc (data, doc); load_default = FALSE; } g_free (uri); } if (load_default) restore_default_location (data); /* Disconnect this signal, it's only called once */ g_signal_handlers_disconnect_by_func (window, G_CALLBACK (on_tab_added_cb), data); } static gchar * get_filename_from_path (GtkTreeModel *model, GtkTreePath *path) { GtkTreeIter iter; gchar *uri; gtk_tree_model_get_iter (model, &iter, path); gtk_tree_model_get (model, &iter, XEDIT_FILE_BROWSER_STORE_COLUMN_URI, &uri, -1); return xedit_file_browser_utils_uri_basename (uri); } static gboolean on_confirm_no_trash_cb (XeditFileBrowserWidget * widget, GList * files, XeditWindow * window) { gchar *normal; gchar *message; gchar *secondary; gboolean result; message = _("Cannot move file to trash, do you\nwant to delete permanently?"); if (files->next == NULL) { normal = xedit_file_browser_utils_file_basename (G_FILE (files->data)); secondary = g_strdup_printf (_("The file \"%s\" cannot be moved to the trash."), normal); g_free (normal); } else { secondary = g_strdup (_("The selected files cannot be moved to the trash.")); } result = xedit_file_browser_utils_confirmation_dialog (window, GTK_MESSAGE_QUESTION, message, secondary, GTK_STOCK_DELETE, NULL); g_free (secondary); return result; } static gboolean on_confirm_delete_cb (XeditFileBrowserWidget *widget, XeditFileBrowserStore *store, GList *paths, XeditWindow *window) { gchar *normal; gchar *message; gchar *secondary; gboolean result; XeditFileBrowserPluginData *data; data = get_plugin_data (window); if (paths->next == NULL) { normal = get_filename_from_path (GTK_TREE_MODEL (store), (GtkTreePath *)(paths->data)); message = g_strdup_printf (_("Are you sure you want to permanently delete \"%s\"?"), normal); g_free (normal); } else { message = g_strdup (_("Are you sure you want to permanently delete the selected files?")); } secondary = _("If you delete an item, it is permanently lost."); result = xedit_file_browser_utils_confirmation_dialog (window, GTK_MESSAGE_QUESTION, message, secondary, GTK_STOCK_DELETE, NULL); g_free (message); return result; } // ex:ts=8:noet: