aboutsummaryrefslogtreecommitdiff
path: root/libpsn00b/include/assert.h
blob: 8f8df74e6286f5dd09cdda80abdcf2064b20e13a (plain) (blame)
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/*
 * PSn00bSDK assert macro and internal logging
 * (C) 2022-2023 spicyjpeg - MPL licensed
 *
 * The _sdk_*() macros are used internally by PSn00bSDK to output messages when
 * building in debug mode.
 */

#pragma once

#include <stdio.h>

#ifdef __cplusplus
extern "C" {
#endif

void _assert_abort(const char *file, int line, const char *expr);

#ifdef __cplusplus
}
#endif

#ifdef NDEBUG

#define assert(expr)
#define _sdk_log(fmt, ...)
#define _sdk_assert(expr, fmt, ...)
#define _sdk_validate_args_void(expr)
#define _sdk_validate_args(expr, ret)

#else

#define assert(expr) \
	((expr) ? ((void) 0) : _assert_abort(__FILE__, __LINE__, #expr))

#ifdef SDK_LIBRARY_NAME
#define _sdk_log(fmt, ...) \
	printf(SDK_LIBRARY_NAME ": " fmt __VA_OPT__(,) __VA_ARGS__)
#else
#define _sdk_log(fmt, ...) \
	printf(fmt __VA_OPT__(,) __VA_ARGS__)
#endif

#define _sdk_assert(expr, ret, fmt, ...) \
	if (!(expr)) { \
		_sdk_log(fmt, __VA_ARGS__); \
		return ret; \
	}
#define _sdk_validate_args_void(expr) \
	if (!(expr)) { \
		_sdk_log("invalid args to %s() (%s)\n", __func__, #expr); \
		return; \
	}
#define _sdk_validate_args(expr, ret) \
	if (!(expr)) { \
		_sdk_log("invalid args to %s() (%s)\n", __func__, #expr); \
		return ret; \
	}

#endif