• Classes
  • Modules
  • Namespaces
  • Files
  • Related Pages
  • File List
  • File Members

loggingStopWatch.h

Go to the documentation of this file.
00001 #ifndef _logging_StopWatch_H_
00002 #define _logging_StopWatch_H_
00003 /*******************************************************************************
00004 * ALMA - Atacama Large Millimiter Array
00005 * Copyright (c) European Southern Observatory, 2014 
00006 * 
00007 * This library is free software; you can redistribute it and/or
00008 * modify it under the terms of the GNU Lesser General Public
00009 * License as published by the Free Software Foundation; either
00010 * version 2.1 of the License, or (at your option) any later version.
00011 * 
00012 * This library is distributed in the hope that it will be useful,
00013 * but WITHOUT ANY WARRANTY; without even the implied warranty of
00014 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00015 * Lesser General Public License for more details.
00016 * 
00017 * You should have received a copy of the GNU Lesser General Public
00018 * License along with this library; if not, write to the Free Software
00019 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307  USA
00020 *
00021 *
00022 * who       when      what
00023 * --------  --------  ----------------------------------------------
00024 * bjeram  2014-05-19  created
00025 */
00026 
00027 /************************************************************************
00028  *
00029  *----------------------------------------------------------------------
00030 
00031  */
00032 
00033 #ifndef __cplusplus
00034 #error This is a C++ include file and cannot be used from plain C
00035 #endif
00036 
00037 #include "loggingLogTrace.h"
00038 
00039 namespace Logging
00040 {
00042 
00049 class StopWatch
00050 {
00051 public:
00053                 typedef Loki::SmartPtr<StopWatch,
00054                                        Loki::NoCopy,
00055                                        Loki::DisallowConversion,
00056                                        Loki::RejectNull,
00057                                        Loki::DefaultSPStorage> StopWatchSmartPtr;
00058 
00059 
00060         StopWatch(Logger::LoggerSmartPtr logger,
00061                         const std::string &file,
00062                         unsigned long line,
00063                         const  std::string &msg,
00064                         double maxTime=0.0);
00065 
00066         ~StopWatch();
00067 protected:
00068         Logger::LoggerSmartPtr logger_m;
00069 
00070         std::string msg_m;
00071         //std::string methodName_m;
00072         std::string fileName_m;
00073         unsigned long lineNumber_m;
00074 
00075         //if elapsed time exceed maxTime_m there is a warning message
00076         double maxTime_m;
00077 
00078         ACE_Time_Value startTime_m;
00079         ACE_Time_Value endTime_m;
00080 };//StopWatch
00081 
00082 };
00083 
00084 #endif 

Generated on Mon May 4 2015 08:27:43 for ACS-2015.4 C++ API by  doxygen 1.7.0