aboutsummaryrefslogtreecommitdiffstats
path: root/l4arg/toargv.c
diff options
context:
space:
mode:
authorLAN-TW <lantw44@gmail.com>2012-09-14 17:56:53 +0800
committerLAN-TW <lantw44@gmail.com>2012-09-14 17:56:53 +0800
commitde126eff57df844c3eca18afeb0530ceeecff8d6 (patch)
tree3d881c6a7c7d95f65b72f75dda56d29d5ae5fe5c /l4arg/toargv.c
parentc0cf367120cba837dc93ca38a197de940f3dabca (diff)
downloadl4basic-de126eff57df844c3eca18afeb0530ceeecff8d6.tar
l4basic-de126eff57df844c3eca18afeb0530ceeecff8d6.tar.gz
l4basic-de126eff57df844c3eca18afeb0530ceeecff8d6.tar.bz2
l4basic-de126eff57df844c3eca18afeb0530ceeecff8d6.tar.lz
l4basic-de126eff57df844c3eca18afeb0530ceeecff8d6.tar.xz
l4basic-de126eff57df844c3eca18afeb0530ceeecff8d6.tar.zst
l4basic-de126eff57df844c3eca18afeb0530ceeecff8d6.zip
l4arg: 測試並修正許多會造成程式異常終止的錯誤
Diffstat (limited to 'l4arg/toargv.c')
-rw-r--r--l4arg/toargv.c39
1 files changed, 25 insertions, 14 deletions
diff --git a/l4arg/toargv.c b/l4arg/toargv.c
index 4b507b0..433ad1a 100644
--- a/l4arg/toargv.c
+++ b/l4arg/toargv.c
@@ -18,7 +18,7 @@ char** l4arg_toargv(const char* str,
char escaped = 0, quoted = 0, delimed = 0;
L4DA* parr;
L4DA* tmpstr;
- char* addstr;
+ char* addstr, tmpchar;
char** rval;
parr = l4da_create(sizeof(char*), 0);
if(parr == NULL){
@@ -47,6 +47,7 @@ char** l4arg_toargv(const char* str,
abort_l4arg_toargv;
}
delimed = 0;
+ continue;
}
if(strchr(esc, str[i]) != NULL){
escaped = 1;
@@ -57,20 +58,24 @@ char** l4arg_toargv(const char* str,
continue;
}
if(strchr(delim, str[i]) != NULL){
- if(l4da_pushback(tmpstr, '\0') < 0){
- abort_l4arg_toargv;
- }
- addstr = (char*)l4da_drop_struct(tmpstr);
- if(l4da_pushback(parr, &addstr) < 0){
- l4da_free(parr);
- return NULL;
- }
- tmpstr = l4da_create(sizeof(char), 0);
- if(tmpstr == NULL){
- l4da_free(parr);
- return NULL;
+ if(l4da_getlen(tmpstr) > 0){
+ tmpchar = '\0';
+ if(l4da_pushback(tmpstr, &tmpchar) < 0){
+ abort_l4arg_toargv;
+ }
+ addstr = (char*)l4da_drop_struct(tmpstr);
+ if(l4da_pushback(parr, &addstr) < 0){
+ l4da_free(parr);
+ return NULL;
+ }
+ tmpstr = l4da_create(sizeof(char), 0);
+ if(tmpstr == NULL){
+ l4da_free(parr);
+ return NULL;
+ }
}
delimed = 1;
+ continue;
}
if(l4da_pushback(tmpstr, &str[i]) < 0){
abort_l4arg_toargv;
@@ -78,7 +83,8 @@ char** l4arg_toargv(const char* str,
delimed = 0;
}
if(!delimed){
- if(l4da_pushback(tmpstr, '\0') < 0){
+ tmpchar = '\0';
+ if(l4da_pushback(tmpstr, &tmpchar) < 0){
abort_l4arg_toargv;
}
addstr = (char*)l4da_drop_struct(tmpstr);
@@ -87,6 +93,11 @@ char** l4arg_toargv(const char* str,
return NULL;
}
}
+ addstr = NULL;
+ if(l4da_pushback(parr, &addstr) < 0){
+ l4da_free(parr);
+ return NULL;
+ }
rval = (char**)l4da_drop_struct(parr);
return rval;
}