Menu

debug.h

Go to the documentation of this file.
00001 /*******************************************************************************
00002  *
00003  * Copyright (c) 2008-2010 Michael Schulze <mschulze@ivs.cs.uni-magdeburg.de>
00004  *                    2010 Philipp Werner <philipp.werner@st.ovgu.de>
00005  * All rights reserved.
00006  *
00007  *    Redistribution and use in source and binary forms, with or without
00008  *    modification, are permitted provided that the following conditions
00009  *    are met:
00010  *
00011  *    * Redistributions of source code must retain the above copyright
00012  *      notice, this list of conditions and the following disclaimer.
00013  *
00014  *    * Redistributions in binary form must reproduce the above copyright
00015  *      notice, this list of conditions and the following disclaimer in
00016  *      the documentation and/or other materials provided with the
00017  *      distribution.
00018  *
00019  *    * Neither the name of the copyright holders nor the names of
00020  *      contributors may be used to endorse or promote products derived
00021  *      from this software without specific prior written permission.
00022  *
00023  *
00024  *    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
00025  *    IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
00026  *    TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
00027  *    PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
00028  *    OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
00029  *    SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
00030  *    LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00031  *    DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
00032  *    THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00033  *    (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00034  *    OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00035  *
00036  *
00037  * $Id$
00038  *
00039  ******************************************************************************/
00040 
00041 #ifndef __DEBUG_h__
00042 #define __DEBUG_h__
00043 
00044 #ifdef __GNUC__
00045 #define FUNCTION_SIGNATURE  __FUNCTION__
00046 #else
00047 #define FUNCTION_SIGNATURE  __FUNCSIG__
00048 #endif
00049 
00050 #include "logging/logging.h"
00051 
00052 #ifdef FAMOUSO_DEBUG_DISABLE
00053 LOGGING_DISABLE_LEVEL(::logging::Trace);
00054 LOGGING_DISABLE_LEVEL(::logging::Info);
00055 #endif
00056 
00057 #define TRACE_FUNCTION do {                                         \
00058     ::logging::log::emit< ::logging::Trace>()                       \
00059        << '"' << FUNCTION_SIGNATURE << '"'                          \
00060        << PROGMEMSTRING(" -> "__FILE__":" __TOSTR__(__LINE__)" ")    \
00061        << ::logging::log::endl;                                     \
00062 } while(0)
00063 
00064 
00065 #if !defined(ASSERT_FAILED_HANDLER)
00066 
00067 #include <stdlib.h>
00068 
00077 template<typename ExprT, typename FileT, typename LineT> static inline
00078 void __famouso_assert_failed_handler(ExprT expr, FileT file, LineT line) {
00079     using ::logging::log;
00080     log::emit() << file << ':' << line
00081         << PROGMEMSTRING(": Assertion '") << expr
00082         << PROGMEMSTRING("' failed.") << log::endl;
00083     abort();
00084 }
00085 
00092 #define FAMOUSO_ASSERT_FAILED_HANDLER ::__famouso_assert_failed_handler
00093 
00094 #endif
00095 
00096 #if defined(NDEBUG)
00097 #define FAMOUSO_ASSERT(expr)
00098 #define FOR_FAMOUSO_ASSERT_ONLY(code)
00099 #else
00100 
00122 #define FAMOUSO_ASSERT(expr) ((expr) ? ((void)0) :                             \
00123             FAMOUSO_ASSERT_FAILED_HANDLER(PROGMEMSTRING(#expr),                \
00124                                           PROGMEMSTRING(__FILE__),             \
00125                                           PROGMEMSTRING(__TOSTR__(__LINE__))))
00126 
00139 #define FOR_FAMOUSO_ASSERT_ONLY(code) code
00140 
00141 #endif
00142 
00143 
00144 #endif