From 7be31e47b2a86fa63237b2027a13bbaebc620ed7 Mon Sep 17 00:00:00 2001 From: Mark Wooding Date: Wed, 26 Apr 2017 11:53:05 +0100 Subject: [PATCH] util.[ch]: Factor out hex encoding and decoding utilities. Also improve the decoder's error handling. The interface is a bit odd, but it will fit with the uses I have in mind. Signed-off-by: Mark Wooding --- util.c | 78 ++++++++++++++++++++++++++++++++++++---------------------- util.h | 18 ++++++++++++++ 2 files changed, 66 insertions(+), 30 deletions(-) diff --git a/util.c b/util.c index d12db66..b04b3c6 100644 --- a/util.c +++ b/util.c @@ -93,31 +93,19 @@ void *safe_malloc_ary(size_t size, size_t count, const char *message) { return safe_realloc_ary(0,size,count,message); } -/* Convert a buffer into its MP_INT representation */ -void read_mpbin(MP_INT *a, uint8_t *bin, int binsize) +/* Hex-encode a buffer, and return the hex in a freshly allocated string. */ +string_t hex_encode(const uint8_t *bin, int binsize) { char *buff; int i; - buff=safe_malloc(binsize*2 + 1,"read_mpbin"); + buff=safe_malloc(binsize*2 + 1,"hex_encode"); for (i=0; i> 4]; buff[i*2+1]=hexdigits[(bin[i] & 0xf)]; } buff[binsize*2]=0; - - mpz_set_str(a, buff, 16); - free(buff); -} - -/* Convert a MP_INT into a hex string */ -char *write_mpstring(MP_INT *a) -{ - char *buff; - - buff=safe_malloc(mpz_sizeinbase(a,16)+2,"write_mpstring"); - mpz_get_str(buff, 16, a); return buff; } @@ -150,27 +138,57 @@ static uint8_t hexval(uint8_t c) return -1; } -/* Convert a MP_INT into a buffer; return length; truncate if necessary */ -int32_t write_mpbin(MP_INT *a, uint8_t *buffer, int32_t buflen) +bool_t hex_decode(uint8_t *buffer, int32_t buflen, int32_t *outlen, + cstring_t hb, bool_t allow_odd_nibble) { - char *hb; - int i,j,l; - - if (buflen==0) return 0; - hb=write_mpstring(a); - - l=strlen(hb); - i=0; j=0; + int i = 0, j = 0, l = strlen(hb), hi, lo; + bool_t ok = False; + + if (!l || !buflen) { ok = !l; goto done; } if (l&1) { /* The number starts with a half-byte */ - buffer[i++]=hexval(hb[j++]); + if (!allow_odd_nibble) goto done; + lo = hexval(hb[j++]); if (lo < 0) goto done; + buffer[i++] = lo; } - for (; hb[j] && i