Main Page | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | File List | Namespace Members | Class Members | File Members

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::doProcessLogMessage(
00076    const LogMessage& message) const
00077 {
00078    for (size_t i = 0; i < m_appenders.size(); ++i)
00079    {
00080       m_appenders[i]->logMessage(message);
00081    }
00082 }
00083 
00085 bool
00086 AppenderLogger::doComponentAndCategoryAreEnabled(
00087    const String& component, 
00088    const String& category) const
00089 {
00090    for (size_t i = 0; i < m_appenders.size(); ++i)
00091    {
00092       if (m_appenders[i]->componentAndCategoryAreEnabled(component, category))
00093       {
00094          return true;
00095       }
00096    }
00097    return false;
00098 }
00099 
00101 bool
00102 AppenderLogger::doCategoryIsEnabled(
00103    const String& category) const
00104 {
00105    for (size_t i = 0; i < m_appenders.size(); ++i)
00106    {
00107       if (m_appenders[i]->categoryIsEnabled(category))
00108       {
00109          return true;
00110       }
00111    }
00112    return false;
00113 }
00114 
00116 LoggerRef
00117 AppenderLogger::doClone() const
00118 {
00119    return LoggerRef(new AppenderLogger(*this));
00120 }
00121 
00123 #ifdef BLOCXX_WIN32
00124 using namespace std;
00125 #endif
00126 
00127 ELogLevel
00128 AppenderLogger::getLevel(
00129    const Array<LogAppenderRef>& appenders)
00130 {
00131    ELogLevel rv = E_FATAL_ERROR_LEVEL;
00132    for (size_t i = 0; i < appenders.size(); ++i)
00133    {
00134 #ifdef BLOCXX_WIN32
00135       // This format was necessary on windoz C2589
00136       rv = max(rv, appenders[i]->getLogLevel());
00137 #else
00138       rv = std::max(rv, appenders[i]->getLogLevel());
00139 #endif
00140    }
00141    return rv;
00142 }
00143 
00144 } // end namespace BLOCXX_NAMESPACE
00145 
00146 
00147 
00148 
00149 
00150 

Generated on Mon Sep 12 23:56:33 2005 for blocxx by  doxygen 1.4.4