all repos — openbox @ 5cadc1bff5a26497df28f38e7e9b74d81dfa1084

openbox fork - make it a bit more like ryudo

much improved functions for maknig directories, props to Logan
Dana Jansens danakj@orodu.net
commit

5cadc1bff5a26497df28f38e7e9b74d81dfa1084

parent

138d98fc3f743f29bdf78efcdc25b515357d6817

3 files changed, 42 insertions(+), 13 deletions(-)

jump to
M openbox/session.copenbox/session.c

@@ -163,7 +163,9 @@ return;

sm_sessions_path = g_build_filename(parse_xdg_data_home_path(), "openbox", "sessions", NULL); - parse_mkdir_path(sm_sessions_path, 0700); + if (!parse_mkdir_path(sm_sessions_path, 0700)) + g_warning(_("unable to make directory '%s': %s"), + sm_sessions_path, g_strerror(errno)); if (save_file) session_load(save_file);
M parser/parse.cparser/parse.c

@@ -19,6 +19,7 @@

#include "parse.h" #include <glib.h> #include <string.h> +#include <errno.h> #include <sys/stat.h> #include <sys/types.h>

@@ -386,21 +387,45 @@ g_strfreev(spl);

return ret; } -void parse_mkdir_path(const gchar *path, gint mode) +gboolean parse_mkdir(const gchar *path, gint mode) { - gchar *c, *e; + gboolean ret = TRUE; - g_assert(path[0] == '/'); + g_return_val_if_fail(path != NULL, FALSE); + g_return_val_if_fail(path[0] != '\0', FALSE); + + if (!g_file_test(path, G_FILE_TEST_IS_DIR)) + if (mkdir(path, mode) == -1) + ret = FALSE; + + return ret; +} - c = g_strdup(path); - e = c; - while ((e = strchr(e + 1, '/'))) { - *e = '\0'; - mkdir(c, mode); - *e = '/'; +gboolean parse_mkdir_path(const gchar *path, gint mode) +{ + gboolean ret = TRUE; + + g_return_val_if_fail(path != NULL, FALSE); + g_return_val_if_fail(path[0] == '/', FALSE); + + if (!g_file_test(path, G_FILE_TEST_IS_DIR)) { + gchar *c, *e; + + c = g_strdup(path); + e = c; + while ((e = strchr(e + 1, '/'))) { + *e = '\0'; + if (!(ret = parse_mkdir(c, mode))) + goto parse_mkdir_path_end; + *e = '/'; + } + ret = parse_mkdir(c, mode); + + parse_mkdir_path_end: + g_free(c); } - mkdir(c, mode); - g_free(c); + + return ret; } const gchar* parse_xdg_config_home_path()
M parser/parse.hparser/parse.h

@@ -79,8 +79,10 @@

/*! Expands the ~ character to the home directory throughout the given string */ gchar *parse_expand_tilde(const gchar *f); +/*! Makes a directory */ +gboolean parse_mkdir(const gchar *path, gint mode); /*! Makes a directory and all its parents */ -void parse_mkdir_path(const gchar *path, gint mode); +gboolean parse_mkdir_path(const gchar *path, gint mode); G_END_DECLS