René Scharfe wrote:
As suggested by Pierre Habouzit, add strchrnul(). It's a useful GNU extension and can simplify string parser code. There are several places in git that can be converted to strchrnul(); as a trivial example, this patch introduces its usage to builtin-fetch--tool.c. Signed-off-by: Rene Scharfe <rene.scharfe@xxxxxxxxxxxxxx> --- Makefile | 13 +++++++++++++ builtin-fetch--tool.c | 8 ++------ compat/strchrnul.c | 8 ++++++++ git-compat-util.h | 5 +++++ 4 files changed, 28 insertions(+), 6 deletions(-) diff --git a/Makefile b/Makefile index 0d5590f..578c999 100644 --- a/Makefile +++ b/Makefile @@ -30,6 +30,8 @@ all:: # # Define NO_MEMMEM if you don't have memmem. # +# Define NO_STRCHRNUL if you don't have strchrnul. +#
This seems overly complicated. How about this instead? From: Andreas Ericsson <ae@xxxxxx> Subject: [PATCH] Add strchrnul() As suggested by Pierre Habouzit, add strchrnul(). It's a useful GNU extension and can simplify string parser code. There are several places in git that can be converted to strchrnul(); as a trivial example, this patch introduces its usage to builtin-fetch--tool.c. strchrnul() was introduced in glibc in April 1999 and included in glibc-2.1. Checking for that version means the majority of all git users would get to use the optimized version in glibc. Of the remaining few some might get to use a slightly slower version than necessary but probably not slower than what we have today. Original patch by Rene Scharfe <rene.scharfe@xxxxxxxxxxxxxx> Signed-off-by: Andreas Ericsson <ae@xxxxxx> --- I'm fairly much against forcing people to know what library functions they have in order to get software to compile properly. This is, imo, a neater solution, and also inlines the function as suggested by Dscho. diff --git a/git-compat-util.h b/git-compat-util.h index 7b29d1b..9fedf33 100644 --- a/git-compat-util.h +++ b/git-compat-util.h @@ -105,6 +105,18 @@ extern void set_die_routine(void (*routine)(const char *err extern void set_error_routine(void (*routine)(const char *err, va_list params)) extern void set_warn_routine(void (*routine)(const char *warn, va_list params)) + +#if !defined(__GLIBC__) && !__GLIBC_PREREQ(2, 1) +# define strchrnul(s, c) gitstrchrnul(s, c) +static inline char *gitstrchrnul(const char *s, int c) +{ + while (*s && *s != c) + s++; + + return (char *)s; +} +#endif + #ifdef NO_MMAP #ifndef PROT_READ diff --git a/builtin-fetch--tool.c b/builtin-fetch--tool.c index 6a78517..ed60847 100644 --- a/builtin-fetch--tool.c +++ b/builtin-fetch--tool.c @@ -435,9 +435,7 @@ static int pick_rref(int sha1_only, const char *rref, const char *ls_remote_resu cp++; if (!*cp) break; - np = strchr(cp, '\n'); - if (!np) - np = cp + strlen(cp); + np = strchrnul(cp, '\n'); if (pass) { lrr_list[i].line = cp; lrr_list[i].name = cp + 41; @@ -461,9 +459,7 @@ static int pick_rref(int sha1_only, const char *rref, const char *ls_remote_resu rref++; if (!*rref) break; - next = strchr(rref, '\n'); - if (!next) - next = rref + strlen(rref); + next = strchrnul(rref, '\n'); rreflen = next - rref; for (i = 0; i < lrr_count; i++) { -- Andreas Ericsson andreas.ericsson@xxxxxx OP5 AB www.op5.se Tel: +46 8-230225 Fax: +46 8-230231 - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html