implement ends_with via strip_suffix
The ends_with function is essentially a simplified version of strip_suffix, in which we throw away the stripped length. Implementing it as an inline on top of strip_suffix has two advantages: 1. We save a bit of duplicated code. 2. The suffix is typically a string literal, and we call strlen on it. By making the function inline, many compilers can replace the strlen call with a constant. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
35480f0b23
commit
f52a35fd63
@ -339,7 +339,6 @@ extern void set_error_routine(void (*routine)(const char *err, va_list params));
|
|||||||
extern void set_die_is_recursing_routine(int (*routine)(void));
|
extern void set_die_is_recursing_routine(int (*routine)(void));
|
||||||
|
|
||||||
extern int starts_with(const char *str, const char *prefix);
|
extern int starts_with(const char *str, const char *prefix);
|
||||||
extern int ends_with(const char *str, const char *suffix);
|
|
||||||
|
|
||||||
static inline const char *skip_prefix(const char *str, const char *prefix)
|
static inline const char *skip_prefix(const char *str, const char *prefix)
|
||||||
{
|
{
|
||||||
@ -377,6 +376,12 @@ static inline int strip_suffix(const char *str, const char *suffix, size_t *len)
|
|||||||
return strip_suffix_mem(str, len, suffix);
|
return strip_suffix_mem(str, len, suffix);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline int ends_with(const char *str, const char *suffix)
|
||||||
|
{
|
||||||
|
size_t len;
|
||||||
|
return strip_suffix(str, suffix, &len);
|
||||||
|
}
|
||||||
|
|
||||||
#if defined(NO_MMAP) || defined(USE_WIN32_MMAP)
|
#if defined(NO_MMAP) || defined(USE_WIN32_MMAP)
|
||||||
|
|
||||||
#ifndef PROT_READ
|
#ifndef PROT_READ
|
||||||
|
9
strbuf.c
9
strbuf.c
@ -10,15 +10,6 @@ int starts_with(const char *str, const char *prefix)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int ends_with(const char *str, const char *suffix)
|
|
||||||
{
|
|
||||||
int len = strlen(str), suflen = strlen(suffix);
|
|
||||||
if (len < suflen)
|
|
||||||
return 0;
|
|
||||||
else
|
|
||||||
return !strcmp(str + len - suflen, suffix);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Used as the default ->buf value, so that people can always assume
|
* Used as the default ->buf value, so that people can always assume
|
||||||
* buf is non NULL and ->buf is NUL terminated even for a freshly
|
* buf is non NULL and ->buf is NUL terminated even for a freshly
|
||||||
|
Loading…
Reference in New Issue
Block a user