diff options
Diffstat (limited to 'camel/camel-file-utils.c')
-rw-r--r-- | camel/camel-file-utils.c | 46 |
1 files changed, 43 insertions, 3 deletions
diff --git a/camel/camel-file-utils.c b/camel/camel-file-utils.c index 9331c64bfa..eed36f1383 100644 --- a/camel/camel-file-utils.c +++ b/camel/camel-file-utils.c @@ -1,6 +1,5 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ - -/* +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- + * * Authors: * Michael Zucchi <notzed@ximian.com> * Dan Winship <danw@ximian.com> @@ -24,6 +23,14 @@ #include "camel-file-utils.h" +#include "camel-url.h" + +#include <sys/stat.h> +#include <sys/types.h> +#include <fcntl.h> +#include <unistd.h> + +#include <string.h> #include <netinet/in.h> @@ -279,4 +286,37 @@ camel_file_util_decode_string (FILE *in, char **str) return 0; } +/* Make a directory heirarchy. + Always use full paths */ +int +camel_file_util_mkdir(const char *path, mode_t mode) +{ + char *copy, *p; + g_assert(path && path[0] == '/'); + + p = copy = alloca(strlen(path)+1); + strcpy(copy, path); + do { + p = strchr(p + 1, '/'); + if (p) + *p = '\0'; + if (access(copy, F_OK) == -1) { + if (mkdir(copy, mode) == -1) + return -1; + } + if (p) + *p = '/'; + } while (p); + + return 0; +} + +char * +camel_file_util_safe_filename(const char *name) +{ + if (name == NULL) + return NULL; + + return camel_url_encode(name, TRUE, "/?()'*"); +} |