| 1234567891011121314151617181920212223242526272829303132333435363738394041 |
- // 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
- #if !defined(JSON_IS_AMALGAMATION)
- #include "config.h"
- #endif // if !defined(JSON_IS_AMALGAMATION)
- #include <stdlib.h>
- #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
|