00001 /* 00002 Copyright 2007, 2008, 2009, 2010, 2011 Instituto de Sistemas e Robotica, Instituto Superior Tecnico 00003 00004 This file is part of MeRMaID. 00005 00006 MeRMaID is free software: you can redistribute it and/or modify 00007 it under the terms of the GNU Lesser General Public License as published by 00008 the Free Software Foundation, either version 3 of the License, or 00009 (at your option) any later version. 00010 00011 MeRMaID is distributed in the hope that it will be useful, 00012 but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00014 GNU Lesser General Public License for more details. 00015 00016 You should have received a copy of the GNU Lesser General Public License 00017 along with MeRMaID. If not, see <http://www.gnu.org/licenses/>. 00018 */ 00019 00020 00021 00022 /** 00023 * @Filename ThreadSafeOutput.cpp 00024 * @Description ThreadSafeOutput implementation 00025 * @Status Finished 00026 * @Version $Id: ThreadSafeOutput.cpp 1 2011-03-04 18:13:18Z jreis $ 00027 * @Maintainer Joao Reis (joaocgreis@gmail.com) 00028 */ 00029 00030 #include "config.h" 00031 00032 #include "Logger.hpp" 00033 00034 #include <iostream> 00035 00036 using namespace mermaid::support::logging; 00037 00038 using std::cerr; 00039 00040 ThreadSafeOutput::ThreadSafeOutput (shared_ptr<LogOutput> output) : 00041 mutex_(), 00042 output_ (output) 00043 { 00044 } 00045 00046 shared_ptr<ThreadSafeOutput> ThreadSafeOutput::build (shared_ptr<LogOutput> output) 00047 { 00048 return shared_ptr<ThreadSafeOutput> (new ThreadSafeOutput (output)); 00049 } 00050 00051 void ThreadSafeOutput::outputMessage (const LogMessage& logMessage) 00052 { 00053 ACE_Guard<ACE_Mutex> guard (mutex_); 00054 output_->outputMessage (logMessage); 00055 }