From 6d689d6e0030c76ce74518af374cfbb0d0960a4c Mon Sep 17 00:00:00 2001 From: Diego Escalante Urrelo Date: Fri, 28 Sep 2007 21:45:48 +0000 Subject: Implement ephy_file_delete_directory in lib/ephy-file-helpers.c so private instances of Epiphany remove the profile dir on exit. Note that the profile dir won't be deleted if it's a custom path. Fixes bug #329680. svn path=/trunk/; revision=7506 --- lib/ephy-file-helpers.c | 32 ++++++++++++++++++++++++++++---- src/ephy-main.c | 2 +- 2 files changed, 29 insertions(+), 5 deletions(-) diff --git a/lib/ephy-file-helpers.c b/lib/ephy-file-helpers.c index 283715c59..3433afeaa 100644 --- a/lib/ephy-file-helpers.c +++ b/lib/ephy-file-helpers.c @@ -36,6 +36,7 @@ #include #include #include +#include #include /* bug http://bugzilla.gnome.org/show_bug.cgi?id=156687 */ @@ -350,11 +351,8 @@ ephy_file_helpers_shutdown (void) { if (!keep_temp_directory) { - /* recursively delete the contents */ + /* recursively delete the contents and the directory */ ephy_file_delete_directory (tmp_dir); - - /* delete the directory itself too */ - rmdir (tmp_dir); } g_free (tmp_dir); @@ -1218,8 +1216,34 @@ ephy_file_monitor_cancel (EphyFileMonitor *monitor) g_free (monitor); } +/** + * ephy_file_delete_directory: + * @path: the path to remove + * + * Remove @path and its contents. Like calling rm -rf @path. + * + **/ void ephy_file_delete_directory (const char *path) { /* FIXME not implemented yet */ + GList *list; + GnomeVFSResult ret; + + list = g_list_append (NULL, gnome_vfs_uri_new (path)); + + ret = gnome_vfs_xfer_delete_list (list, GNOME_VFS_XFER_ERROR_MODE_ABORT, + GNOME_VFS_XFER_EMPTY_DIRECTORIES, + NULL, NULL); + + gnome_vfs_uri_list_free (list); + + if (ret == GNOME_VFS_OK) + { + LOG ("Deleted the profile dir '%s'", path); + } + else + { + LOG ("Couldn't delete profile dir '%s'", path); + } } diff --git a/src/ephy-main.c b/src/ephy-main.c index b3f0dc30c..bf71e2156 100644 --- a/src/ephy-main.c +++ b/src/ephy-main.c @@ -675,7 +675,7 @@ main (int argc, if (!ephy_file_helpers_init (profile_directory, private_instance, - keep_temp_directory, + keep_temp_directory || profile_directory, &error)) { _ephy_dbus_release (); -- cgit v1.2.3