00001 /* 00002 * Copyright (C) 2007 Pleyo. All rights reserved. 00003 * 00004 * Redistribution and use in source and binary forms, with or without 00005 * modification, are permitted provided that the following conditions 00006 * are met: 00007 * 00008 * 1. Redistributions of source code must retain the above copyright 00009 * notice, this list of conditions and the following disclaimer. 00010 * 2. Redistributions in binary form must reproduce the above copyright 00011 * notice, this list of conditions and the following disclaimer in the 00012 * documentation and/or other materials provided with the distribution. 00013 * 3. Neither the name of Pleyo nor the names of 00014 * its contributors may be used to endorse or promote products derived 00015 * from this software without specific prior written permission. 00016 * 00017 * THIS SOFTWARE IS PROVIDED BY PLEYO AND ITS CONTRIBUTORS "AS IS" AND ANY 00018 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 00019 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 00020 * DISCLAIMED. IN NO EVENT SHALL PLEYO OR ITS CONTRIBUTORS BE LIABLE FOR ANY 00021 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 00022 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 00023 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 00024 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 00025 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 00026 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00027 */ 00028 00048 #ifndef BTLOGHELPER_H 00049 #define BTLOGHELPER_H 00050 00051 #ifdef BAL_LOG 00052 00053 #include "BTLogManager.h" 00054 #include <stdarg.h> 00055 #include <stdio.h> 00056 #include <stdlib.h> 00057 00058 namespace BALFacilities { 00059 00060 extern BTLogManager logger; 00061 // FIXME SRO temporary length of variadic args size to 0xff 00062 00063 #define DBG(...) BALFacilities::logger.send(MODULE_UNDEFINED, LEVEL_INFO, __FILE__, __LINE__, __func__, __VA_ARGS__) 00064 00065 #define DBGM(module, ...) BALFacilities::logger.send(module, LEVEL_INFO, \ 00066 __FILE__, __LINE__, __func__, __VA_ARGS__) 00067 00068 #define DBGML(module, level, ...) BALFacilities::logger.send(module, level,\ 00069 __FILE__, __LINE__, __func__, __VA_ARGS__) 00070 00071 } // namespace BALFacilities 00072 00073 #else // BAL_LOG 00074 // we're in release mode 00075 00076 namespace BALFacilities { 00077 00078 #define DBG(...) ((void)0) 00079 #define DBGM(module, ...) ((void)0) 00080 #define DBGML(module, level, ...) ((void)0) 00081 00082 inline char* make_message(const char *format, ...) { return 0; } 00083 00084 } // namespace BALFacilities 00085 00086 #endif // DEBUG 00087 #endif // BTLOGHELPER_H