summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Gryniewicz <dang@gentoo.org>2006-09-15 19:07:44 +0000
committerDaniel Gryniewicz <dang@gentoo.org>2006-09-15 19:07:44 +0000
commit07e4d5d5bc1cd99cc581a217a91d697e1745c656 (patch)
treecfae07a2ce90a77f08aae18fc3f3c08d4bfa527a /mail-client/evolution/files
parentMake repoman happy; remove hppa and ia64 until libnotify can be keyworded (diff)
downloadhistorical-07e4d5d5bc1cd99cc581a217a91d697e1745c656.tar.gz
historical-07e4d5d5bc1cd99cc581a217a91d697e1745c656.tar.bz2
historical-07e4d5d5bc1cd99cc581a217a91d697e1745c656.zip
Make repoman happy; remove hppa and ia64 until libnotify can be keyworded
Package-Manager: portage-2.1.1
Diffstat (limited to 'mail-client/evolution/files')
-rw-r--r--mail-client/evolution/files/evolution-2.8.0-uri.patch746
1 files changed, 0 insertions, 746 deletions
diff --git a/mail-client/evolution/files/evolution-2.8.0-uri.patch b/mail-client/evolution/files/evolution-2.8.0-uri.patch
deleted file mode 100644
index 118e8ee07aba..000000000000
--- a/mail-client/evolution/files/evolution-2.8.0-uri.patch
+++ /dev/null
@@ -1,746 +0,0 @@
-diff --exclude-from=/home/dang/.diffrc -u -ruN evolution-2.7.91.orig/calendar/gui/apps_evolution_calendar.schemas.in.in evolution-2.7.91.uri/calendar/gui/apps_evolution_calendar.schemas.in.in
---- evolution-2.7.91.orig/calendar/gui/apps_evolution_calendar.schemas.in.in 2006-08-07 00:47:42.000000000 -0400
-+++ evolution-2.7.91.uri/calendar/gui/apps_evolution_calendar.schemas.in.in 2006-08-24 13:06:28.000000000 -0400
-@@ -577,5 +577,19 @@
- <long>The URL template to use as a free/busy data fallback, %u is replaced by the user part of the mail address and %d is replaced by the domain.</long>
- </locale>
- </schema>
-+
-+ <schema>
-+ <key>/schemas/apps/evolution/calendar/audio_dir</key>
-+ <applyto>/apps/evolution/calendar/audio_dir</applyto>
-+ <owner>evolution-calendar</owner>
-+ <type>string</type>
-+ <locale name="C">
-+ <short>Save directory for alarm audio</short>
-+ <long>
-+ Directory for saving alarm audio files
-+ </long>
-+ </locale>
-+ </schema>
-+
- </schemalist>
- </gconfschemafile>
-diff --exclude-from=/home/dang/.diffrc -u -ruN evolution-2.7.91.orig/calendar/gui/calendar-config-keys.h evolution-2.7.91.uri/calendar/gui/calendar-config-keys.h
---- evolution-2.7.91.orig/calendar/gui/calendar-config-keys.h 2006-07-22 07:14:50.000000000 -0400
-+++ evolution-2.7.91.uri/calendar/gui/calendar-config-keys.h 2006-08-24 12:05:43.000000000 -0400
-@@ -91,7 +91,7 @@
- /* Free/Busy settings */
- #define CALENDAR_CONFIG_TEMPLATE CALENDAR_CONFIG_PREFIX"/publish/template"
-
--#define CALENDAR_CONFIG_SAVE_DIR "/apps/evolution/mail/save_dir"
-+#define CALENDAR_CONFIG_SAVE_DIR CALENDAR_CONFIG_PREFIX"/audio_dir"
- G_END_DECLS
-
- #endif
-diff --exclude-from=/home/dang/.diffrc -u -ruN evolution-2.7.91.orig/calendar/gui/dialogs/alarm-dialog.c evolution-2.7.91.uri/calendar/gui/dialogs/alarm-dialog.c
---- evolution-2.7.91.orig/calendar/gui/dialogs/alarm-dialog.c 2006-07-09 23:54:00.000000000 -0400
-+++ evolution-2.7.91.uri/calendar/gui/dialogs/alarm-dialog.c 2006-08-24 11:47:41.000000000 -0400
-@@ -1080,6 +1080,7 @@
- dir = calendar_config_get_dir_path ();
- if ( dir && *dir )
- gnome_file_entry_set_default_path (GNOME_FILE_ENTRY (dialog->aalarm_file_entry), dir);
-+ g_free(dir);
- check_custom_sound (dialog);
- break;
-
-diff --exclude-from=/home/dang/.diffrc -u -ruN evolution-2.7.91.orig/e-util/e-dialog-utils.c evolution-2.7.91.uri/e-util/e-dialog-utils.c
---- evolution-2.7.91.orig/e-util/e-dialog-utils.c 2006-05-31 23:29:48.000000000 -0400
-+++ evolution-2.7.91.uri/e-util/e-dialog-utils.c 2006-08-24 11:45:27.000000000 -0400
-@@ -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 @@
- 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 @@
- 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 --exclude-from=/home/dang/.diffrc -u -ruN evolution-2.7.91.orig/e-util/e-dialog-utils.h evolution-2.7.91.uri/e-util/e-dialog-utils.h
---- evolution-2.7.91.orig/e-util/e-dialog-utils.h 2005-10-18 05:57:20.000000000 -0400
-+++ evolution-2.7.91.uri/e-util/e-dialog-utils.h 2006-08-24 11:44:48.000000000 -0400
-@@ -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_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 --exclude-from=/home/dang/.diffrc -u -ruN evolution-2.7.91.orig/e-util/e-util.c evolution-2.7.91.uri/e-util/e-util.c
---- evolution-2.7.91.orig/e-util/e-util.c 2006-07-24 04:21:14.000000000 -0400
-+++ evolution-2.7.91.uri/e-util/e-util.c 2006-08-24 11:45:06.000000000 -0400
-@@ -1187,4 +1187,45 @@
- 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 --exclude-from=/home/dang/.diffrc -u -ruN evolution-2.7.91.orig/e-util/e-util.h evolution-2.7.91.uri/e-util/e-util.h
---- evolution-2.7.91.orig/e-util/e-util.h 2006-07-22 07:14:52.000000000 -0400
-+++ evolution-2.7.91.uri/e-util/e-util.h 2006-08-24 11:44:45.000000000 -0400
-@@ -215,6 +215,8 @@
- Less than 0 for the int means copy the whole string. */
- gchar *e_strdup_append_strings (gchar *first_string,
- ...);
-+void e_file_update_save_path(char *uri, gboolean free);
-+char *e_file_get_save_path(void);
- cairo_font_options_t * get_font_options ();
-
- #ifdef __cplusplus
-diff --exclude-from=/home/dang/.diffrc -u -ruN evolution-2.7.91.orig/mail/em-utils.c evolution-2.7.91.uri/mail/em-utils.c
---- evolution-2.7.91.orig/mail/em-utils.c 2006-05-31 23:29:48.000000000 -0400
-+++ evolution-2.7.91.uri/mail/em-utils.c 2006-08-23 23:50:18.000000000 -0400
-@@ -90,23 +90,6 @@
-
- #define d(x)
-
--static gboolean
--emu_file_check_local (const char *name)
--{
-- CamelURL *url;
-- gboolean local = FALSE;
--
-- url = camel_url_new (name, NULL);
-- if (url == NULL)
-- return TRUE;
--
-- if (!g_ascii_strcasecmp (url->protocol, "file"))
-- local = TRUE;
--
-- camel_url_free (url);
--
-- return local;
--}
- /**
- * em_utils_prompt_user:
- * @parent: parent window
-@@ -375,119 +358,24 @@
-
- /* Saving messages... */
-
--static GtkWidget *
--emu_get_save_filesel (GtkWidget *parent, const char *title, const char *name, GtkFileChooserAction action)
--{
-- GtkWidget *filesel;
-- const char *dir;
-- char *realname, *gdir;
-- GConfClient *gconf;
--
--#ifdef USE_GTKFILECHOOSER
-- 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 (filesel, FALSE);
--#else
-- char *filename;
--
-- filesel = gtk_file_selection_new (title);
--#endif
--
-- if (parent)
-- e_dialog_set_transient_for((GtkWindow *)filesel, parent);
--
-- 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 = g_get_home_dir();
--
-- if (name && name[0]) {
-- realname = g_strdup (name);
-- em_filename_make_safe (realname);
-- } else {
-- realname = NULL;
-- }
--
--#ifdef USE_GTKFILECHOOSER
-- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (filesel), dir);
--
-- if (realname)
-- gtk_file_chooser_set_current_name (GTK_FILE_CHOOSER (filesel), realname);
--#else
-- filename = g_build_filename (dir, G_DIR_SEPARATOR_S, realname, NULL);
-- gtk_file_selection_set_filename (GTK_FILE_SELECTION (filesel), filename);
-- g_free (filename);
--#endif
--
-- g_free (realname);
-- g_free (gdir);
--
-- return filesel;
--}
--
--static void
--emu_update_save_path(const char *filename, gboolean path)
--{
-- char *dir = path ? (char *)filename : g_path_get_dirname(filename);
-- GConfClient *gconf = gconf_client_get_default();
--
-- gconf_client_set_string(gconf, "/apps/evolution/mail/save_dir", dir, NULL);
-- g_object_unref(gconf);
-- if (!path)
-- g_free(dir);
--}
--
--static gboolean
--emu_can_save(GtkWindow *parent, const char *path)
--{
-- struct stat st;
--
-- if (!path || path[0] == 0)
-- return FALSE;
--
-- /* make sure we can actually save to it... */
-- if (g_stat (path, &st) != -1 && !S_ISREG (st.st_mode))
-- return FALSE;
--
-- 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);
-- return FALSE;
-- }
--
-- return e_error_run(parent, E_ERROR_ASK_FILE_EXISTS_OVERWRITE, path, NULL) == GTK_RESPONSE_OK;
-- }
--
-- return TRUE;
--}
--
- static void
- emu_save_part_response(GtkWidget *filesel, int response, CamelMimePart *part)
- {
-- const char *path;
-- const char *uri;
-+ char *uri;
-
- if (response == GTK_RESPONSE_OK) {
--#ifdef USE_GTKFILECHOOSER
- uri = gtk_file_chooser_get_uri (GTK_FILE_CHOOSER (filesel));
-- path = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (filesel));
--#else
-- path = gtk_file_selection_get_filename (GTK_FILE_SELECTION (filesel));
--#endif
-
-- if (emu_file_check_local(uri) && !emu_can_save((GtkWindow *)filesel, path))
-+ if (!e_file_can_save((GtkWindow *)filesel, uri)) {
-+ g_free(uri);
- return;
-+ }
-
-- emu_update_save_path(path, FALSE);
-+ e_file_update_save_path(gtk_file_chooser_get_current_folder_uri(
-+ GTK_FILE_CHOOSER(filesel)), TRUE);
- /* FIXME: popup error if it fails? */
- mail_save_part(part, uri, NULL, NULL, FALSE);
-+ g_free(uri);
- }
-
- gtk_widget_destroy((GtkWidget *)filesel);
-@@ -519,7 +407,7 @@
- }
- }
-
-- filesel = emu_get_save_filesel(parent, prompt, name, GTK_FILE_CHOOSER_ACTION_SAVE);
-+ filesel = e_file_get_save_filesel(parent, prompt, name, GTK_FILE_CHOOSER_ACTION_SAVE);
- camel_object_ref(part);
- g_signal_connect (filesel, "response", G_CALLBACK (emu_save_part_response), part);
- gtk_widget_show (filesel);
-@@ -528,16 +416,11 @@
- static void
- emu_save_parts_response (GtkWidget *filesel, int response, GSList *parts)
- {
-- char *path = NULL;
- GSList *selected;
-+ char *uri = NULL;
- if (response == GTK_RESPONSE_OK) {
--#ifdef USE_GTKFILECHOOSER
-- path = gtk_file_chooser_get_current_folder_uri (GTK_FILE_CHOOSER (filesel));
--#else
-- path = gtk_file_selection_get_filename (GTK_FILE_SELECTION (filesel));
--#endif
--
-- emu_update_save_path(path, TRUE);
-+ uri = gtk_file_chooser_get_current_folder_uri(GTK_FILE_CHOOSER (filesel));
-+ e_file_update_save_path(uri, FALSE);
-
- for ( selected = parts; selected != NULL; selected = selected->next) {
- const char *file_name;
-@@ -560,8 +443,8 @@
- file_name = safe_name;
- }
-
-- file_path = g_build_filename (path, file_name, NULL);
-- if (!g_file_test(file_path, (G_FILE_TEST_EXISTS)) || e_error_run(NULL, E_ERROR_ASK_FILE_EXISTS_OVERWRITE, file_name, NULL) == GTK_RESPONSE_OK)
-+ file_path = g_build_filename (uri, file_name, NULL);
-+ if (!e_file_check_local(file_path) || !g_file_test(file_path, (G_FILE_TEST_EXISTS)) || e_error_run(NULL, E_ERROR_ASK_FILE_EXISTS_OVERWRITE, file_name, NULL) == GTK_RESPONSE_OK)
- mail_save_part(part, file_path, NULL, NULL, FALSE);
- else
- g_warning ("Could not save %s. File already exists", file_path);
-@@ -570,7 +453,7 @@
- g_free (safe_name);
- }
-
-- g_free (path);
-+ g_free (uri);
- }
-
- g_slist_free (parts);
-@@ -582,7 +465,7 @@
- {
- GtkWidget *filesel;
-
-- filesel = emu_get_save_filesel (parent, prompt, NULL, GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER);
-+ filesel = e_file_get_save_filesel (parent, prompt, NULL, GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER);
- g_signal_connect (filesel, "response", G_CALLBACK (emu_save_parts_response), parts);
- gtk_widget_show (filesel);
- }
-@@ -643,21 +526,21 @@
- static void
- emu_save_messages_response(GtkWidget *filesel, int response, struct _save_messages_data *data)
- {
-- const char *path;
-+ char *uri;
-
- if (response == GTK_RESPONSE_OK) {
--#ifdef USE_GTKFILECHOOSER
-- path = gtk_file_chooser_get_uri (GTK_FILE_CHOOSER (filesel));
--#else
-- path = gtk_file_selection_get_filename (GTK_FILE_SELECTION (filesel));
--#endif
-+ uri = gtk_file_chooser_get_uri (GTK_FILE_CHOOSER (filesel));
-
-- if (!emu_can_save((GtkWindow *)filesel, path))
-+ if (!e_file_can_save((GtkWindow *)filesel, uri)) {
-+ g_free(uri);
- return;
-+ }
-
-- emu_update_save_path(path, FALSE);
-- mail_save_messages(data->folder, data->uids, path, NULL, NULL);
-+ e_file_update_save_path(gtk_file_chooser_get_current_folder_uri(
-+ GTK_FILE_CHOOSER (filesel)), TRUE);
-+ mail_save_messages(data->folder, data->uids, uri, NULL, NULL);
- data->uids = NULL;
-+ g_free(uri);
- }
-
- camel_object_unref(data->folder);
-@@ -685,7 +568,7 @@
- g_return_if_fail (CAMEL_IS_FOLDER (folder));
- g_return_if_fail (uids != NULL);
-
-- filesel = emu_get_save_filesel(parent, _("Save Message..."), NULL, GTK_FILE_CHOOSER_ACTION_SAVE);
-+ filesel = e_file_get_save_filesel(parent, _("Save Message..."), NULL, GTK_FILE_CHOOSER_ACTION_SAVE);
- camel_object_ref(folder);
-
- data = g_malloc(sizeof(struct _save_messages_data));
-diff --exclude-from=/home/dang/.diffrc -u -ruN evolution-2.7.91.orig/mail/evolution-mail.schemas.in.in evolution-2.7.91.uri/mail/evolution-mail.schemas.in.in
---- evolution-2.7.91.orig/mail/evolution-mail.schemas.in.in 2006-07-22 07:14:53.000000000 -0400
-+++ evolution-2.7.91.uri/mail/evolution-mail.schemas.in.in 2006-08-24 13:04:58.000000000 -0400
-@@ -913,5 +913,20 @@
- </locale>
- </schema>
-
-+ <!-- save directory settings -->
-+
-+ <schema>
-+ <key>/schemas/apps/evolution/mail/save_dir</key>
-+ <applyto>/apps/evolution/mail/save_dir</applyto>
-+ <owner>evolution-mail</owner>
-+ <type>string</type>
-+ <locale name="C">
-+ <short>Save directory</short>
-+ <long>
-+ Directory for saving mail component files
-+ </long>
-+ </locale>
-+ </schema>
-+
- </schemalist>
- </gconfschemafile>