[common] asserts now display expression of assert (#2997)
Easiest change in the world, will help to pinpoint asserts quicker, it's just a relatively small thing so doesn't even need testing. Signed-off-by: lizzie lizzie@eden-emu.dev Reviewed-on: https://git.eden-emu.dev/eden-emu/eden/pulls/2997 Reviewed-by: Caio Oliveira <caiooliveirafarias0@gmail.com> Reviewed-by: CamilleLaVey <camillelavey99@gmail.com> Co-authored-by: lizzie <lizzie@eden-emu.dev> Co-committed-by: lizzie <lizzie@eden-emu.dev>
This commit is contained in:
parent
941caf31ce
commit
97054357d2
|
|
@ -22,33 +22,21 @@ void AssertFailSoftImpl();
|
||||||
#define YUZU_NO_INLINE __attribute__((noinline))
|
#define YUZU_NO_INLINE __attribute__((noinline))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define ASSERT(_a_) \
|
|
||||||
([&]() YUZU_NO_INLINE { \
|
|
||||||
if (!(_a_)) [[unlikely]] { \
|
|
||||||
LOG_CRITICAL(Debug, "Assert"); \
|
|
||||||
AssertFailSoftImpl(); \
|
|
||||||
} \
|
|
||||||
}())
|
|
||||||
|
|
||||||
#define ASSERT_MSG(_a_, ...) \
|
#define ASSERT_MSG(_a_, ...) \
|
||||||
([&]() YUZU_NO_INLINE { \
|
([&]() YUZU_NO_INLINE { \
|
||||||
if (!(_a_)) [[unlikely]] { \
|
if (!(_a_)) [[unlikely]] { \
|
||||||
LOG_CRITICAL(Debug, "Assert\n" __VA_ARGS__); \
|
LOG_CRITICAL(Debug, __FILE__ ": assert\n" __VA_ARGS__); \
|
||||||
AssertFailSoftImpl(); \
|
AssertFailSoftImpl(); \
|
||||||
} \
|
} \
|
||||||
}())
|
}())
|
||||||
|
#define ASSERT(_a_) ASSERT_MSG(_a_, "{}", #_a_)
|
||||||
#define UNREACHABLE() \
|
|
||||||
do { \
|
|
||||||
LOG_CRITICAL(Debug, "Unreachable"); \
|
|
||||||
AssertFatalImpl(); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#define UNREACHABLE_MSG(...) \
|
#define UNREACHABLE_MSG(...) \
|
||||||
do { \
|
do { \
|
||||||
LOG_CRITICAL(Debug, "Unreachable\n" __VA_ARGS__); \
|
LOG_CRITICAL(Debug, __FILE__ ": unreachable\n" __VA_ARGS__); \
|
||||||
AssertFatalImpl(); \
|
AssertFatalImpl(); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
#define UNREACHABLE() UNREACHABLE_MSG("")
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
#define DEBUG_ASSERT(_a_) ASSERT(_a_)
|
#define DEBUG_ASSERT(_a_) ASSERT(_a_)
|
||||||
|
|
@ -68,20 +56,12 @@ void AssertFailSoftImpl();
|
||||||
#define UNIMPLEMENTED_IF(cond) ASSERT_MSG(!(cond), "Unimplemented code!")
|
#define UNIMPLEMENTED_IF(cond) ASSERT_MSG(!(cond), "Unimplemented code!")
|
||||||
#define UNIMPLEMENTED_IF_MSG(cond, ...) ASSERT_MSG(!(cond), __VA_ARGS__)
|
#define UNIMPLEMENTED_IF_MSG(cond, ...) ASSERT_MSG(!(cond), __VA_ARGS__)
|
||||||
|
|
||||||
// If the assert is ignored, execute _b_
|
|
||||||
#define ASSERT_OR_EXECUTE(_a_, _b_) \
|
|
||||||
do { \
|
|
||||||
ASSERT(_a_); \
|
|
||||||
if (!(_a_)) [[unlikely]] { \
|
|
||||||
_b_ \
|
|
||||||
} \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
// If the assert is ignored, execute _b_
|
// If the assert is ignored, execute _b_
|
||||||
#define ASSERT_OR_EXECUTE_MSG(_a_, _b_, ...) \
|
#define ASSERT_OR_EXECUTE_MSG(_a_, _b_, ...) \
|
||||||
do { \
|
do { \
|
||||||
ASSERT_MSG(_a_, __VA_ARGS__); \
|
ASSERT_MSG(_a_, __VA_ARGS__); \
|
||||||
if (!(_a_)) [[unlikely]] { \
|
if (!(_a_)) { _b_ } \
|
||||||
_b_ \
|
|
||||||
} \
|
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
// If the assert is ignored, execute _b_
|
||||||
|
#define ASSERT_OR_EXECUTE(_a_, _b_) ASSERT_OR_EXECUTE_MSG(_a_, _b_, "{}", #_a_)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue