ThreadSafeOutput.cpp

Go to the documentation of this file.
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 }
Generated on Fri Mar 4 22:14:58 2011 for MeRMaID::support by  doxygen 1.6.3