forked from mirrors/gecko-dev
		
	
		
			
				
	
	
		
			61 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
	
		
			2.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // 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
 | 
