summaryrefslogtreecommitdiff
path: root/cache.h
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2016-09-19 13:51:43 -0700
committerJunio C Hamano <gitster@pobox.com>2016-09-19 13:51:43 -0700
commitc3befaeab9ebd0def9f03d434a52cf40614c65f9 (patch)
treeeaa41d9b527b3bdb4c8a6a78443a9277e1c5740f /cache.h
parent815a73f7143214510fae6e8a2f2077b2e8694509 (diff)
parentd23309733a5b2a9e1adc304ee50c5a5ed7a087c2 (diff)
downloadgit-c3befaeab9ebd0def9f03d434a52cf40614c65f9.tar.gz
Merge branch 'rs/hex2chr' into maint
Code cleanup. * rs/hex2chr: introduce hex2chr() for converting two hexadecimal digits to a character
Diffstat (limited to 'cache.h')
-rw-r--r--cache.h10
1 files changed, 10 insertions, 0 deletions
diff --git a/cache.h b/cache.h
index b780a91a56..b0dae4bac1 100644
--- a/cache.h
+++ b/cache.h
@@ -1139,6 +1139,16 @@ static inline unsigned int hexval(unsigned char c)
return hexval_table[c];
}
+/*
+ * Convert two consecutive hexadecimal digits into a char. Return a
+ * negative value on error. Don't run over the end of short strings.
+ */
+static inline int hex2chr(const char *s)
+{
+ int val = hexval(s[0]);
+ return (val < 0) ? val : (val << 4) | hexval(s[1]);
+}
+
/* Convert to/from hex/sha1 representation */
#define MINIMUM_ABBREV minimum_abbrev
#define DEFAULT_ABBREV default_abbrev