00001 // [License] 00002 // The Ariba-Underlay Copyright 00003 // 00004 // Copyright (c) 2008-2009, Institute of Telematics, Universität Karlsruhe (TH) 00005 // 00006 // Institute of Telematics 00007 // Universität Karlsruhe (TH) 00008 // Zirkel 2, 76128 Karlsruhe 00009 // Germany 00010 // 00011 // Redistribution and use in source and binary forms, with or without 00012 // modification, are permitted provided that the following conditions are 00013 // met: 00014 // 00015 // 1. Redistributions of source code must retain the above copyright 00016 // notice, this list of conditions and the following disclaimer. 00017 // 2. Redistributions in binary form must reproduce the above copyright 00018 // notice, this list of conditions and the following disclaimer in the 00019 // documentation and/or other materials provided with the distribution. 00020 // 00021 // THIS SOFTWARE IS PROVIDED BY THE INSTITUTE OF TELEMATICS ``AS IS'' AND 00022 // ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00023 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 00024 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE ARIBA PROJECT OR 00025 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00026 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00027 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00028 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00029 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00030 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00031 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00032 // 00033 // The views and conclusions contained in the software and documentation 00034 // are those of the authors and should not be interpreted as representing 00035 // official policies, either expressed or implied, of the Institute of 00036 // Telematics. 00037 // [License] 00038 00039 #ifndef LOGGING_H__ 00040 #define LOGGING_H__ 00041 00042 #include <iostream> 00043 #include <cstdlib> 00044 #include <log4cxx/logger.h> 00045 #include <log4cxx/basicconfigurator.h> 00046 00047 #ifdef LOGCOLORS 00048 00049 #define colorDefault { std::cout << "\033[0m"; } /*reset*/ 00050 #define colorDebug { std::cout << "\033[33m"; } /*cyan*/ 00051 #define colorInfo { std::cout << "\033[32m"; } /*green*/ 00052 #define colorWarn { std::cout << "\033[34m"; } /*blue*/ 00053 #define colorError { std::cout << "\033[31m"; } /*red*/ 00054 00055 #else 00056 00057 #define colorDefault { } 00058 #define colorDebug { } 00059 #define colorInfo { } 00060 #define colorWarn { } 00061 #define colorError { } 00062 00063 #endif // ENABLE_LOGCOLORS 00064 00065 #define use_logging_h(x) \ 00066 private: static log4cxx::LoggerPtr logger; 00067 00068 #define use_logging_cpp(x) \ 00069 log4cxx::LoggerPtr x::logger(log4cxx::Logger::getLogger(#x)); 00070 00071 #define logging_trace(x) { LOG4CXX_TRACE(logger,x); } 00072 #define logging_debug(x) {colorDebug; LOG4CXX_DEBUG(logger,x); colorDefault; } 00073 #define logging_info(x) {colorInfo; LOG4CXX_INFO(logger,x); colorDefault; } 00074 #define logging_warn(x) {colorWarn; LOG4CXX_WARN(logger,x); colorDefault; } 00075 #define logging_error(x) {colorError; LOG4CXX_ERROR(logger,x); colorDefault; } 00076 #define logging_fatal(x) {colorError; LOG4CXX_FATAL(logger,x); colorDefault; exit(-1); } 00077 00078 #endif //LOGGING_H__