X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Frrd_utils.c;h=3936cffd1d2e6689bd4ac5117e6404f54c09b35e;hb=13282ca45604d2cb79144e7eb9eb4245032ccf5f;hp=39d2aca1601cac61e5507047fcf0802f4af5163a;hpb=2f0b984b0dfee0a8ab2cb1d41670f40a07ec5cdb;p=rrdtool.git diff --git a/src/rrd_utils.c b/src/rrd_utils.c index 39d2aca..3936cff 100644 --- a/src/rrd_utils.c +++ b/src/rrd_utils.c @@ -1,4 +1,8 @@ /** + * RRDtool - src/rrd_utils.c + * Copyright (C) 2009 Kevin Brintnall + * Copyright (C) 2008 Sebastian Harl + * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; only version 2 of the License is applicable. @@ -11,11 +15,22 @@ * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + * + * Authors: + * kevin brintnall + * Sebastian Harl **/ #include "rrd_tool.h" +#include +#include +#include #include +#include +#include +#include +#include #ifdef WIN32 # define random() rand() @@ -34,3 +49,111 @@ long rrd_random(void) return random(); } + +/* rrd_add_ptr: add a pointer to a dynamically sized array of pointers, + * realloc as necessary. returns 1 on success, 0 on failure. + */ + +int rrd_add_ptr(void ***dest, size_t *dest_size, void *src) +{ + void **temp; + + assert(dest != NULL); + + temp = (void **) rrd_realloc(*dest, (*dest_size+1) * sizeof(*dest)); + if (!temp) + return 0; + + *dest = temp; + temp[*dest_size] = src; + (*dest_size)++; + + return 1; +} + +/* like rrd_add_ptr, but calls strdup() on a string first. */ +int rrd_add_strdup(char ***dest, size_t *dest_size, char *src) +{ + char *dup_src; + int add_ok; + + assert(dest != NULL); + assert(src != NULL); + + dup_src = strdup(src); + if (!dup_src) + return 0; + + add_ok = rrd_add_ptr((void ***)dest, dest_size, (void *)dup_src); + if (!add_ok) + free(dup_src); + + return add_ok; +} + +void rrd_free_ptrs(void ***src, size_t *cnt) +{ + void **sp; + + assert(src != NULL); + sp = *src; + + if (sp == NULL) + return; + + while (*cnt > 0) { + (*cnt)--; + free(sp[*cnt]); + } + + free (sp); + *src = NULL; +} + +/* recursively create the directory named by 'pathname' + * (similar to "mkdir -p" on the command line) */ +int rrd_mkdir_p(const char *pathname, mode_t mode) +{ + struct stat sb; + + char *pathname_copy; + char *base_dir; + + if ((NULL == pathname) || ('\0' == *pathname)) { + errno = EINVAL; + return -1; + } + + if (0 == stat(pathname, &sb)) { + if (! S_ISDIR(sb.st_mode)) { + errno = ENOTDIR; + return -1; + } + return 0; + } + + /* keep errno as set by stat() */ + if (ENOENT != errno) + return -1; + + /* dirname might modify its first argument */ + if (NULL == (pathname_copy = strdup(pathname))) + return -1; + + base_dir = dirname(pathname_copy); + + if (0 != rrd_mkdir_p(base_dir, mode)) { + int orig_errno = errno; + free(pathname_copy); + errno = orig_errno; + return -1; + } + + free(pathname_copy); + + /* keep errno as set by mkdir() */ + if (0 != mkdir(pathname, mode)) + return -1; + return 0; +} /* rrd_mkdir_p */ +