AppenderLogger.cpp

Go to the documentation of this file.
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/AppenderLogger.hpp"
00039 #include "blocxx/LogMessage.hpp"
00040 #include "blocxx/LogAppender.hpp"
00041 
00042 #ifdef BLOCXX_WIN32
00043 #include <algorithm>
00044 #endif
00045 
00046 namespace BLOCXX_NAMESPACE
00047 {
00048 
00050 AppenderLogger::AppenderLogger(
00051    const String& defaultComponent, 
00052    ELogLevel level, 
00053    const LogAppenderRef& appender)
00054    : Logger(defaultComponent, level)
00055    , m_appenders(1, appender)
00056 {
00057 }
00058 
00060 AppenderLogger::AppenderLogger(
00061    const String& defaultComponent, 
00062    const Array<LogAppenderRef>& appenders)
00063    : Logger(defaultComponent, getLevel(appenders))
00064    , m_appenders(appenders)
00065 {
00066 }
00067 
00069 AppenderLogger::~AppenderLogger()
00070 {
00071 }
00072 
00074 void
00075 AppenderLogger::addLogAppender(const LogAppenderRef& appender)
00076 {
00077    m_appenders.append(appender);
00078 }
00079 
00081 void
00082 AppenderLogger::doProcessLogMessage(
00083    const LogMessage& message) const
00084 {
00085    for (size_t i = 0; i < m_appenders.size(); ++i)
00086    {
00087       m_appenders[i]->logMessage(message);
00088    }
00089 }
00090 
00092 bool
00093 AppenderLogger::doComponentAndCategoryAreEnabled(
00094    const String& component, 
00095    const String& category) const
00096 {
00097    for (size_t i = 0; i < m_appenders.size(); ++i)
00098    {
00099       if (m_appenders[i]->componentAndCategoryAreEnabled(component, category))
00100       {
00101          return true;
00102       }
00103    }
00104    return false;
00105 }
00106 
00108 bool
00109 AppenderLogger::doCategoryIsEnabled(
00110    const String& category) const
00111 {
00112    for (size_t i = 0; i < m_appenders.size(); ++i)
00113    {
00114       if (m_appenders[i]->categoryIsEnabled(category))
00115       {
00116          return true;
00117       }
00118    }
00119    return false;
00120 }
00121 
00123 LoggerRef
00124 AppenderLogger::doClone() const
00125 {
00126    return LoggerRef(new AppenderLogger(*this));
00127 }
00128 
00130 #ifdef BLOCXX_WIN32
00131 using namespace std;
00132 #endif
00133 
00134 ELogLevel
00135 AppenderLogger::getLevel(
00136    const Array<LogAppenderRef>& appenders)
00137 {
00138    ELogLevel rv = E_FATAL_ERROR_LEVEL;
00139    for (size_t i = 0; i < appenders.size(); ++i)
00140    {
00141 #ifdef BLOCXX_WIN32
00142       // This format was necessary on windoz C2589
00143       rv = max(rv, appenders[i]->getLogLevel());
00144 #else
00145       rv = std::max(rv, appenders[i]->getLogLevel());
00146 #endif
00147    }
00148    return rv;
00149 }
00150 
00151 } // end namespace BLOCXX_NAMESPACE
00152 
00153 
00154 
00155 
00156 
00157 

Generated on Fri Jun 16 15:39:08 2006 for blocxx by  doxygen 1.4.6