mirror of
https://github.com/neocturne/fastd.git
synced 2025-05-15 04:35:08 +02:00
Add hexdump support to fastd logging functions
This commit is contained in:
parent
fce2157168
commit
0d9b7eeb90
1 changed files with 14 additions and 0 deletions
14
src/log.c
14
src/log.c
|
@ -107,6 +107,15 @@ static size_t snprint_peer_str(char *buffer, size_t size, const fastd_peer_t *pe
|
||||||
return snprintf_safe(buffer, size, "(null)");
|
return snprintf_safe(buffer, size, "(null)");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Add a hexdump to a string buffer */
|
||||||
|
static size_t snprint_hexdump(char *buffer, size_t size, const uint8_t *d, size_t len) {
|
||||||
|
size_t n = 0, i;
|
||||||
|
for (i = 0; i < len && n < size; i++)
|
||||||
|
n += snprintf_safe(buffer+n, size-n, "%02x", d[i]);
|
||||||
|
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
/** vsnprintf-like function using different conversion specifiers */
|
/** vsnprintf-like function using different conversion specifiers */
|
||||||
static int fastd_vsnprintf(char *buffer, size_t size, const char *format, va_list ap) {
|
static int fastd_vsnprintf(char *buffer, size_t size, const char *format, va_list ap) {
|
||||||
char *buffer_start = buffer;
|
char *buffer_start = buffer;
|
||||||
|
@ -171,6 +180,11 @@ static int fastd_vsnprintf(char *buffer, size_t size, const char *format, va_lis
|
||||||
buffer += snprint_peer_str(buffer, buffer_end-buffer, va_arg(ap, const fastd_peer_t *));
|
buffer += snprint_peer_str(buffer, buffer_end-buffer, va_arg(ap, const fastd_peer_t *));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'H':
|
||||||
|
p = va_arg(ap, const uint8_t *);
|
||||||
|
buffer += snprint_hexdump(buffer, buffer_end-buffer, p, va_arg(ap, size_t));
|
||||||
|
break;
|
||||||
|
|
||||||
case 'I':
|
case 'I':
|
||||||
case 'B':
|
case 'B':
|
||||||
case 'L':
|
case 'L':
|
||||||
|
|
Loading…
Add table
Reference in a new issue