summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFurkan Sahin <furkan-dev@proton.me>2019-01-17 16:56:04 +0000
committerFurkan Sahin <furkan-dev@proton.me>2019-01-17 16:56:04 +0000
commit8ad03b81902bc0818cb5cdc17752082040b447a1 (patch)
treed5de8a1227529a34414a3c98dd66e6785d76a3b7
parent3999b4d32df18c9e828fc80549ad5f9bba6416eb (diff)
stringop.c: refactor a few functions
-rw-r--r--common/stringop.c13
1 files changed, 5 insertions, 8 deletions
diff --git a/common/stringop.c b/common/stringop.c
index b42604c1..dea152cc 100644
--- a/common/stringop.c
+++ b/common/stringop.c
@@ -78,12 +78,10 @@ int lenient_strcmp(char *a, char *b) {
list_t *split_string(const char *str, const char *delims) {
list_t *res = create_list();
char *copy = strdup(str);
- char *token;
- token = strtok(copy, delims);
- while(token) {
- token = strdup(token);
- list_add(res, token);
+ char *token = strtok(copy, delims);
+ while (token) {
+ list_add(res, strdup(token));
token = strtok(NULL, delims);
}
free(copy);
@@ -268,13 +266,13 @@ char *argsep(char **stringp, const char *delim) {
escaped = !escaped;
} else if (*end == '\0') {
*stringp = NULL;
- goto found;
+ break;
} else if (!in_string && !in_char && !escaped && strchr(delim, *end)) {
if (end - start) {
*(end++) = 0;
*stringp = end + strspn(end, delim);;
if (!**stringp) *stringp = NULL;
- goto found;
+ break;
} else {
++start;
end = start;
@@ -285,6 +283,5 @@ char *argsep(char **stringp, const char *delim) {
}
++end;
}
- found:
return start;
}