-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathdebug.h
27 lines (20 loc) · 1017 Bytes
/
debug.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#ifndef debug_header
#define debug_header
#include <unistd.h>
#include <stdint.h>
#include <stdio.h>
void _dump(FILE *f, const char *file, int line, const uint8_t *data, size_t len, unsigned width, int ascii);
#define DEBUG_LIB 0
#define DEBUG_ALLOC 0
#define DEBUG_RAWREAD 0
#define DEBUG_PARSE 0
#define DEBUG_OUTPUT 0
#define DEBUG_DISASSEMBLY 0
#define IFDEBUG(TYPE) (DEBUG_ ## TYPE)
#define DEBUGF(TYPE, FMT, ...) if (DEBUG_ ## TYPE) fprintf(stderr, "%s:%u " #TYPE " - " FMT "\n", __FILE__, __LINE__, ##__VA_ARGS__)
#define WARNF(FMT, ...) fprintf(stderr, "%s:%u WARNING - " FMT "\n", __FILE__, __LINE__, ##__VA_ARGS__)
#define DUMP(TYPE, B, L) if (DEBUG_ ## TYPE) _dump(stderr, __FILE__,__LINE__,(uint8_t*)(B),(L),16,1)
#define DUMP_STRUCT(TYPE, S) if (DEBUG_ ## TYPE) _dump(stderr, __FILE__,__LINE__,(uint8_t*)&S,sizeof S,16,0)
#define DUMP_ARRAY(TYPE, S,C) if (DEBUG_ ## TYPE) _dump(stderr, __FILE__,__LINE__,(uint8_t*)&S,C * sizeof S,sizeof S,0)
#define UNUSED(x) x __attribute__((__unused__))
#endif