Browse Source

daemon/config: factor out duplicate xstrdup_tolower

We have two implementations of the same function; let's drop
that to one. We take the name from daemon.c, but the
implementation (which is just slightly more efficient) from
the config code.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Jeff King 11 years ago committed by Junio C Hamano
parent
commit
88d5a6f6cd
  1. 15
      builtin/config.c
  2. 8
      daemon.c
  3. 13
      strbuf.c
  4. 2
      strbuf.h

15
builtin/config.c

@ -396,19 +396,6 @@ static int urlmatch_collect_fn(const char *var, const char *value, void *cb) @@ -396,19 +396,6 @@ static int urlmatch_collect_fn(const char *var, const char *value, void *cb)
return 0;
}

static char *dup_downcase(const char *string)
{
char *result;
size_t len, i;

len = strlen(string);
result = xmalloc(len + 1);
for (i = 0; i < len; i++)
result[i] = tolower(string[i]);
result[i] = '\0';
return result;
}

static int get_urlmatch(const char *var, const char *url)
{
char *section_tail;
@ -423,7 +410,7 @@ static int get_urlmatch(const char *var, const char *url) @@ -423,7 +410,7 @@ static int get_urlmatch(const char *var, const char *url)
if (!url_normalize(url, &config.url))
die("%s", config.url.err);

config.section = dup_downcase(var);
config.section = xstrdup_tolower(var);
section_tail = strchr(config.section, '.');
if (section_tail) {
*section_tail = '\0';

8
daemon.c

@ -475,14 +475,6 @@ static void make_service_overridable(const char *name, int ena) @@ -475,14 +475,6 @@ static void make_service_overridable(const char *name, int ena)
die("No such service %s", name);
}

static char *xstrdup_tolower(const char *str)
{
char *p, *dup = xstrdup(str);
for (p = dup; *p; p++)
*p = tolower(*p);
return dup;
}

static void parse_host_and_port(char *hostport, char **host,
char **port)
{

13
strbuf.c

@ -570,3 +570,16 @@ int fprintf_ln(FILE *fp, const char *fmt, ...) @@ -570,3 +570,16 @@ int fprintf_ln(FILE *fp, const char *fmt, ...)
return -1;
return ret + 1;
}

char *xstrdup_tolower(const char *string)
{
char *result;
size_t len, i;

len = strlen(string);
result = xmalloc(len + 1);
for (i = 0; i < len; i++)
result[i] = tolower(string[i]);
result[i] = '\0';
return result;
}

2
strbuf.h

@ -177,4 +177,6 @@ extern int printf_ln(const char *fmt, ...); @@ -177,4 +177,6 @@ extern int printf_ln(const char *fmt, ...);
__attribute__((format (printf,2,3)))
extern int fprintf_ln(FILE *fp, const char *fmt, ...);

char *xstrdup_tolower(const char *);

#endif /* STRBUF_H */

Loading…
Cancel
Save