You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							79 lines
						
					
					
						
							2.1 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							79 lines
						
					
					
						
							2.1 KiB
						
					
					
				| // -*- C++ -*- | |
| // Module:  Log4CPLUS | |
| // File:    tracelogger.h | |
| // Created: 1/2009 | |
| // Author:  Vaclav Haisman | |
| // | |
| // | |
| // Copyright 2009-2010 Tad E. Smith | |
| // | |
| // Licensed under the Apache License, Version 2.0 (the "License"); | |
| // you may not use this file except in compliance with the License. | |
| // You may obtain a copy of the License at | |
| // | |
| //     http://www.apache.org/licenses/LICENSE-2.0 | |
| // | |
| // Unless required by applicable law or agreed to in writing, software | |
| // distributed under the License is distributed on an "AS IS" BASIS, | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| // See the License for the specific language governing permissions and | |
| // limitations under the License. | |
|  | |
| /** @file */ | |
| 
 | |
| #ifndef LOG4CPLUS_TRACELOGGER_H | |
| #define LOG4CPLUS_TRACELOGGER_H | |
|  | |
| #include <log4cplus/config.hxx> | |
|  | |
| #if defined (LOG4CPLUS_HAVE_PRAGMA_ONCE) | |
| #pragma once | |
| #endif | |
|  | |
| #include <log4cplus/logger.h> | |
|  | |
| 
 | |
| namespace log4cplus | |
| { | |
| 
 | |
| 
 | |
| /** | |
|  * This class is used to produce "Trace" logging.  When an instance of | |
|  * this class is created, it will log a <code>"ENTER: " + msg</code> | |
|  * log message if TRACE_LOG_LEVEL is enabled for <code>logger</code>. | |
|  * When an instance of this class is destroyed, it will log a | |
|  * <code>"ENTER: " + msg</code> log message if TRACE_LOG_LEVEL is enabled | |
|  * for <code>logger</code>. | |
|  * <p> | |
|  * @see LOG4CPLUS_TRACE | |
|  */ | |
| class TraceLogger | |
| { | |
| public: | |
|     TraceLogger(const Logger& l, const log4cplus::tstring& _msg, | |
|                 const char* _file=NULL, int _line=-1)  | |
|       : logger(l), msg(_msg), file(_file), line(_line) | |
|     { if(logger.isEnabledFor(TRACE_LOG_LEVEL)) | |
|           logger.forcedLog(TRACE_LOG_LEVEL, LOG4CPLUS_TEXT("ENTER: ") + msg, file, line);  | |
|     } | |
| 
 | |
|     ~TraceLogger() | |
|     { if(logger.isEnabledFor(TRACE_LOG_LEVEL)) | |
|           logger.forcedLog(TRACE_LOG_LEVEL, LOG4CPLUS_TEXT("EXIT:  ") + msg, file, line);  | |
|     } | |
| 
 | |
| private: | |
|     TraceLogger (TraceLogger const &); | |
|     TraceLogger & operator = (TraceLogger const &); | |
| 
 | |
|     Logger logger; | |
|     log4cplus::tstring msg; | |
|     const char* file; | |
|     int line; | |
| }; | |
| 
 | |
| 
 | |
| } // log4cplus | |
|  | |
| 
 | |
| #endif // LOG4CPLUS_TRACELOGGER_H
 |