aboutsummaryrefslogtreecommitdiffstats
path: root/lib/sol2/examples/include/assert.hpp
diff options
context:
space:
mode:
authorAndy <drumsetmonkey@gmail.com>2019-08-29 13:07:45 -0400
committerAndy <drumsetmonkey@gmail.com>2019-08-29 13:07:45 -0400
commit4ac4b280abf2ffa28caa5a532353115a3033444f (patch)
tree2a13d658bb454360b2faf401244bb0321d3460d4 /lib/sol2/examples/include/assert.hpp
parente9758416b18b27a65337c28d9641afc0ee89b34b (diff)
parent7a46fa2dd3dad3f038bf8e7339bc67abca428ae6 (diff)
Started creating scripting library/namespace and added sol2 for interfacing
Diffstat (limited to 'lib/sol2/examples/include/assert.hpp')
-rw-r--r--lib/sol2/examples/include/assert.hpp41
1 files changed, 41 insertions, 0 deletions
diff --git a/lib/sol2/examples/include/assert.hpp b/lib/sol2/examples/include/assert.hpp
new file mode 100644
index 0000000..4b7df80
--- /dev/null
+++ b/lib/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