102 lines
3.1 KiB
C++
102 lines
3.1 KiB
C++
// Module: Log4CPLUS
|
|
// File: consoleappender.cxx
|
|
// Created: 6/2001
|
|
// Author: Tad E. Smith
|
|
//
|
|
//
|
|
// Copyright 2001-2009 Tad E. Smith
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
#include <log4cplus/layout.h>
|
|
#include <log4cplus/consoleappender.h>
|
|
#include <log4cplus/streams.h>
|
|
#include <log4cplus/helpers/loglog.h>
|
|
#include <log4cplus/helpers/stringhelper.h>
|
|
#include <log4cplus/spi/loggingevent.h>
|
|
|
|
using namespace std;
|
|
using namespace log4cplus::helpers;
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
// log4cplus::ConsoleAppender ctors and dtor
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
log4cplus::ConsoleAppender::ConsoleAppender(bool logToStdErr_, bool immediateFlush_)
|
|
: logToStdErr(logToStdErr_),
|
|
immediateFlush(immediateFlush_)
|
|
{
|
|
}
|
|
|
|
|
|
|
|
log4cplus::ConsoleAppender::ConsoleAppender(const log4cplus::helpers::Properties properties)
|
|
: Appender(properties),
|
|
logToStdErr(false),
|
|
immediateFlush(false)
|
|
{
|
|
tstring val = toLower(properties.getProperty(LOG4CPLUS_TEXT("logToStdErr")));
|
|
if(val == LOG4CPLUS_TEXT("true")) {
|
|
logToStdErr = true;
|
|
}
|
|
if(properties.exists( LOG4CPLUS_TEXT("ImmediateFlush") )) {
|
|
tstring tmp = properties.getProperty( LOG4CPLUS_TEXT("ImmediateFlush") );
|
|
immediateFlush = (toLower(tmp) == LOG4CPLUS_TEXT("true"));
|
|
}
|
|
}
|
|
|
|
|
|
|
|
log4cplus::ConsoleAppender::~ConsoleAppender()
|
|
{
|
|
destructorImpl();
|
|
}
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
// log4cplus::ConsoleAppender public methods
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
void
|
|
log4cplus::ConsoleAppender::close()
|
|
{
|
|
getLogLog().debug(LOG4CPLUS_TEXT("Entering ConsoleAppender::close().."));
|
|
closed = true;
|
|
}
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
// log4cplus::ConsoleAppender protected methods
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Normally, append() methods do not need to be locked since they are
|
|
// called by doAppend() which performs the locking. However, this locks
|
|
// on the LogLog instance, so we don't have multiple threads writing to
|
|
// tcout and tcerr
|
|
void
|
|
log4cplus::ConsoleAppender::append(const spi::InternalLoggingEvent& event)
|
|
{
|
|
LOG4CPLUS_BEGIN_SYNCHRONIZE_ON_MUTEX( getLogLog().mutex )
|
|
log4cplus::tostream& output = (logToStdErr ? tcerr : tcout);
|
|
layout->formatAndAppend(output, event);
|
|
if(immediateFlush) {
|
|
output.flush();
|
|
}
|
|
LOG4CPLUS_END_SYNCHRONIZE_ON_MUTEX;
|
|
}
|
|
|
|
|