diff options
author | Jeff King <peff@peff.net> | 2011-06-09 11:51:22 -0400 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2011-06-22 11:24:50 -0700 |
commit | 28fc3a6857a5d7a6b4f63b2672fb0ce966b0df78 (patch) | |
tree | 96e604d953b38fa5f41b7f0be61e06c7e27623d8 /strbuf.h | |
parent | e5af0de202e885b793482d416b8ce9d50dd2b8bc (diff) | |
download | git-28fc3a6857a5d7a6b4f63b2672fb0ce966b0df78.tar.gz git-28fc3a6857a5d7a6b4f63b2672fb0ce966b0df78.tar.xz |
strbuf_split: add a max parameter
Sometimes when splitting, you only want a limited number of
fields, and for the final field to contain "everything
else", even if it includes the delimiter.
This patch introduces strbuf_split_max, which provides a
"max number of fields" parameter; it behaves similarly to
perl's "split" with a 3rd field.
The existing 2-argument form of strbuf_split is retained for
compatibility and ease-of-use.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'strbuf.h')
-rw-r--r-- | strbuf.h | 7 |
1 files changed, 6 insertions, 1 deletions
@@ -47,7 +47,12 @@ extern void strbuf_rtrim(struct strbuf *); extern void strbuf_ltrim(struct strbuf *); extern int strbuf_cmp(const struct strbuf *, const struct strbuf *); -extern struct strbuf **strbuf_split(const struct strbuf *, int delim); +extern struct strbuf **strbuf_split_max(const struct strbuf *, + int delim, int max); +static inline struct strbuf **strbuf_split(const struct strbuf *sb, int delim) +{ + return strbuf_split_max(sb, delim, 0); +} extern void strbuf_list_free(struct strbuf **); /*----- add data in your buffer -----*/ |