summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2021-04-18 22:13:13 +0200
committerSébastien Helleu <flashcode@flashtux.org>2021-05-11 21:06:32 +0200
commit4c5fcb743b2e512c407a09ca95d155c9e6edd2bd (patch)
tree40eb5d456730c995792942d2ed8be51ff6b2e8ff /src
parent269576eea2c20033dc3a704847810a0b1bc55440 (diff)
downloadweechat-4c5fcb743b2e512c407a09ca95d155c9e6edd2bd.zip
core: move home directory functions from weechat.c to wee-dir.c (issue #1285)
Diffstat (limited to 'src')
-rw-r--r--src/core/wee-dir.c153
-rw-r--r--src/core/wee-dir.h1
-rw-r--r--src/core/weechat.c155
-rw-r--r--src/core/weechat.h1
4 files changed, 156 insertions, 154 deletions
diff --git a/src/core/wee-dir.c b/src/core/wee-dir.c
index 2eb3bd7d7..96f98ada9 100644
--- a/src/core/wee-dir.c
+++ b/src/core/wee-dir.c
@@ -512,3 +512,156 @@ error:
fclose (f);
return NULL;
}
+
+/*
+ * Expands and assigns given path to "weechat_home".
+ */
+
+void
+dir_set_home_path (char *home_path)
+{
+ char *ptr_home;
+ int dir_length;
+
+ if (home_path[0] == '~')
+ {
+ /* replace leading '~' by $HOME */
+ ptr_home = getenv ("HOME");
+ if (!ptr_home)
+ {
+ string_fprintf (stderr, _("Error: unable to get HOME directory\n"));
+ weechat_shutdown (EXIT_FAILURE, 0);
+ /* make C static analyzer happy (never executed) */
+ return;
+ }
+ dir_length = strlen (ptr_home) + strlen (home_path + 1) + 1;
+ weechat_home = malloc (dir_length);
+ if (weechat_home)
+ {
+ snprintf (weechat_home, dir_length,
+ "%s%s", ptr_home, home_path + 1);
+ }
+ }
+ else
+ {
+ weechat_home = strdup (home_path);
+ }
+
+ if (!weechat_home)
+ {
+ string_fprintf (stderr,
+ _("Error: not enough memory for home directory\n"));
+ weechat_shutdown (EXIT_FAILURE, 0);
+ /* make C static analyzer happy (never executed) */
+ return;
+ }
+}
+
+/*
+ * Creates WeeChat home directory (by default ~/.weechat).
+ *
+ * Any error in this function is fatal: WeeChat can not run without a home
+ * directory.
+ */
+
+void
+dir_create_home_dir ()
+{
+ char *temp_dir, *temp_home_template, *ptr_weechat_home;
+ char *config_weechat_home;
+ int length, add_separator;
+ struct stat statinfo;
+
+ /* temporary WeeChat home */
+ if (weechat_home_temp)
+ {
+ temp_dir = dir_get_temp_dir ();
+ if (!temp_dir || !temp_dir[0])
+ {
+ string_fprintf (stderr,
+ _("Error: not enough memory for home "
+ "directory\n"));
+ weechat_shutdown (EXIT_FAILURE, 0);
+ /* make C static analyzer happy (never executed) */
+ return;
+ }
+ length = strlen (temp_dir) + 32 + 1;
+ temp_home_template = malloc (length);
+ if (!temp_home_template)
+ {
+ free (temp_dir);
+ string_fprintf (stderr,
+ _("Error: not enough memory for home "
+ "directory\n"));
+ weechat_shutdown (EXIT_FAILURE, 0);
+ /* make C static analyzer happy (never executed) */
+ return;
+ }
+ add_separator = (temp_dir[strlen (temp_dir) - 1] != DIR_SEPARATOR_CHAR);
+ snprintf (temp_home_template, length,
+ "%s%sweechat_temp_XXXXXX",
+ temp_dir,
+ add_separator ? DIR_SEPARATOR : "");
+ free (temp_dir);
+ ptr_weechat_home = mkdtemp (temp_home_template);
+ if (!ptr_weechat_home)
+ {
+ string_fprintf (stderr,
+ _("Error: unable to create a temporary "
+ "home directory (using template: \"%s\")\n"),
+ temp_home_template);
+ free (temp_home_template);
+ weechat_shutdown (EXIT_FAILURE, 0);
+ /* make C static analyzer happy (never executed) */
+ return;
+ }
+ weechat_home = strdup (ptr_weechat_home);
+ free (temp_home_template);
+ weechat_home_delete_on_exit = 1;
+ return;
+ }
+
+ /*
+ * weechat_home is not set yet: look for environment variable
+ * "WEECHAT_HOME"
+ */
+ if (!weechat_home)
+ {
+ ptr_weechat_home = getenv ("WEECHAT_HOME");
+ if (ptr_weechat_home && ptr_weechat_home[0])
+ dir_set_home_path (ptr_weechat_home);
+ }
+
+ /* weechat_home is still not set: try to use compile time default */
+ if (!weechat_home)
+ {
+ config_weechat_home = WEECHAT_HOME;
+ dir_set_home_path (
+ (config_weechat_home[0] ? config_weechat_home : "~/.weechat"));
+ }
+
+ /* if home already exists, it has to be a directory */
+ if (stat (weechat_home, &statinfo) == 0)
+ {
+ if (!S_ISDIR (statinfo.st_mode))
+ {
+ string_fprintf (stderr,
+ _("Error: home (%s) is not a directory\n"),
+ weechat_home);
+ weechat_shutdown (EXIT_FAILURE, 0);
+ /* make C static analyzer happy (never executed) */
+ return;
+ }
+ }
+
+ /* create home directory; error is fatal */
+ if (!dir_mkdir (weechat_home, 0755))
+ {
+ string_fprintf (stderr,
+ _("Error: cannot create directory \"%s\"\n"),
+ weechat_home);
+ weechat_shutdown (EXIT_FAILURE, 0);
+ /* make C static analyzer happy (never executed) */
+ return;
+ }
+}
diff --git a/src/core/wee-dir.h b/src/core/wee-dir.h
index fbbdf96a7..8292eb1cc 100644
--- a/src/core/wee-dir.h
+++ b/src/core/wee-dir.h
@@ -33,5 +33,6 @@ extern void dir_exec_on_files (const char *directory, int recurse_subdirs,
extern char *dir_search_full_lib_name (const char *filename,
const char *sys_directory);
extern char *dir_file_get_content (const char *filename);
+extern void dir_create_home_dir ();
#endif /* WEECHAT_DIR_H */
diff --git a/src/core/weechat.c b/src/core/weechat.c
index d29a4eac0..fa8f0fa29 100644
--- a/src/core/weechat.c
+++ b/src/core/weechat.c
@@ -375,159 +375,6 @@ weechat_parse_args (int argc, char *argv[])
}
/*
- * Expands and assigns given path to "weechat_home".
- */
-
-void
-weechat_set_home_path (char *home_path)
-{
- char *ptr_home;
- int dir_length;
-
- if (home_path[0] == '~')
- {
- /* replace leading '~' by $HOME */
- ptr_home = getenv ("HOME");
- if (!ptr_home)
- {
- string_fprintf (stderr, _("Error: unable to get HOME directory\n"));
- weechat_shutdown (EXIT_FAILURE, 0);
- /* make C static analyzer happy (never executed) */
- return;
- }
- dir_length = strlen (ptr_home) + strlen (home_path + 1) + 1;
- weechat_home = malloc (dir_length);
- if (weechat_home)
- {
- snprintf (weechat_home, dir_length,
- "%s%s", ptr_home, home_path + 1);
- }
- }
- else
- {
- weechat_home = strdup (home_path);
- }
-
- if (!weechat_home)
- {
- string_fprintf (stderr,
- _("Error: not enough memory for home directory\n"));
- weechat_shutdown (EXIT_FAILURE, 0);
- /* make C static analyzer happy (never executed) */
- return;
- }
-}
-
-/*
- * Creates WeeChat home directory (by default ~/.weechat).
- *
- * Any error in this function is fatal: WeeChat can not run without a home
- * directory.
- */
-
-void
-weechat_create_home_dir ()
-{
- char *temp_dir, *temp_home_template, *ptr_weechat_home;
- char *config_weechat_home;
- int length, add_separator;
- struct stat statinfo;
-
- /* temporary WeeChat home */
- if (weechat_home_temp)
- {
- temp_dir = dir_get_temp_dir ();
- if (!temp_dir || !temp_dir[0])
- {
- string_fprintf (stderr,
- _("Error: not enough memory for home "
- "directory\n"));
- weechat_shutdown (EXIT_FAILURE, 0);
- /* make C static analyzer happy (never executed) */
- return;
- }
- length = strlen (temp_dir) + 32 + 1;
- temp_home_template = malloc (length);
- if (!temp_home_template)
- {
- free (temp_dir);
- string_fprintf (stderr,
- _("Error: not enough memory for home "
- "directory\n"));
- weechat_shutdown (EXIT_FAILURE, 0);
- /* make C static analyzer happy (never executed) */
- return;
- }
- add_separator = (temp_dir[strlen (temp_dir) - 1] != DIR_SEPARATOR_CHAR);
- snprintf (temp_home_template, length,
- "%s%sweechat_temp_XXXXXX",
- temp_dir,
- add_separator ? DIR_SEPARATOR : "");
- free (temp_dir);
- ptr_weechat_home = mkdtemp (temp_home_template);
- if (!ptr_weechat_home)
- {
- string_fprintf (stderr,
- _("Error: unable to create a temporary "
- "home directory (using template: \"%s\")\n"),
- temp_home_template);
- free (temp_home_template);
- weechat_shutdown (EXIT_FAILURE, 0);
- /* make C static analyzer happy (never executed) */
- return;
- }
- weechat_home = strdup (ptr_weechat_home);
- free (temp_home_template);
- weechat_home_delete_on_exit = 1;
- return;
- }
-
- /*
- * weechat_home is not set yet: look for environment variable
- * "WEECHAT_HOME"
- */
- if (!weechat_home)
- {
- ptr_weechat_home = getenv ("WEECHAT_HOME");
- if (ptr_weechat_home && ptr_weechat_home[0])
- weechat_set_home_path (ptr_weechat_home);
- }
-
- /* weechat_home is still not set: try to use compile time default */
- if (!weechat_home)
- {
- config_weechat_home = WEECHAT_HOME;
- weechat_set_home_path (
- (config_weechat_home[0] ? config_weechat_home : "~/.weechat"));
- }
-
- /* if home already exists, it has to be a directory */
- if (stat (weechat_home, &statinfo) == 0)
- {
- if (!S_ISDIR (statinfo.st_mode))
- {
- string_fprintf (stderr,
- _("Error: home (%s) is not a directory\n"),
- weechat_home);
- weechat_shutdown (EXIT_FAILURE, 0);
- /* make C static analyzer happy (never executed) */
- return;
- }
- }
-
- /* create home directory; error is fatal */
- if (!dir_mkdir (weechat_home, 0755))
- {
- string_fprintf (stderr,
- _("Error: cannot create directory \"%s\"\n"),
- weechat_home);
- weechat_shutdown (EXIT_FAILURE, 0);
- /* make C static analyzer happy (never executed) */
- return;
- }
-}
-
-/*
* Displays WeeChat startup message.
*/
@@ -767,7 +614,7 @@ weechat_init (int argc, char *argv[], void (*gui_init_cb)())
if (!config_weechat_init ()) /* init WeeChat options (weechat.*) */
weechat_shutdown (EXIT_FAILURE, 0);
weechat_parse_args (argc, argv); /* parse command line args */
- weechat_create_home_dir (); /* create WeeChat home directory */
+ dir_create_home_dir (); /* create WeeChat home directory */
log_init (); /* init log file */
plugin_api_init (); /* create some hooks (info,hdata,..)*/
secure_config_read (); /* read secured data options */
diff --git a/src/core/weechat.h b/src/core/weechat.h
index 49614a804..b642b5e1a 100644
--- a/src/core/weechat.h
+++ b/src/core/weechat.h
@@ -114,6 +114,7 @@ extern volatile sig_atomic_t weechat_quit_signal;
extern volatile sig_atomic_t weechat_reload_signal;
extern char *weechat_home;
extern int weechat_home_temp;
+extern int weechat_home_delete_on_exit;
extern char *weechat_local_charset;
extern int weechat_plugin_no_dlclose;
extern int weechat_no_gnutls;