From 37f2cac0981177aef291a3411c64c0494187cfbc Mon Sep 17 00:00:00 2001 From: George Hazan Date: Tue, 22 May 2012 11:58:35 +0000 Subject: JSON plugin git-svn-id: http://svn.miranda-ng.org/main/trunk@128 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c --- plugins/json/Source/JSONDebug.cpp | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 plugins/json/Source/JSONDebug.cpp (limited to 'plugins/json/Source/JSONDebug.cpp') diff --git a/plugins/json/Source/JSONDebug.cpp b/plugins/json/Source/JSONDebug.cpp new file mode 100644 index 0000000000..3061fff616 --- /dev/null +++ b/plugins/json/Source/JSONDebug.cpp @@ -0,0 +1,39 @@ +#include "JSONDebug.h" +#ifdef JSON_DEBUG + +#ifdef JSON_STDERROR + #include //need std::cerr +#else + //otherwise, use a callback to tell the end user what happened + json_error_callback_t ErrorCallback = 0; + void JSONDebug::register_callback(json_error_callback_t callback){ + ErrorCallback = callback; + } +#endif + +//Something went wrong or an assert failed +void JSONDebug::_JSON_FAIL(const json_string & msg){ + #ifdef JSON_STDERROR //no callback, just use stderror + #ifndef JSON_UNICODE + std::cerr << msg << std::endl; + #else + std::cerr << std::string(msg.begin(), msg.end()) << std::endl; + #endif + #else + if (ErrorCallback){ //only do anything if the callback is registered + #ifdef JSON_LIBRARY + ErrorCallback(msg.c_str()); + #else + ErrorCallback(msg); + #endif + } + #endif +} + +//asserts that condition is true, more useful than cassert because it lets you keep going +void JSONDebug::_JSON_ASSERT(bool condition, const json_string & msg){ + if (!condition){ + _JSON_FAIL(msg); + } +} +#endif -- cgit v1.2.3