aboutsummaryrefslogtreecommitdiffstats
path: root/e-util
diff options
context:
space:
mode:
Diffstat (limited to 'e-util')
-rw-r--r--e-util/ChangeLog12
-rw-r--r--e-util/e-dialog-utils.c239
-rw-r--r--e-util/e-dialog-utils.h6
-rw-r--r--e-util/e-util.c41
-rw-r--r--e-util/e-util.h3
5 files changed, 185 insertions, 116 deletions
diff --git a/e-util/ChangeLog b/e-util/ChangeLog
index a0e1bf8f38..57bf7fd461 100644
--- a/e-util/ChangeLog
+++ b/e-util/ChangeLog
@@ -1,3 +1,15 @@
+2006-11-28 Daniel Gryniewicz <dang@gentoo.org>
+
+ ** Fix for bug #349966
+
+ * e-dialog-utils.c: (save_ok), (filechooser_response),
+ (e_file_dialog_save), (save_folder_ok), (folderchooser_response),
+ (e_file_dialog_save_folder), (e_file_get_save_filesel),
+ (e_file_can_save), (e_file_check_local):
+ * e-dialog-utils.h:
+ * e-util.c: (e_file_update_save_path), (e_file_get_save_path):
+ * e-util.h:
+
2006-11-20 Harish Krishnaswamy <kharish@novell.com>
* e-icon-factory.c: (load_icon), (e_icon_factory_get_icon):
diff --git a/e-util/e-dialog-utils.c b/e-util/e-dialog-utils.c
index 44c5c24194..581c24240c 100644
--- a/e-util/e-dialog-utils.c
+++ b/e-util/e-dialog-utils.c
@@ -28,6 +28,10 @@
#include "e-dialog-utils.h"
+#include <unistd.h>
+#include <glib.h>
+#include <glib/gstdio.h>
+
#include <gdkconfig.h>
#ifdef GDK_WINDOWING_X11
#include <gdk/gdkx.h>
@@ -37,18 +41,19 @@
#include <gtk/gtkplug.h>
#include <gtk/gtkversion.h>
-#ifdef USE_GTKFILECHOOSER
#include <gtk/gtkfilechooser.h>
#include <gtk/gtkfilechooserdialog.h>
#include <gtk/gtkstock.h>
-#else
-#include <gtk/gtkfilesel.h>
-#endif
#include <gconf/gconf-client.h>
#include <libgnome/gnome-i18n.h>
#include <libgnome/gnome-util.h>
+#include <libgnomevfs/gnome-vfs-utils.h>
+
+#include "e-util/e-util.h"
+#include "e-util/e-error.h"
+
/**
* e_notice:
@@ -261,104 +266,42 @@ save_ok (GtkWidget *widget, gpointer data)
GtkWidget *fs;
char **filename = data;
char *uri;
- const char *path;
- int btn = GTK_RESPONSE_YES;
- GConfClient *gconf = gconf_client_get_default();
- char *dir;
fs = gtk_widget_get_toplevel (widget);
-#ifdef USE_GTKFILECHOOSER
- path = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (fs));
uri = gtk_file_chooser_get_uri (GTK_FILE_CHOOSER (fs));
-#else
- path = gtk_file_selection_get_filename (GTK_FILE_SELECTION (fs));
-#endif
-
- if (g_file_test (path, G_FILE_TEST_IS_REGULAR)) {
- GtkWidget *dlg;
-
- dlg = gtk_message_dialog_new (GTK_WINDOW (fs), 0,
- GTK_MESSAGE_QUESTION,
- GTK_BUTTONS_YES_NO,
- _("A file by that name already exists.\n"
- "Overwrite it?"));
- gtk_window_set_title (GTK_WINDOW (dlg), _("Overwrite file?"));
- gtk_dialog_set_has_separator (GTK_DIALOG (dlg), FALSE);
-
- btn = gtk_dialog_run (GTK_DIALOG (dlg));
- gtk_widget_destroy (dlg);
- }
- if (btn == GTK_RESPONSE_YES) {
- dir = g_path_get_dirname (path);
- gconf_client_set_string(gconf, "/apps/evolution/mail/save_dir", dir, NULL);
- g_free (dir);
+ if (e_file_can_save((GtkWindow *)widget, uri)) {
+ e_file_update_save_path(gtk_file_chooser_get_current_folder_uri(GTK_FILE_CHOOSER(fs)), TRUE);
*filename = uri;
}
- g_object_unref(gconf);
gtk_main_quit ();
}
-#ifdef USE_GTKFILECHOOSER
static void
filechooser_response (GtkWidget *fc, gint response_id, gpointer data)
{
- if (response_id == GTK_RESPONSE_ACCEPT)
+ if (response_id == GTK_RESPONSE_OK)
save_ok (fc, data);
else
gtk_widget_destroy (fc);
}
-#endif
char *
e_file_dialog_save (const char *title, const char *fname)
{
GtkWidget *selection;
char *filename = NULL;
- char *dir, *gdir = NULL;
- GConfClient *gconf;
-
- gconf = gconf_client_get_default();
- dir = gdir = gconf_client_get_string(gconf, "/apps/evolution/mail/save_dir", NULL);
- g_object_unref(gconf);
-
- if (dir == NULL)
- dir = (char *)g_get_home_dir();
-
-#ifdef USE_GTKFILECHOOSER
- selection = gtk_file_chooser_dialog_new (title,
- NULL,
- GTK_FILE_CHOOSER_ACTION_SAVE,
- GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
- GTK_STOCK_SAVE, GTK_RESPONSE_ACCEPT,
- NULL);
- gtk_dialog_set_default_response (GTK_DIALOG (selection), GTK_RESPONSE_ACCEPT);
- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (selection), dir);
- gtk_file_chooser_set_local_only (selection, FALSE);
-
- if (fname)
- gtk_file_chooser_set_current_name(GTK_FILE_CHOOSER (selection), fname);
-
- g_signal_connect (G_OBJECT (selection), "response", G_CALLBACK (filechooser_response), &filename);
-#else
- char *path;
- selection = gtk_file_selection_new (title);
- path = g_strdup_printf ("%s/", dir);
- gtk_file_selection_set_filename (GTK_FILE_SELECTION (selection), path);
- g_free (path);
+ selection = e_file_get_save_filesel(NULL, title, fname, GTK_FILE_CHOOSER_ACTION_SAVE);
- g_signal_connect (G_OBJECT (GTK_FILE_SELECTION (selection)->ok_button), "clicked", G_CALLBACK (save_ok), &filename);
- g_signal_connect (G_OBJECT (GTK_FILE_SELECTION (selection)->cancel_button), "clicked", G_CALLBACK (gtk_main_quit), NULL);
-#endif
+ g_signal_connect (G_OBJECT (selection), "response", G_CALLBACK (filechooser_response), &filename);
gtk_widget_show (GTK_WIDGET (selection));
gtk_grab_add (GTK_WIDGET (selection));
gtk_main ();
gtk_widget_destroy (GTK_WIDGET (selection));
- g_free (gdir);
return filename;
}
@@ -369,83 +312,147 @@ save_folder_ok (GtkWidget *widget, gpointer data)
GtkWidget *fs;
char **filename = data;
char *uri;
- const char *path;
- GConfClient *gconf = gconf_client_get_default();
fs = gtk_widget_get_toplevel (widget);
-#ifdef USE_GTKFILECHOOSER
- path = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (fs));
uri = gtk_file_chooser_get_current_folder_uri (GTK_FILE_CHOOSER (fs));
-#else
- path = gtk_file_selection_get_filename (GTK_FILE_SELECTION (fs));
-#endif
- gconf_client_set_string(gconf, "/apps/evolution/mail/save_dir", path, NULL);
- g_object_unref(gconf);
+ e_file_update_save_path(uri, FALSE);
*filename = uri;
gtk_main_quit ();
}
-#ifdef USE_GTKFILECHOOSER
static void
folderchooser_response (GtkWidget *fc, gint response_id, gpointer data)
{
- if (response_id == GTK_RESPONSE_ACCEPT)
+ if (response_id == GTK_RESPONSE_OK)
save_folder_ok (fc, data);
else
gtk_widget_destroy (fc);
}
-#endif
char *
e_file_dialog_save_folder (const char *title)
{
GtkWidget *selection;
-#ifndef USE_GTKFILECHOOSER
- char *path;
-#endif
char *filename = NULL;
- char *dir, *gdir = NULL;
- GConfClient *gconf;
-
- gconf = gconf_client_get_default();
- dir = gdir = gconf_client_get_string(gconf, "/apps/evolution/mail/save_dir", NULL);
- g_object_unref(gconf);
-
- if (dir == NULL)
- dir = (char *)g_get_home_dir();
-
-#ifdef USE_GTKFILECHOOSER
- selection = gtk_file_chooser_dialog_new (title,
- NULL,
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
- GTK_STOCK_SAVE, GTK_RESPONSE_ACCEPT,
- NULL);
- gtk_dialog_set_default_response (GTK_DIALOG (selection), GTK_RESPONSE_ACCEPT);
- gtk_file_chooser_set_local_only (selection, FALSE);
- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (selection), dir);
+ selection = e_file_get_save_filesel(NULL, title, NULL, GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER);
g_signal_connect (G_OBJECT (selection), "response", G_CALLBACK (folderchooser_response), &filename);
-#else
- selection = gtk_file_selection_new (title);
- path = g_strdup_printf ("%s/", dir);
- gtk_file_selection_set_filename (GTK_FILE_SELECTION (selection), path);
- g_free (path);
-
- g_signal_connect (G_OBJECT (GTK_FILE_SELECTION (selection)->ok_button), "clicked", G_CALLBACK (save_folder_ok), &filename);
- g_signal_connect (G_OBJECT (GTK_FILE_SELECTION (selection)->cancel_button), "clicked", G_CALLBACK (gtk_main_quit), NULL);
-#endif
gtk_widget_show (GTK_WIDGET (selection));
gtk_grab_add (GTK_WIDGET (selection));
gtk_main ();
gtk_widget_destroy (GTK_WIDGET (selection));
- g_free (gdir);
return filename;
}
+/**
+ * e_file_get_save_filesel:
+ * @parent: parent window
+ * @title: dialog title
+ * @name: filename
+ * @action: action for dialog
+ *
+ * Creates a save dialog, using the saved directory from gconf. The dialog has
+ * no signals connected and is not shown.
+ **/
+GtkWidget *
+e_file_get_save_filesel (GtkWidget *parent, const char *title, const char *name, GtkFileChooserAction action)
+{
+ GtkWidget *filesel;
+ char *realname, *uri;
+
+ filesel = gtk_file_chooser_dialog_new (title,
+ NULL,
+ action,
+ GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
+ GTK_STOCK_SAVE, GTK_RESPONSE_OK,
+ NULL);
+ gtk_dialog_set_default_response (GTK_DIALOG (filesel), GTK_RESPONSE_OK);
+ gtk_file_chooser_set_local_only (GTK_FILE_CHOOSER (filesel), FALSE);
+
+ if (parent)
+ e_dialog_set_transient_for((GtkWindow *)filesel, parent);
+
+ uri = e_file_get_save_path();
+
+ if (name && name[0]) {
+ realname = gnome_vfs_escape_string (name);
+ } else {
+ realname = NULL;
+ }
+
+ gtk_file_chooser_set_current_folder_uri (GTK_FILE_CHOOSER (filesel), uri);
+
+ if (realname)
+ gtk_file_chooser_set_current_name (GTK_FILE_CHOOSER (filesel), realname);
+
+ g_free (realname);
+ g_free (uri);
+
+ return filesel;
+}
+
+/**
+ * e_file_can_save:
+ *
+ * Return TRUE if the URI can be saved to, FALSE otherwise. It checks local
+ * files to see if they're regular and can be accessed. If the file exists and
+ * is writable, it pops up a dialog asking the user if they want to overwrite
+ * it. Returns the users choice.
+ **/
+gboolean
+e_file_can_save(GtkWindow *parent, const char *uri)
+{
+ struct stat st;
+ char *path;
+ gboolean res;
+
+ if (!uri || uri[0] == 0)
+ return FALSE;
+
+ /* Assume remote files are writable; too costly to check */
+ if (!e_file_check_local(uri))
+ return TRUE;
+
+ path = gnome_vfs_get_local_path_from_uri(uri);
+ if (!path)
+ return FALSE;
+ /* make sure we can actually save to it... */
+ if (g_stat (path, &st) != -1 && !S_ISREG (st.st_mode)) {
+ g_free(path);
+ return FALSE;
+ }
+
+ res = TRUE;
+ if (g_access (path, F_OK) == 0) {
+ if (g_access (path, W_OK) != 0) { e_error_run(parent, "mail:no-save-path", path, g_strerror(errno), NULL);
+ g_free(path);
+ return FALSE;
+ }
+
+ res = e_error_run(parent, E_ERROR_ASK_FILE_EXISTS_OVERWRITE, path, NULL) == GTK_RESPONSE_OK;
+
+ }
+
+ g_free(path);
+ return res;
+}
+
+gboolean
+e_file_check_local (const char *name)
+{
+ char *uri;
+
+ uri = gnome_vfs_get_local_path_from_uri(name);
+ if (uri) {
+ g_free(uri);
+ return TRUE;
+ }
+
+ return FALSE;
+}
diff --git a/e-util/e-dialog-utils.h b/e-util/e-dialog-utils.h
index 6ae3a2ec23..57cfac90c3 100644
--- a/e-util/e-dialog-utils.h
+++ b/e-util/e-dialog-utils.h
@@ -24,6 +24,7 @@
#define E_DIALOG_UTILS_H
#include <gtk/gtkmessagedialog.h>
+#include <gtk/gtkfilechooser.h>
void e_notice (gpointer parent,
GtkMessageType type,
@@ -43,5 +44,10 @@ char *e_file_dialog_save (const char *title, const char *fname)
char *e_file_dialog_save_folder (const char *title);
+GtkWidget * e_file_get_save_filesel (GtkWidget *parent, const char *title, const char *name, GtkFileChooserAction action);
+
+gboolean e_file_can_save(GtkWindow *parent, const char *uri);
+gboolean e_file_check_local(const char *name);
+
#endif
diff --git a/e-util/e-util.c b/e-util/e-util.c
index d213296041..5d854e0d51 100644
--- a/e-util/e-util.c
+++ b/e-util/e-util.c
@@ -1187,4 +1187,45 @@ get_font_options ()
return font_options;
}
+/**
+ * e_file_update_save_path:
+ * @uri: URI to store
+ * @free: If TRUE, free uri
+ *
+ * Save the save_dir path for evolution. If free is TRUE, uri gets freed when
+ * done. Genearally, this should be called with the output of
+ * gtk_file_chooser_get_current_folder_uri() The URI must be a path URI, not a
+ * file URI.
+ **/
+void
+e_file_update_save_path(char *uri, gboolean free)
+{
+ GConfClient *gconf = gconf_client_get_default();
+
+ gconf_client_set_string(gconf, "/apps/evolution/mail/save_dir", uri, NULL);
+ g_object_unref(gconf);
+ if (free)
+ g_free(uri);
+}
+
+/**
+ * e_file_get_save_path:
+ *
+ * Return the save_dir path for evolution. If there isn't a save_dir, returns
+ * the users home directory. Returns an allocated URI that should be freed by
+ * the caller.
+ **/
+char *
+e_file_get_save_path(void)
+{
+ GConfClient *gconf = gconf_client_get_default();
+ char *uri;
+
+ uri = gconf_client_get_string(gconf, "/apps/evolution/mail/save_dir", NULL);
+ g_object_unref(gconf);
+
+ if (uri == NULL)
+ uri = gnome_vfs_get_uri_from_local_path(g_get_home_dir());
+ return (uri);
+}
diff --git a/e-util/e-util.h b/e-util/e-util.h
index 1d3d6ba150..d0faa995d8 100644
--- a/e-util/e-util.h
+++ b/e-util/e-util.h
@@ -217,6 +217,9 @@ gchar *e_strdup_append_strings (gcha
...);
cairo_font_options_t * get_font_options ();
+void e_file_update_save_path(char *uri, gboolean free);
+char *e_file_get_save_path(void);
+
#ifdef __cplusplus
}
#endif /* __cplusplus */