gremlin/libs/log4cplus/src/win32debugappender.cxx

87 lines
2.2 KiB
C++

// Module: Log4CPLUS
// File: win32debugappender.cxx
// Created: 12/2003
// Author: Eduardo Francos, Odalio SARL
//
//
// Copyright 2003-2010 Odalio SARL
//
// 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/win32debugappender.h>
#if defined (LOG4CPLUS_HAVE_OUTPUTDEBUGSTRING)
using namespace std;
using namespace log4cplus;
using namespace log4cplus::helpers;
///////////////////////////////////////////////////////////////////////////////
// log4cplus::Win32DebugAppender ctors and dtor
///////////////////////////////////////////////////////////////////////////////
log4cplus::Win32DebugAppender::Win32DebugAppender()
{
}
log4cplus::Win32DebugAppender::Win32DebugAppender(
const log4cplus::helpers::Properties& properties)
: Appender(properties)
{
}
log4cplus::Win32DebugAppender::~Win32DebugAppender()
{
destructorImpl();
}
///////////////////////////////////////////////////////////////////////////////
// log4cplus::Win32DebugAppender public methods
///////////////////////////////////////////////////////////////////////////////
void
log4cplus::Win32DebugAppender::close()
{
closed = true;
}
///////////////////////////////////////////////////////////////////////////////
// log4cplus::Win32DebugAppender protected methods
///////////////////////////////////////////////////////////////////////////////
// This method does not need to be locked since it is called by
// doAppend() which performs the locking
void
log4cplus::Win32DebugAppender::append(const spi::InternalLoggingEvent& event)
{
tostringstream buf;
layout->formatAndAppend(buf, event);
tstring sz = buf.str();
const tchar * s = sz.c_str();
::OutputDebugString(s);
}
#endif // LOG4CPLUS_HAVE_OUTPUTDEBUGSTRING