| // Copyright 2007-2010 Baptiste Lepilleur |
| // Distributed under MIT license, or public domain if desired and |
| // recognized in your jurisdiction. |
| // See file LICENSE for detail or copy at http://jsoncpp.sourceforge.net/LICENSE |
| |
| #ifndef CPPTL_JSON_ASSERTIONS_H_INCLUDED |
| #define CPPTL_JSON_ASSERTIONS_H_INCLUDED |
| |
| #include <stdlib.h> |
| |
| #if !defined(JSON_IS_AMALGAMATION) |
| #include "config.h" |
| #endif // if !defined(JSON_IS_AMALGAMATION) |
| |
| #if JSON_USE_EXCEPTION |
| #include <stdexcept> |
| #define JSON_ASSERT(condition) \ |
| assert(condition); // @todo <= change this into an exception throw |
| #define JSON_FAIL_MESSAGE(message) throw std::runtime_error(message); |
| #else // JSON_USE_EXCEPTION |
| #define JSON_ASSERT(condition) assert(condition); |
| |
| // The call to assert() will show the failure message in debug builds. In |
| // release bugs we write to invalid memory in order to crash hard, so that a |
| // debugger or crash reporter gets the chance to take over. We still call exit() |
| // afterward in order to tell the compiler that this macro doesn't return. |
| #define JSON_FAIL_MESSAGE(message) \ |
| { \ |
| assert(false&& message); \ |
| strcpy(reinterpret_cast<char*>(666), message); \ |
| exit(123); \ |
| } |
| |
| #endif |
| |
| #define JSON_ASSERT_MESSAGE(condition, message) \ |
| if (!(condition)) { \ |
| JSON_FAIL_MESSAGE(message) \ |
| } |
| |
| #endif // CPPTL_JSON_ASSERTIONS_H_INCLUDED |