diff options
author | Andy Belle-Isle <drumsetmonkey@gmail.com> | 2019-08-30 00:19:31 -0400 |
---|---|---|
committer | Andy Belle-Isle <drumsetmonkey@gmail.com> | 2019-08-30 00:19:31 -0400 |
commit | bd3fe0cac583739bc0d7c4b5c8f301bb350abca0 (patch) | |
tree | 7eeb1aabcebd6999de1c3457d0882246ec0ff4d4 /deps/sol2/examples/include/assert.hpp | |
parent | 2662ac356ce14dacfbc91689fd37244facff4989 (diff) |
Renamed lib to deps so github will ignore it for language stats
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 |