ResourcePoolStreamLogger.hh

00001 //********************************************************************
00002 //*** ResourcePool/ResourcePoolStreamLogger.hh
00003 //*** Copyright (c) 2003-2009 by Markus Winand <mws@fatalmind.com>
00004 //*** $Id: ResourcePoolStreamLogger.hh,v 1.6 2009-03-02 14:16:44 mws Exp $
00005 //********************************************************************
00006 /*
00007 This file is part of ResourcePool.
00008 
00009 ResourcePool is free software; you can redistribute it
00010 and/or modify it under the terms of the GNU General Public License
00011 as published by the Free Software Foundation; either version 2 of 
00012 the License, or (at your option) any later version.
00013 
00014 ResourcePool is distributed in the hope that it will be
00015 useful, but WITHOUT ANY WARRANTY; without even the implied warranty
00016 of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00017 GNU General Public License for more details.
00018 
00019 You should have received a copy of the GNU General Public License
00020 along with ResourcePool; if not, write to the Free Software
00021 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
00022 02111-1307  USA */
00023 
00024 #ifndef RESOURCEPOOL_STREAMLOGGER_HH
00025 #define RESOURCEPOOL_STREAMLOGGER_HH
00026 
00027 #include <iostream>
00028 #include <time.h>
00029 
00030 #include "POSIX/sys/timeval.hh"
00031 #include "ResourcePool/ResourcePoolEventObserver.hh"
00032 
00033 namespace fatalmind {
00034 
00043 class ResourcePoolStreamLogger: public ResourcePoolEventObserver {
00044     public:
00045         ResourcePoolStreamLogger(std::ostream& a_os) 
00046         : ResourcePoolEventObserver()
00047         , os(a_os)
00048         {
00049         }
00050 
00051         virtual void event(event_t eventID, const std::string& resourceID = NoResourceID, const std::string& message = "N/A") {
00052             if ((logevents & eventID) != 0) {
00053                 if (logevents & Event.TIME_HIRES) {
00054                     ::POSIX::timeval t;
00055                     struct timezone tz;
00056                     gettimeofday(&t, &tz);
00057                     os << t << ";" << getEventName(eventID) << ';' <<  resourceID << ';' << message << std::endl;
00058                 } else {
00059                     os << time(NULL) << ";" << getEventName(eventID) << ';' <<  resourceID << ';' << message << std::endl;
00060                 }
00061             }
00062         };
00063 
00064         static ResourcePoolStreamLogger defaultLogger;
00065 
00066     protected:
00067         virtual Clone* DoClone() const {
00068             return new ResourcePoolStreamLogger(*this);
00069         }
00070     private:
00071         std::ostream& os;
00072 };
00073 
00074 } // namespace fatalmind
00075 #endif

Generated on Mon Nov 9 16:21:24 2009 for ResourcePool by  doxygen 1.5.3