diff options
| author | Junio C Hamano <gitster@pobox.com> | 2018-05-23 14:38:17 +0900 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2018-05-23 14:38:17 +0900 |
| commit | 352cf6cfe138b1dbcf9c105c91ca793b67511d7b (patch) | |
| tree | c7aa5bc4bc01eafeb06d8c000397da6b881e95a7 /argv-array.c | |
| parent | 5002702e487dc501702b29e768b78d5c22114425 (diff) | |
| parent | a3694d949fcd39f9a909cf762f698df8ce83215c (diff) | |
Merge branch 'js/deprecate-grafts'
The functionality of "$GIT_DIR/info/grafts" has been superseded by
the "refs/replace/" mechanism for some time now, but the internal
code had support for it in many places, which has been cleaned up
in order to drop support of the "grafts" mechanism.
* js/deprecate-grafts:
Remove obsolete script to convert grafts to replace refs
technical/shallow: describe why shallow cannot use replace refs
technical/shallow: stop referring to grafts
filter-branch: stop suggesting to use grafts
Deprecate support for .git/info/grafts
Add a test for `git replace --convert-graft-file`
replace: introduce --convert-graft-file
replace: prepare create_graft() for converting graft files wholesale
replace: "libify" create_graft() and callees
replace: avoid using die() to indicate a bug
commit: Let the callback of for_each_mergetag return on error
argv_array: offer to split a string by whitespace
Diffstat (limited to 'argv-array.c')
| -rw-r--r-- | argv-array.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/argv-array.c b/argv-array.c index 5d370fa336..cb5bcd2c06 100644 --- a/argv-array.c +++ b/argv-array.c @@ -64,6 +64,26 @@ void argv_array_pop(struct argv_array *array) array->argc--; } +void argv_array_split(struct argv_array *array, const char *to_split) +{ + while (isspace(*to_split)) + to_split++; + for (;;) { + const char *p = to_split; + + if (!*p) + break; + + while (*p && !isspace(*p)) + p++; + argv_array_push_nodup(array, xstrndup(to_split, p - to_split)); + + while (isspace(*p)) + p++; + to_split = p; + } +} + void argv_array_clear(struct argv_array *array) { if (array->argv != empty_argv) { |
