X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=lib%2Futils.c;h=3dda9e5ed7e8955053e4e756b087b1056bccacb0;hb=83723896cdbe2fb064748e45611e9b9c829c1d72;hp=863fe4f33bcd8f9393b7c9fa3522f27892dbd1ee;hpb=90f6e953d2d2f905675aadbaf5e307e24c586edd;p=ashd.git diff --git a/lib/utils.c b/lib/utils.c index 863fe4f..3dda9e5 100644 --- a/lib/utils.c +++ b/lib/utils.c @@ -18,6 +18,8 @@ #include #include +#include +#include #ifdef HAVE_CONFIG_H #include @@ -98,3 +100,70 @@ char *sprintf3(char *format, ...) va_end(args); return(buf); } + +off_t atoo(char *n) +{ + return((off_t)strtoll(n, NULL, 10)); +} + +char **tokenize(char *src) +{ + char **ret; + char *p, *p2, *n; + int s, q, cl; + + p = src; + s = 0; + ret = NULL; + while(1) { + while(isspace(*p)) + p++; + if(!*p) + break; + p2 = p; + q = 0; + while(1) { + if(q) { + if(*p == '\"') + q = 0; + else if(*p == '\\') + p++; + } else { + if(*p == '\"') + q = 1; + else if(isspace(*p) || !*p) + break; + else if(*p == '\\') + p++; + } + p++; + } + cl = p - p2; + n = memcpy(malloc(cl + 1), p2, cl); + n[cl] = 0; + for(p2 = n; *p2; cl--) { + if(*p2 == '\\') { + memmove(p2, p2 + 1, cl--); + p2++; + } else if(*p2 == '\"') { + memmove(p2, p2 + 1, cl); + } else { + p2++; + } + } + ret = realloc(ret, sizeof(char *) * (++s)); + ret[s - 1] = n; + } + ret = realloc(ret, sizeof(char *) * (++s)); + ret[s - 1] = NULL; + return(ret); +} + +void freeca(char **ca) +{ + char **c; + + for(c = ca; *c; c++) + free(*c); + free(ca); +}