diff options
Diffstat (limited to 'deps/sol2/examples/include/assert.hpp')
-rw-r--r-- | deps/sol2/examples/include/assert.hpp | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/deps/sol2/examples/include/assert.hpp b/deps/sol2/examples/include/assert.hpp new file mode 100644 index 0000000..4b7df80 --- /dev/null +++ b/deps/sol2/examples/include/assert.hpp @@ -0,0 +1,41 @@ +#ifndef EXAMPLES_ASSERT_HPP +#define EXAMPLES_ASSERT_HPP + +#ifdef SOL2_CI +struct pre_main { + pre_main() { + #ifdef _MSC_VER + _set_abort_behavior(0, _WRITE_ABORT_MSG); + #endif + } +} pm; +#endif // Prevent lockup when doing Continuous Integration + +#ifndef NDEBUG +#include <exception> +#include <iostream> +#include <cstdlib> + +# define m_assert(condition, message) \ + do { \ + if (! (condition)) { \ + std::cerr << "Assertion `" #condition "` failed in " << __FILE__ \ + << " line " << __LINE__ << ": " << message << std::endl; \ + std::terminate(); \ + } \ + } while (false) + +# define c_assert(condition) \ + do { \ + if (! (condition)) { \ + std::cerr << "Assertion `" #condition "` failed in " << __FILE__ \ + << " line " << __LINE__ << std::endl; \ + std::terminate(); \ + } \ + } while (false) +#else +# define m_assert(condition, message) do { if (false) { (void)(condition); (void)sizeof(message); } } while (false) +# define c_assert(condition) do { if (false) { (void)(condition); } } while (false) +#endif + +#endif // EXAMPLES_ASSERT_HPP |