aboutsummaryrefslogblamecommitdiffstats
path: root/behex_lower.c
blob: 6fdf4747b0d343951ff5eb2af47a2477dc776a76 (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11
12











                                                                                        
                                                                                   
 
                                                         





                                                                               
/* See LICENSE file for copyright and license details. */
#include "common.h"


/**
 * Convert a binary hashsum to lower case hexadecimal representation
 * 
 * @param  output   Output array, should have an allocation size of at least `2 * n + 1`
 * @param  hashsum  The hashsum to convert
 * @param  n        The size of `hashsum`
 */
void
libsha2_behex_lower(char *restrict output, const void *restrict hashsum_, size_t n)
{
	const unsigned char *restrict hashsum = hashsum_;
	output[2 * n] = '\0';
	while (n--) {
		output[2 * n + 0] = "0123456789abcdef"[(hashsum[n] >> 4) & 15];
		output[2 * n + 1] = "0123456789abcdef"[(hashsum[n] >> 0) & 15];
	}
}