3 const signed char hexval_table
[256] = {
4 -1, -1, -1, -1, -1, -1, -1, -1, /* 00-07 */
5 -1, -1, -1, -1, -1, -1, -1, -1, /* 08-0f */
6 -1, -1, -1, -1, -1, -1, -1, -1, /* 10-17 */
7 -1, -1, -1, -1, -1, -1, -1, -1, /* 18-1f */
8 -1, -1, -1, -1, -1, -1, -1, -1, /* 20-27 */
9 -1, -1, -1, -1, -1, -1, -1, -1, /* 28-2f */
10 0, 1, 2, 3, 4, 5, 6, 7, /* 30-37 */
11 8, 9, -1, -1, -1, -1, -1, -1, /* 38-3f */
12 -1, 10, 11, 12, 13, 14, 15, -1, /* 40-47 */
13 -1, -1, -1, -1, -1, -1, -1, -1, /* 48-4f */
14 -1, -1, -1, -1, -1, -1, -1, -1, /* 50-57 */
15 -1, -1, -1, -1, -1, -1, -1, -1, /* 58-5f */
16 -1, 10, 11, 12, 13, 14, 15, -1, /* 60-67 */
17 -1, -1, -1, -1, -1, -1, -1, -1, /* 68-67 */
18 -1, -1, -1, -1, -1, -1, -1, -1, /* 70-77 */
19 -1, -1, -1, -1, -1, -1, -1, -1, /* 78-7f */
20 -1, -1, -1, -1, -1, -1, -1, -1, /* 80-87 */
21 -1, -1, -1, -1, -1, -1, -1, -1, /* 88-8f */
22 -1, -1, -1, -1, -1, -1, -1, -1, /* 90-97 */
23 -1, -1, -1, -1, -1, -1, -1, -1, /* 98-9f */
24 -1, -1, -1, -1, -1, -1, -1, -1, /* a0-a7 */
25 -1, -1, -1, -1, -1, -1, -1, -1, /* a8-af */
26 -1, -1, -1, -1, -1, -1, -1, -1, /* b0-b7 */
27 -1, -1, -1, -1, -1, -1, -1, -1, /* b8-bf */
28 -1, -1, -1, -1, -1, -1, -1, -1, /* c0-c7 */
29 -1, -1, -1, -1, -1, -1, -1, -1, /* c8-cf */
30 -1, -1, -1, -1, -1, -1, -1, -1, /* d0-d7 */
31 -1, -1, -1, -1, -1, -1, -1, -1, /* d8-df */
32 -1, -1, -1, -1, -1, -1, -1, -1, /* e0-e7 */
33 -1, -1, -1, -1, -1, -1, -1, -1, /* e8-ef */
34 -1, -1, -1, -1, -1, -1, -1, -1, /* f0-f7 */
35 -1, -1, -1, -1, -1, -1, -1, -1, /* f8-ff */
38 int hex_to_bytes(unsigned char *binary
, const char *hex
, size_t len
)
40 for (; len
; len
--, hex
+= 2) {
41 unsigned int val
= (hexval(hex
[0]) << 4) | hexval(hex
[1]);
50 static int get_hash_hex_algop(const char *hex
, unsigned char *hash
,
51 const struct git_hash_algo
*algop
)
54 for (i
= 0; i
< algop
->rawsz
; i
++) {
55 int val
= hex2chr(hex
);
64 int get_sha1_hex(const char *hex
, unsigned char *sha1
)
66 return get_hash_hex_algop(hex
, sha1
, the_hash_algo
);
69 int get_oid_hex_algop(const char *hex
, struct object_id
*oid
,
70 const struct git_hash_algo
*algop
)
72 int ret
= get_hash_hex_algop(hex
, oid
->hash
, algop
);
74 oid_set_algo(oid
, algop
);
79 * NOTE: This function relies on hash algorithms being in order from shortest
80 * length to longest length.
82 int get_oid_hex_any(const char *hex
, struct object_id
*oid
)
85 for (i
= GIT_HASH_NALGOS
- 1; i
> 0; i
--) {
86 if (!get_oid_hex_algop(hex
, oid
, &hash_algos
[i
]))
89 return GIT_HASH_UNKNOWN
;
92 int get_oid_hex(const char *hex
, struct object_id
*oid
)
94 return get_oid_hex_algop(hex
, oid
, the_hash_algo
);
97 int parse_oid_hex_algop(const char *hex
, struct object_id
*oid
,
99 const struct git_hash_algo
*algop
)
101 int ret
= get_oid_hex_algop(hex
, oid
, algop
);
103 *end
= hex
+ algop
->hexsz
;
107 int parse_oid_hex_any(const char *hex
, struct object_id
*oid
, const char **end
)
109 int ret
= get_oid_hex_any(hex
, oid
);
111 *end
= hex
+ hash_algos
[ret
].hexsz
;
115 int parse_oid_hex(const char *hex
, struct object_id
*oid
, const char **end
)
117 return parse_oid_hex_algop(hex
, oid
, end
, the_hash_algo
);
120 char *hash_to_hex_algop_r(char *buffer
, const unsigned char *hash
,
121 const struct git_hash_algo
*algop
)
123 static const char hex
[] = "0123456789abcdef";
127 for (i
= 0; i
< algop
->rawsz
; i
++) {
128 unsigned int val
= *hash
++;
129 *buf
++ = hex
[val
>> 4];
130 *buf
++ = hex
[val
& 0xf];
137 char *oid_to_hex_r(char *buffer
, const struct object_id
*oid
)
139 return hash_to_hex_algop_r(buffer
, oid
->hash
, the_hash_algo
);
142 char *hash_to_hex_algop(const unsigned char *hash
, const struct git_hash_algo
*algop
)
145 static char hexbuffer
[4][GIT_MAX_HEXSZ
+ 1];
146 bufno
= (bufno
+ 1) % ARRAY_SIZE(hexbuffer
);
147 return hash_to_hex_algop_r(hexbuffer
[bufno
], hash
, algop
);
150 char *hash_to_hex(const unsigned char *hash
)
152 return hash_to_hex_algop(hash
, the_hash_algo
);
155 char *oid_to_hex(const struct object_id
*oid
)
157 return hash_to_hex_algop(oid
->hash
, the_hash_algo
);