Skip to content

Commit

Permalink
AK: Print VERIFY() error messages in release builds
Browse files Browse the repository at this point in the history
Until now, VERIFY() failures would just cause a __builtin_trap() in
release builds, which made them a bit too harsh. This commit adds an
out-of-line helper function that prints the error before trapping.
  • Loading branch information
awesomekling committed Oct 6, 2022
1 parent 4fdfaff commit da781e9
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 3 deletions.
20 changes: 20 additions & 0 deletions AK/Assertions.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
/*
* Copyright (c) 2018-2020, Andreas Kling <[email protected]>
*
* SPDX-License-Identifier: BSD-2-Clause
*/

#include <AK/Assertions.h>
#include <AK/Format.h>

#if !defined(KERNEL) && defined(NDEBUG)
extern "C" {

void ak_verification_failed(char const* message)
{
dbgln("VERIFICATION FAILED: {}", message);
__builtin_trap();
}
}

#endif
9 changes: 6 additions & 3 deletions AK/Assertions.h
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,12 @@
# ifndef NDEBUG
# define VERIFY assert
# else
# define VERIFY(expr) \
(__builtin_expect(!(expr), 0) \
? __builtin_trap() \
# define __stringify_helper(x) # x
# define __stringify(x) __stringify_helper(x)
extern "C" __attribute__((noreturn)) void ak_verification_failed(char const*);
# define VERIFY(expr) \
(__builtin_expect(!(expr), 0) \
? ak_verification_failed(#expr "\n" __FILE__ ":" __stringify(__LINE__)) \
: (void)0)
# endif
# define VERIFY_NOT_REACHED() VERIFY(false) /* NOLINT(cert-dcl03-c,misc-static-assert) No, this can't be static_assert, it's a runtime check */
Expand Down

0 comments on commit da781e9

Please sign in to comment.