X-Git-Url: http://www.dolda2000.com/gitweb/?p=ashd.git;a=blobdiff_plain;f=lib%2Futils.c;fp=lib%2Futils.c;h=3dda9e5ed7e8955053e4e756b087b1056bccacb0;hp=a5faaa64e6ddebf12a2215b9c8a8843485421025;hb=f2b26d44416abd494ce430659cfbbf254d9c3c55;hpb=3c296bd47d6b2980206c3c87cfa949583f2a09d6 diff --git a/lib/utils.c b/lib/utils.c index a5faaa6..3dda9e5 100644 --- a/lib/utils.c +++ b/lib/utils.c @@ -18,6 +18,8 @@ #include #include +#include +#include #ifdef HAVE_CONFIG_H #include @@ -103,3 +105,65 @@ 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); +}