// 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 "dcmtk/oflog/config.h" #if defined (DCMTK_LOG4CPLUS_HAVE_OUTPUTDEBUGSTRING) #include "dcmtk/oflog/config/windowsh.h" #include "dcmtk/oflog/windebap.h" #include "dcmtk/oflog/internal/internal.h" #include "dcmtk/oflog/thread/syncpub.h" namespace dcmtk { namespace log4cplus { /////////////////////////////////////////////////////////////////////////////// // Win32DebugAppender ctors and dtor /////////////////////////////////////////////////////////////////////////////// Win32DebugAppender::Win32DebugAppender() { } Win32DebugAppender::Win32DebugAppender( const helpers::Properties& properties) : Appender(properties) { } Win32DebugAppender::~Win32DebugAppender() { destructorImpl(); } /////////////////////////////////////////////////////////////////////////////// // Win32DebugAppender public methods /////////////////////////////////////////////////////////////////////////////// void Win32DebugAppender::close() { closed = true; } /////////////////////////////////////////////////////////////////////////////// // Win32DebugAppender protected methods /////////////////////////////////////////////////////////////////////////////// // This method does not need to be locked since it is called by // doAppend() which performs the locking void Win32DebugAppender::append(const spi::InternalLoggingEvent& event) { const tchar * s = formatEvent (event).c_str(); #if defined (DCMTK_OFLOG_UNICODE) ::OutputDebugString(s); #else ::OutputDebugStringA(s); #endif } } // namespace log4cplus } // end namespace dcmtk #endif // DCMTK_LOG4CPLUS_HAVE_OUTPUTDEBUGSTRING