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

loggingLogTrace.h

Go to the documentation of this file.
00001 #ifndef logging_log_trace_H
00002 #define logging_log_trace_H
00003 /*******************************************************************************
00004 * ALMA - Atacama Large Millimiter Array
00005 * (c) Associated Universities Inc., 2005 
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 * "@(#) $Id: loggingLogTrace.h,v 1.5 2011/09/14 11:31:09 bjeram Exp $"
00022 *
00023 * who       when      what
00024 * --------  --------  ----------------------------------------------
00025 * dfugate  2005-03-09  created
00026 */
00027 
00032 #ifndef __cplusplus
00033 #error This is a C++ include file and cannot be used from plain C
00034 #endif
00035 
00036 #include <string>
00037 #include "loggingLogger.h"
00038 #include <OS_NS_time.h>
00039 
00040 namespace Logging 
00041 {
00042     //------------------------------------------------------------------------------
00046     class LogTrace
00047     {
00048       public:
00050         typedef Loki::SmartPtr<LogTrace, 
00051                                Loki::NoCopy, 
00052                                Loki::DisallowConversion,
00053                                Loki::RejectNull,
00054                                Loki::DefaultSPStorage> LogTraceSmartPtr;
00055 
00063         LogTrace(Logger::LoggerSmartPtr logger,
00064                  const std::string &method,
00065                  const std::string &file,
00066                  unsigned long line);
00067 
00073         LogTrace(Logger::LoggerSmartPtr logger,
00074                  const std::string &method);
00075         
00079         virtual 
00080         ~LogTrace();
00081 
00082       protected:
00083         
00091         virtual void
00092         entryLog(Logger::LoggerSmartPtr logger,
00093                  std::string method,
00094                  std::string file,
00095                  unsigned long line);
00096 
00097       private:
00099         Logger::LoggerSmartPtr logger_m;
00100 
00102         std::string methodName_m;
00103 
00104         //file name saved for destructor use
00105         std::string fileName_m;
00106 
00107         //line number saved for destructor use
00108         unsigned long lineNumber_m;
00109 
00110         ACE_Time_Value start_time;
00111         ACE_Time_Value end_time;
00112     };
00113     //------------------------------------------------------------------------------
00114 };
00115 
00116 #endif 

Generated on Thu Jan 12 2012 23:13:51 for ACS-10.0 C++ API by  doxygen 1.7.0