зеркало из https://github.com/microsoft/git.git
strbuf_split*(): rename "delim" parameter to "terminator"
The word "delimiter" suggests that the argument separates the substrings, whereas in fact (1) the delimiter characters are included in the output, and (2) if the input string ends with the delimiter, then the output does not include a final empty string. So rename the "delim" arguments of the strbuf_split() family of functions to "terminator", which is more suggestive of how it is used. Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu> Signed-off-by: Jeff King <peff@peff.net>
This commit is contained in:
Родитель
1173bb3311
Коммит
17b73dc699
5
strbuf.c
5
strbuf.c
|
@ -106,7 +106,8 @@ void strbuf_ltrim(struct strbuf *sb)
|
|||
sb->buf[sb->len] = '\0';
|
||||
}
|
||||
|
||||
struct strbuf **strbuf_split_buf(const char *str, size_t slen, int delim, int max)
|
||||
struct strbuf **strbuf_split_buf(const char *str, size_t slen,
|
||||
int terminator, int max)
|
||||
{
|
||||
struct strbuf **ret = NULL;
|
||||
size_t nr = 0, alloc = 0;
|
||||
|
@ -115,7 +116,7 @@ struct strbuf **strbuf_split_buf(const char *str, size_t slen, int delim, int ma
|
|||
while (slen) {
|
||||
int len = slen;
|
||||
if (max <= 0 || nr + 1 < max) {
|
||||
const char *end = memchr(str, delim, slen);
|
||||
const char *end = memchr(str, terminator, slen);
|
||||
if (end)
|
||||
len = end - str + 1;
|
||||
}
|
||||
|
|
15
strbuf.h
15
strbuf.h
|
@ -45,20 +45,21 @@ extern void strbuf_ltrim(struct strbuf *);
|
|||
extern int strbuf_cmp(const struct strbuf *, const struct strbuf *);
|
||||
|
||||
extern struct strbuf **strbuf_split_buf(const char *, size_t,
|
||||
int delim, int max);
|
||||
int terminator, int max);
|
||||
static inline struct strbuf **strbuf_split_str(const char *str,
|
||||
int delim, int max)
|
||||
int terminator, int max)
|
||||
{
|
||||
return strbuf_split_buf(str, strlen(str), delim, max);
|
||||
return strbuf_split_buf(str, strlen(str), terminator, max);
|
||||
}
|
||||
static inline struct strbuf **strbuf_split_max(const struct strbuf *sb,
|
||||
int delim, int max)
|
||||
int terminator, int max)
|
||||
{
|
||||
return strbuf_split_buf(sb->buf, sb->len, delim, max);
|
||||
return strbuf_split_buf(sb->buf, sb->len, terminator, max);
|
||||
}
|
||||
static inline struct strbuf **strbuf_split(const struct strbuf *sb, int delim)
|
||||
static inline struct strbuf **strbuf_split(const struct strbuf *sb,
|
||||
int terminator)
|
||||
{
|
||||
return strbuf_split_max(sb, delim, 0);
|
||||
return strbuf_split_max(sb, terminator, 0);
|
||||
}
|
||||
extern void strbuf_list_free(struct strbuf **);
|
||||
|
||||
|
|
Загрузка…
Ссылка в новой задаче