2011-05-24 01:03:22 +00:00
|
|
|
// 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
|
|
|
|
|
2011-05-24 06:27:36 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
|
2011-05-24 01:03:22 +00:00
|
|
|
#if !defined(JSON_IS_AMALGAMATION)
|
|
|
|
# include <json/config.h>
|
|
|
|
#endif // if !defined(JSON_IS_AMALGAMATION)
|
|
|
|
|
2011-09-14 08:41:37 +00:00
|
|
|
#if JSON_USE_EXCEPTION
|
2011-05-24 01:03:22 +00:00
|
|
|
#define JSON_ASSERT( condition ) assert( condition ); // @todo <= change this into an exception throw
|
|
|
|
#define JSON_FAIL_MESSAGE( message ) throw std::runtime_error( message );
|
2011-09-14 08:41:37 +00:00
|
|
|
#else // JSON_USE_EXCEPTION
|
2011-05-24 01:03:22 +00:00
|
|
|
#define JSON_ASSERT( condition ) assert( condition );
|
2011-12-22 03:18:24 +00:00
|
|
|
|
|
|
|
// 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 instead of
|
|
|
|
// calling exit(), so that a debugger or crash reporter gets the chance to take
|
|
|
|
// over.
|
|
|
|
#define JSON_FAIL_MESSAGE( message ) { assert(false && message); strcpy(reinterpret_cast<char*>(666), message); }
|
|
|
|
|
2011-05-24 01:03:22 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#define JSON_ASSERT_MESSAGE( condition, message ) if (!( condition )) { JSON_FAIL_MESSAGE( message ) }
|
|
|
|
|
|
|
|
#endif // CPPTL_JSON_ASSERTIONS_H_INCLUDED
|