From 8a2afc351781ab3af6b151f276fcdf87b8519f25 Mon Sep 17 00:00:00 2001 From: Ettore Perazzoli Date: Thu, 13 Dec 2001 00:45:09 +0000 Subject: New helper function to create the `~/evolution/private' directory. * e-setup.c (setup_bonobo_conf_private_directory): New helper function to create the `~/evolution/private' directory. (e_setup): Call it. svn path=/trunk/; revision=15012 --- shell/e-setup.c | 49 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) (limited to 'shell/e-setup.c') diff --git a/shell/e-setup.c b/shell/e-setup.c index fb5930bef6..31c16eca2b 100644 --- a/shell/e-setup.c +++ b/shell/e-setup.c @@ -265,6 +265,52 @@ e_shell_rm_dir (const char *path) } } + +/* FIXME: This is a workaround for bonobo-conf breakage. */ +static gboolean +setup_bonobo_conf_private_directory (const char *evolution_directory) +{ + char *name; + struct stat buf; + + name = g_concat_dir_and_file (evolution_directory, "private"); + if (stat (name, &buf) == -1) { + if (mkdir (name, 0700) != 0) { + e_notice (NULL, GNOME_MESSAGE_BOX_ERROR, + _("Evolution could not create directory\n" + "%s:\n%s"), + name, strerror (errno)); + free (name); + return FALSE; + } + + free (name); + return TRUE; + } + + if (S_ISDIR (buf.st_mode) && access (name, R_OK | W_OK | X_OK) == 0) { + free (name); + return TRUE; + } + + if (S_ISDIR (buf.st_mode)) { + e_notice (NULL, GNOME_MESSAGE_BOX_ERROR, + _("Directory %s\n" + "does not have the right permissions. Please make it\n" + "readable and executable and restart Evolution."), + name); + } else { + e_notice (NULL, GNOME_MESSAGE_BOX_ERROR, + _("File %s\n" + "should be removed to allow Evolution to work correctly.\n" + "Please remove this file and restart Evolution."), + name, strerror (errno)); + } + + free (name); + return FALSE; +} + gboolean e_setup (const char *evolution_directory) @@ -360,6 +406,9 @@ e_setup (const char *evolution_directory) } g_free (file); + if (! setup_bonobo_conf_private_directory (evolution_directory)) + return FALSE; + /* User has evolution directory... Check if it is up to date. */ return check_evolution_directory (evolution_directory); -- cgit