diff options
author | Jeff King <peff@peff.net> | 2013-01-23 01:24:23 -0500 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2013-01-23 08:41:50 -0800 |
commit | d731f0ade129a71237eff5a17f3196002cb439fb (patch) | |
tree | a0957b9760127aac53b5f4a98f44cd0a198e66c5 /userdiff.c | |
parent | 785a04298177e155dc7391e7234945b38b624e34 (diff) | |
download | git-d731f0ade129a71237eff5a17f3196002cb439fb.tar.gz git-d731f0ade129a71237eff5a17f3196002cb439fb.tar.xz |
convert some config callbacks to parse_config_key
These callers can drop some inline pointer arithmetic and
magic offset constants, making them more readable and less
error-prone (those constants had to match the lengths of
strings, but there is no automatic verification of that
fact).
The "ep" pointer (presumably for "end pointer"), which
points to the final key segment of the config variable, is
given the more standard name "key" to describe its function
rather than its derivation.
Signed-off-by: Jeff King <peff@peff.net>
Reviewed-by: Jonathan Nieder <jrnieder@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'userdiff.c')
-rw-r--r-- | userdiff.c | 13 |
1 files changed, 3 insertions, 10 deletions
diff --git a/userdiff.c b/userdiff.c index ed958ef6b..a4ea1e97b 100644 --- a/userdiff.c +++ b/userdiff.c @@ -188,20 +188,13 @@ static struct userdiff_driver *parse_driver(const char *var, const char *value, const char *type) { struct userdiff_driver *drv; - const char *dot; - const char *name; + const char *name, *key; int namelen; - if (prefixcmp(var, "diff.")) - return NULL; - dot = strrchr(var, '.'); - if (dot == var + 4) - return NULL; - if (strcmp(type, dot+1)) + if (parse_config_key(var, "diff", &name, &namelen, &key) < 0 || + !name || strcmp(type, key)) return NULL; - name = var + 5; - namelen = dot - name; drv = userdiff_find_by_namelen(name, namelen); if (!drv) { ALLOC_GROW(drivers, ndrivers+1, drivers_alloc); |