00001 /******************************************************************************* 00002 * Copyright (C) 2004 Vintela, Inc. All rights reserved. 00003 * Copyright (C) 2005 Novell, Inc. All rights reserved. 00004 * 00005 * Redistribution and use in source and binary forms, with or without 00006 * modification, are permitted provided that the following conditions are met: 00007 * 00008 * - Redistributions of source code must retain the above copyright notice, 00009 * this list of conditions and the following disclaimer. 00010 * 00011 * - Redistributions in binary form must reproduce the above copyright notice, 00012 * this list of conditions and the following disclaimer in the documentation 00013 * and/or other materials provided with the distribution. 00014 * 00015 * - Neither the name of Vintela, Inc., Novell, Inc., nor the names of its 00016 * contributors may be used to endorse or promote products derived from this 00017 * software without specific prior written permission. 00018 * 00019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' 00020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00022 * ARE DISCLAIMED. IN NO EVENT SHALL Vintela, Inc., Novell, Inc., OR THE 00023 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00024 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00025 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 00026 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 00027 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 00028 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 00029 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00030 *******************************************************************************/ 00031 00032 00037 #include "blocxx/BLOCXX_config.h" 00038 #include "blocxx/CerrAppender.hpp" 00039 #include "blocxx/String.hpp" 00040 #include "blocxx/Mutex.hpp" 00041 #include "blocxx/MutexLock.hpp" 00042 00043 #include <iostream> 00044 00045 namespace BLOCXX_NAMESPACE 00046 { 00047 00049 CerrAppender::CerrAppender(const StringArray& components, 00050 const StringArray& categories, 00051 const String& pattern) 00052 : LogAppender(components, categories, pattern) 00053 { 00054 } 00055 00057 CerrAppender::~CerrAppender() 00058 { 00059 } 00060 00062 namespace 00063 { 00064 Mutex cerrGuard; 00065 } 00066 00067 void 00068 CerrAppender::doProcessLogMessage(const String& formattedMessage, const LogMessage& message) const 00069 { 00070 MutexLock lock(cerrGuard); 00071 std::clog << formattedMessage << std::endl; 00072 } 00073 00075 // const char* red = "\x1b[1;31;40m"; 00076 // const char* darkRed = "\x1b[0;31;40m"; 00077 // const char* green = "\x1b[1;32;40m"; 00078 // const char* darkGreen = "\x1b[0;32;40m"; 00079 // const char* yellow = "\x1b[1;33;40m"; 00080 // const char* darkYellow = "\x1b[0;33;40m"; 00081 // const char* blue = "\x1b[1;34;40m"; 00082 // const char* darkBlue = "\x1b[0;34;40m"; 00083 // const char* purple = "\x1b[1;35;40m"; 00084 // const char* darkPurple = "\x1b[0;35;40m"; 00085 // const char* cyan = "\x1b[1;36;40m"; 00086 // const char* darkCyan = "\x1b[0;36;40m"; 00087 // const char* white = "\x1b[1;37;40m"; 00088 // const char* darkWhite = "\x1b[0;37;40m"; 00089 // const char* gray = "\x1b[0;37;40m"; 00090 // const char* resetColor = "\x1b[0;37;40m"; 00091 00092 // colorized version: const String CerrAppender::STR_DEFAULT_MESSAGE_PATTERN("\x1b[1;37;40m[\x1b[1;31;40m%-.6t\x1b[1;37;40m]\x1b[1;32;40m %m\x1b[0;37;40m"); 00093 const String CerrAppender::STR_DEFAULT_MESSAGE_PATTERN("[%-.6t] %m"); 00094 00095 00096 } // end namespace BLOCXX_NAMESPACE 00097 00098 00099