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