|  | #include "cache.h" | 
|  |  | 
|  | const signed char hexval_table[256] = { | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 00-07 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 08-0f */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 10-17 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 18-1f */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 20-27 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 28-2f */ | 
|  | 0,  1,  2,  3,  4,  5,  6,  7,		/* 30-37 */ | 
|  | 8,  9, -1, -1, -1, -1, -1, -1,		/* 38-3f */ | 
|  | -1, 10, 11, 12, 13, 14, 15, -1,		/* 40-47 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 48-4f */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 50-57 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 58-5f */ | 
|  | -1, 10, 11, 12, 13, 14, 15, -1,		/* 60-67 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 68-67 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 70-77 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 78-7f */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 80-87 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 88-8f */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 90-97 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* 98-9f */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* a0-a7 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* a8-af */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* b0-b7 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* b8-bf */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* c0-c7 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* c8-cf */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* d0-d7 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* d8-df */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* e0-e7 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* e8-ef */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* f0-f7 */ | 
|  | -1, -1, -1, -1, -1, -1, -1, -1,		/* f8-ff */ | 
|  | }; | 
|  |  | 
|  | int get_sha1_hex(const char *hex, unsigned char *sha1) | 
|  | { | 
|  | int i; | 
|  | for (i = 0; i < GIT_SHA1_RAWSZ; i++) { | 
|  | unsigned int val; | 
|  | /* | 
|  | * hex[1]=='\0' is caught when val is checked below, | 
|  | * but if hex[0] is NUL we have to avoid reading | 
|  | * past the end of the string: | 
|  | */ | 
|  | if (!hex[0]) | 
|  | return -1; | 
|  | val = (hexval(hex[0]) << 4) | hexval(hex[1]); | 
|  | if (val & ~0xff) | 
|  | return -1; | 
|  | *sha1++ = val; | 
|  | hex += 2; | 
|  | } | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | int get_oid_hex(const char *hex, struct object_id *oid) | 
|  | { | 
|  | return get_sha1_hex(hex, oid->hash); | 
|  | } | 
|  |  | 
|  | char *sha1_to_hex_r(char *buffer, const unsigned char *sha1) | 
|  | { | 
|  | static const char hex[] = "0123456789abcdef"; | 
|  | char *buf = buffer; | 
|  | int i; | 
|  |  | 
|  | for (i = 0; i < GIT_SHA1_RAWSZ; i++) { | 
|  | unsigned int val = *sha1++; | 
|  | *buf++ = hex[val >> 4]; | 
|  | *buf++ = hex[val & 0xf]; | 
|  | } | 
|  | *buf = '\0'; | 
|  |  | 
|  | return buffer; | 
|  | } | 
|  |  | 
|  | char *oid_to_hex_r(char *buffer, const struct object_id *oid) | 
|  | { | 
|  | return sha1_to_hex_r(buffer, oid->hash); | 
|  | } | 
|  |  | 
|  | char *sha1_to_hex(const unsigned char *sha1) | 
|  | { | 
|  | static int bufno; | 
|  | static char hexbuffer[4][GIT_SHA1_HEXSZ + 1]; | 
|  | return sha1_to_hex_r(hexbuffer[3 & ++bufno], sha1); | 
|  | } | 
|  |  | 
|  | char *oid_to_hex(const struct object_id *oid) | 
|  | { | 
|  | return sha1_to_hex(oid->hash); | 
|  | } |