1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski #ifndef __FRAMEWORK_MACROS_DEBUG_LOGMECHANISM_HXX_
25*b1cdbd2cSJim Jagielski #define __FRAMEWORK_MACROS_DEBUG_LOGMECHANISM_HXX_
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski //*****************************************************************************************************************
28*b1cdbd2cSJim Jagielski //	generic macros for logging
29*b1cdbd2cSJim Jagielski //*****************************************************************************************************************
30*b1cdbd2cSJim Jagielski 
31*b1cdbd2cSJim Jagielski #ifdef	ENABLE_LOGMECHANISM
32*b1cdbd2cSJim Jagielski 
33*b1cdbd2cSJim Jagielski 	//_____________________________________________________________________________________________________________
34*b1cdbd2cSJim Jagielski 	//	includes
35*b1cdbd2cSJim Jagielski 	//_____________________________________________________________________________________________________________
36*b1cdbd2cSJim Jagielski 
37*b1cdbd2cSJim Jagielski 	#ifndef _RTL_STRING_HXX_
38*b1cdbd2cSJim Jagielski 	#include <rtl/string.hxx>
39*b1cdbd2cSJim Jagielski 	#endif
40*b1cdbd2cSJim Jagielski 
41*b1cdbd2cSJim Jagielski 	#include <stdio.h>
42*b1cdbd2cSJim Jagielski 
43*b1cdbd2cSJim Jagielski 	/*_____________________________________________________________________________________________________________
44*b1cdbd2cSJim Jagielski 		WRITE_LOGFILE( SFILENAME, STEXT )
45*b1cdbd2cSJim Jagielski 
46*b1cdbd2cSJim Jagielski 		Log any information in file. We append any information at file and don't clear it anymore.
47*b1cdbd2cSJim Jagielski 		( Use new scope in macro to declare pFile more then on time in same "parentscope"!
48*b1cdbd2cSJim Jagielski 	  	  Don't control pFile before access! What will you doing if its not valid? Log an error ...
49*b1cdbd2cSJim Jagielski   	  	  An error and an error is an error ... )
50*b1cdbd2cSJim Jagielski 
51*b1cdbd2cSJim Jagielski         Attention:  You must use "%s" and STEXT as parameter ... because otherwise encoded strings (they include e.g. %...)
52*b1cdbd2cSJim Jagielski                     are handled wrong.
53*b1cdbd2cSJim Jagielski 	_____________________________________________________________________________________________________________*/
54*b1cdbd2cSJim Jagielski 
writeToLogFile(const char * SFILENAME,const char * STEXT)55*b1cdbd2cSJim Jagielski 	inline void writeToLogFile( const char* SFILENAME, const char* STEXT )
56*b1cdbd2cSJim Jagielski 				{																								\
57*b1cdbd2cSJim Jagielski 					::rtl::OString	_swriteLogfileFileName	( SFILENAME	);										\
58*b1cdbd2cSJim Jagielski 					::rtl::OString	_swriteLogfileText		( STEXT		);										\
59*b1cdbd2cSJim Jagielski 					FILE* pFile = fopen( _swriteLogfileFileName.getStr(), "a" );								\
60*b1cdbd2cSJim Jagielski                     fprintf( pFile, "%s", _swriteLogfileText.getStr() );                                        \
61*b1cdbd2cSJim Jagielski                     fclose ( pFile                                    );                                        \
62*b1cdbd2cSJim Jagielski 				}
63*b1cdbd2cSJim Jagielski 
writeToLogFile(const char * pFILENAME,const rtl::OString & rTEXT)64*b1cdbd2cSJim Jagielski 	inline void writeToLogFile( const char* pFILENAME, const rtl::OString& rTEXT ) { writeToLogFile( pFILENAME, rTEXT.getStr()); }
65*b1cdbd2cSJim Jagielski 
66*b1cdbd2cSJim Jagielski 	#define WRITE_LOGFILE( SFILENAME, STEXT ) { writeToLogFile( (SFILENAME), (STEXT) ); }
67*b1cdbd2cSJim Jagielski 
68*b1cdbd2cSJim Jagielski 	/*_____________________________________________________________________________________________________________
69*b1cdbd2cSJim Jagielski 		LOGTYPE
70*b1cdbd2cSJim Jagielski 
71*b1cdbd2cSJim Jagielski 		For other debug macros we need information about the output mode. If user forget to set this information we
72*b1cdbd2cSJim Jagielski 		do it for him. Valid values are:	LOGTYPE_FILECONTINUE
73*b1cdbd2cSJim Jagielski 											LOGTYPE_FILEEXIT
74*b1cdbd2cSJim Jagielski 											LOGTYPE_MESSAGEBOX
75*b1cdbd2cSJim Jagielski 		The normal case is LOGTYPE_MESSAGEBOX to show assertions in normal manner!
76*b1cdbd2cSJim Jagielski 	_____________________________________________________________________________________________________________*/
77*b1cdbd2cSJim Jagielski 
78*b1cdbd2cSJim Jagielski 	#define	LOGTYPE_MESSAGEBOX		1
79*b1cdbd2cSJim Jagielski 	#define	LOGTYPE_FILECONTINUE	2
80*b1cdbd2cSJim Jagielski 	#define	LOGTYPE_FILEEXIT		3
81*b1cdbd2cSJim Jagielski 
82*b1cdbd2cSJim Jagielski 	#ifndef	LOGTYPE
83*b1cdbd2cSJim Jagielski 		#define	LOGTYPE																							\
84*b1cdbd2cSJim Jagielski 					LOGTYPE_MESSAGEBOX
85*b1cdbd2cSJim Jagielski 	#endif
86*b1cdbd2cSJim Jagielski 
87*b1cdbd2cSJim Jagielski #else	// #ifdef ENABLE_LOGMECHANISM
88*b1cdbd2cSJim Jagielski 
89*b1cdbd2cSJim Jagielski 	/*_____________________________________________________________________________________________________________
90*b1cdbd2cSJim Jagielski 		If right testmode is'nt set - implements these macro empty!
91*b1cdbd2cSJim Jagielski 	_____________________________________________________________________________________________________________*/
92*b1cdbd2cSJim Jagielski 
93*b1cdbd2cSJim Jagielski 	#define	WRITE_LOGFILE( SFILENAME, STEXT )
94*b1cdbd2cSJim Jagielski 	#undef	LOGTYPE
95*b1cdbd2cSJim Jagielski 
96*b1cdbd2cSJim Jagielski #endif	// #ifdef ENABLE_LOGMECHANISM
97*b1cdbd2cSJim Jagielski 
98*b1cdbd2cSJim Jagielski //*****************************************************************************************************************
99*b1cdbd2cSJim Jagielski //	end of file
100*b1cdbd2cSJim Jagielski //*****************************************************************************************************************
101*b1cdbd2cSJim Jagielski 
102*b1cdbd2cSJim Jagielski #endif	// #ifndef __FRAMEWORK_MACROS_DEBUG_LOGMECHANISM_HXX_
103