|
- // Copyright 2007-2010 Baptiste Lepilleur and The JsonCpp Authors
- // 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 JSON_ASSERTIONS_H_INCLUDED
- #define JSON_ASSERTIONS_H_INCLUDED
-
- #include <cstdlib>
- #include <sstream>
-
- #if !defined(JSON_IS_AMALGAMATION)
- #include "config.h"
- #endif // if !defined(JSON_IS_AMALGAMATION)
-
- /** It should not be possible for a maliciously designed file to
- * cause an abort() or seg-fault, so these macros are used only
- * for pre-condition violations and internal logic errors.
- */
- #if JSON_USE_EXCEPTION
-
- // @todo <= add detail about condition in exception
- #define JSON_ASSERT(condition) \
- do { \
- if (!(condition)) { \
- Json::throwLogicError("assert json failed"); \
- } \
- } while (0)
-
- #define JSON_FAIL_MESSAGE(message) \
- do { \
- OStringStream oss; \
- oss << message; \
- Json::throwLogicError(oss.str()); \
- abort(); \
- } while (0)
-
- #else // JSON_USE_EXCEPTION
-
- #define JSON_ASSERT(condition) assert(condition)
-
- // The call to assert() will show the failure message in debug builds. In
- // release builds we abort, for a core-dump or debugger.
- #define JSON_FAIL_MESSAGE(message) \
- { \
- OStringStream oss; \
- oss << message; \
- assert(false && oss.str().c_str()); \
- abort(); \
- }
-
- #endif
-
- #define JSON_ASSERT_MESSAGE(condition, message) \
- do { \
- if (!(condition)) { \
- JSON_FAIL_MESSAGE(message); \
- } \
- } while (0)
-
- #endif // JSON_ASSERTIONS_H_INCLUDED
|