From 3345a1fc6e87cd910602ec0f428073632d2f1ad1 Mon Sep 17 00:00:00 2001 From: Tavian Barnes Date: Tue, 4 Mar 2025 13:05:16 -0500 Subject: diag: Don't leave unused assertion messages in the binary Rather than hiding them with %.0s, use a ternary to replace them with an empty string if they would be unused. --- src/diag.h | 25 +++++++++++++++++++------ 1 file changed, 19 insertions(+), 6 deletions(-) (limited to 'src') diff --git a/src/diag.h b/src/diag.h index a8ee911..645dbb1 100644 --- a/src/diag.h +++ b/src/diag.h @@ -88,6 +88,12 @@ void bfs_abortf(const char *format, ...); # define bfs_ebug bfs_eabort #endif +/** + * Get the default assertion message, if no format string was specified. + */ +#define BFS_DIAG_MSG_(format, str) \ + (sizeof(format) > 1 ? "" : str) + /** * Unconditional assert. */ @@ -95,11 +101,14 @@ void bfs_abortf(const char *format, ...); bfs_verify_(#__VA_ARGS__, __VA_ARGS__, "", ) #define bfs_verify_(str, cond, format, ...) \ - ((cond) ? (void)0 : bfs_abortf( \ + ((cond) ? (void)0 : bfs_verify__(format, BFS_DIAG_MSG_(format, str), __VA_ARGS__)) + +#define bfs_verify__(format, ...) \ + bfs_abortf( \ sizeof(format) > 1 \ - ? BFS_DIAG_FORMAT_("%.0s" format "%s") \ + ? BFS_DIAG_FORMAT_("%s" format "%s") \ : BFS_DIAG_FORMAT_("Assertion failed: `%s`"), \ - BFS_DIAG_ARGS_(str, __VA_ARGS__))) + BFS_DIAG_ARGS_(__VA_ARGS__)) /** * Unconditional assert, including the last error. @@ -107,12 +116,16 @@ void bfs_abortf(const char *format, ...); #define bfs_everify(...) \ bfs_everify_(#__VA_ARGS__, __VA_ARGS__, "", ) + #define bfs_everify_(str, cond, format, ...) \ - ((cond) ? (void)0 : bfs_abortf( \ + ((cond) ? (void)0 : bfs_everify__(format, BFS_DIAG_MSG_(format, str), __VA_ARGS__)) + +#define bfs_everify__(format, ...) \ + bfs_abortf( \ sizeof(format) > 1 \ - ? BFS_DIAG_FORMAT_("%.0s" format "%s: %s") \ + ? BFS_DIAG_FORMAT_("%s" format "%s: %s") \ : BFS_DIAG_FORMAT_("Assertion failed: `%s`: %s"), \ - BFS_DIAG_ARGS_(str, __VA_ARGS__ errstr(), ))) + BFS_DIAG_ARGS_(__VA_ARGS__ errstr(), )) /** * Assert in debug builds; no-op in release builds. -- cgit v1.2.3