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
							 |