1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir #ifndef __FRAMEWORK_MACROS_DEBUG_TARGETING_HXX_
29*cdf0e10cSrcweir #define __FRAMEWORK_MACROS_DEBUG_TARGETING_HXX_
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir //*****************************************************************************************************************
32*cdf0e10cSrcweir //	special macros for targeting of frames
33*cdf0e10cSrcweir //*****************************************************************************************************************
34*cdf0e10cSrcweir 
35*cdf0e10cSrcweir #ifdef	ENABLE_TARGETINGDEBUG
36*cdf0e10cSrcweir 
37*cdf0e10cSrcweir 	//_____________________________________________________________________________________________________________
38*cdf0e10cSrcweir 	//	includes
39*cdf0e10cSrcweir 	//_____________________________________________________________________________________________________________
40*cdf0e10cSrcweir 
41*cdf0e10cSrcweir 	#ifndef _RTL_STRBUF_HXX_
42*cdf0e10cSrcweir 	#include <rtl/strbuf.hxx>
43*cdf0e10cSrcweir 	#endif
44*cdf0e10cSrcweir 
45*cdf0e10cSrcweir 	/*_____________________________________________________________________________________________________________
46*cdf0e10cSrcweir 		LOGFILE_TARGETING
47*cdf0e10cSrcweir 
48*cdf0e10cSrcweir 		For follow macros we need a special log file. If user forget to specify anyone, we must do it for him!
49*cdf0e10cSrcweir 	_____________________________________________________________________________________________________________*/
50*cdf0e10cSrcweir 
51*cdf0e10cSrcweir 	#ifndef	LOGFILE_TARGETING
52*cdf0e10cSrcweir 		#define	LOGFILE_TARGETSTEPS		"targetsteps.log"
53*cdf0e10cSrcweir 		#define	LOGFILE_TARGETPARAM		"targetparam.log"
54*cdf0e10cSrcweir 	#endif
55*cdf0e10cSrcweir 
56*cdf0e10cSrcweir 	/*_____________________________________________________________________________________________________________
57*cdf0e10cSrcweir 		LOG_PARAMETER_FINDFRAME( SSERVICE, SFRAMENAME, STARGETNAME, NSEARCHFLAGS )
58*cdf0e10cSrcweir 
59*cdf0e10cSrcweir 		Log format for parameter e.g.: Desktop::findFrame( "frame1", 23 ) my name is "desktop"
60*cdf0e10cSrcweir 		Log format for steps     e.g.: desktop--
61*cdf0e10cSrcweir 
62*cdf0e10cSrcweir 		With this macro you can log informations about search parameter of method "findFrame()" of an service.
63*cdf0e10cSrcweir 		Use it at beginning of search only!
64*cdf0e10cSrcweir 	_____________________________________________________________________________________________________________*/
65*cdf0e10cSrcweir 
66*cdf0e10cSrcweir 	#define	LOG_PARAMETER_FINDFRAME( SSERVICE, SFRAMENAME, STARGETNAME, NSEARCHFLAGS )							\
67*cdf0e10cSrcweir 				/* Use new scope to prevent code against multiple variable defines! */							\
68*cdf0e10cSrcweir 				{																								\
69*cdf0e10cSrcweir 					::rtl::OStringBuffer sBufferParam(256);														\
70*cdf0e10cSrcweir 					::rtl::OStringBuffer sBufferSteps(256);														\
71*cdf0e10cSrcweir 					sBufferParam.append( SSERVICE												);				\
72*cdf0e10cSrcweir 					sBufferParam.append( "::findFrame( \""										);				\
73*cdf0e10cSrcweir 					sBufferParam.append( U2B( STARGETNAME )										);				\
74*cdf0e10cSrcweir 					sBufferParam.append( "\", "													);				\
75*cdf0e10cSrcweir 					sBufferParam.append( ::rtl::OString::valueOf( sal_Int32( NSEARCHFLAGS ) )	);				\
76*cdf0e10cSrcweir 					sBufferParam.append( " ) my name is \""										);				\
77*cdf0e10cSrcweir 					sBufferParam.append( U2B( SFRAMENAME )										);				\
78*cdf0e10cSrcweir 					sBufferParam.append( "\"\n"													);				\
79*cdf0e10cSrcweir 					sBufferSteps.append( U2B( SFRAMENAME )										);				\
80*cdf0e10cSrcweir 					sBufferSteps.append( "--"													);				\
81*cdf0e10cSrcweir 					WRITE_LOGFILE( LOGFILE_TARGETPARAM, sBufferParam.makeStringAndClear() )						\
82*cdf0e10cSrcweir 					WRITE_LOGFILE( LOGFILE_TARGETSTEPS, sBufferSteps.makeStringAndClear() )						\
83*cdf0e10cSrcweir 				}
84*cdf0e10cSrcweir 
85*cdf0e10cSrcweir 	/*_____________________________________________________________________________________________________________
86*cdf0e10cSrcweir 		LOG_PARAMETER_QUERYDISPATCH( SSERVICE, SFRAMENAME, AURL, STARGETNAME, NSEARCHFLAGS )
87*cdf0e10cSrcweir 
88*cdf0e10cSrcweir 		With this macro you can log informations about search parameter of method "queryDispatch()" of an service.
89*cdf0e10cSrcweir 		Use it at beginning of search only!
90*cdf0e10cSrcweir 	_____________________________________________________________________________________________________________*/
91*cdf0e10cSrcweir 
92*cdf0e10cSrcweir 	#define	LOG_PARAMETER_QUERYDISPATCH( SSERVICE, SFRAMENAME, AURL, STARGETNAME, NSEARCHFLAGS )						\
93*cdf0e10cSrcweir 				/* Use new scope to prevent code against multiple variable defines! */									\
94*cdf0e10cSrcweir 				{																										\
95*cdf0e10cSrcweir 					::rtl::OStringBuffer sBuffer(1024);																	\
96*cdf0e10cSrcweir 					sBuffer.append( "[ "													);							\
97*cdf0e10cSrcweir 					sBuffer.append( U2B( SFRAMENAME )										);							\
98*cdf0e10cSrcweir 					sBuffer.append( "] "													);							\
99*cdf0e10cSrcweir 					sBuffer.append( SSERVICE												);							\
100*cdf0e10cSrcweir 					sBuffer.append( "::queryDispatch( \""									);							\
101*cdf0e10cSrcweir 					sBuffer.append( U2B( AURL.Complete )									);							\
102*cdf0e10cSrcweir 					sBuffer.append( "\", \""												);							\
103*cdf0e10cSrcweir 					sBuffer.append( U2B( STARGETNAME )										);							\
104*cdf0e10cSrcweir 					sBuffer.append( "\", "													);							\
105*cdf0e10cSrcweir 					sBuffer.append( ::rtl::OString::valueOf( sal_Int32( NSEARCHFLAGS ) )	);							\
106*cdf0e10cSrcweir 					sBuffer.append( " )\n"													);							\
107*cdf0e10cSrcweir 					WRITE_LOGFILE( LOGFILE_TARGETPARAM, sBuffer.makeStringAndClear() )									\
108*cdf0e10cSrcweir 				}
109*cdf0e10cSrcweir 
110*cdf0e10cSrcweir 	/*_____________________________________________________________________________________________________________
111*cdf0e10cSrcweir 		LOG_PARAMETER_LOADCOMPONENTFROMURL( SSERVICE, SFRAMENAME, SURL, STARGETNAME, NSEARCHFLAGS, SEQPARAMETER )
112*cdf0e10cSrcweir 
113*cdf0e10cSrcweir 		With this macro you can log informations about search parameter of method "loadComponentFromURL()" of an service.
114*cdf0e10cSrcweir 		Use it at beginning of search only!
115*cdf0e10cSrcweir 	_____________________________________________________________________________________________________________*/
116*cdf0e10cSrcweir 
117*cdf0e10cSrcweir 	#define	LOG_PARAMETER_LOADCOMPONENTFROMURL( SSERVICE, SFRAMENAME, SURL, STARGETNAME, NSEARCHFLAGS, SEQPARAMETER )	\
118*cdf0e10cSrcweir 				/* Use new scope to prevent code against multiple variable defines! */									\
119*cdf0e10cSrcweir 				{																										\
120*cdf0e10cSrcweir 					::rtl::OStringBuffer sBuffer(1024);																	\
121*cdf0e10cSrcweir 					sBuffer.append( "[ "													);							\
122*cdf0e10cSrcweir 					sBuffer.append( U2B( SFRAMENAME )										);							\
123*cdf0e10cSrcweir 					sBuffer.append( "] "													);							\
124*cdf0e10cSrcweir 					sBuffer.append( SSERVICE												);							\
125*cdf0e10cSrcweir 					sBuffer.append( "::loadComponentFromURL( \""							);							\
126*cdf0e10cSrcweir 					sBuffer.append( U2B( SURL )												);							\
127*cdf0e10cSrcweir 					sBuffer.append( "\", \""												);							\
128*cdf0e10cSrcweir 					sBuffer.append( U2B( STARGETNAME )										);							\
129*cdf0e10cSrcweir 					sBuffer.append( "\", "													);							\
130*cdf0e10cSrcweir 					sBuffer.append( ::rtl::OString::valueOf( sal_Int32( NSEARCHFLAGS ) )	);							\
131*cdf0e10cSrcweir 					sBuffer.append( ", "													);							\
132*cdf0e10cSrcweir 					sal_Int32 nCount = SEQPARAMETER.getLength();														\
133*cdf0e10cSrcweir 					for( sal_Int32 nParameter=0; nParameter<nCount; ++nParameter )										\
134*cdf0e10cSrcweir 					{																									\
135*cdf0e10cSrcweir 						sBuffer.append( U2B( SEQPARAMETER[nParameter].Name ));											\
136*cdf0e10cSrcweir 						if( nParameter<(nCount-1) )																		\
137*cdf0e10cSrcweir 						{																								\
138*cdf0e10cSrcweir 							sBuffer.append( " | " );																	\
139*cdf0e10cSrcweir 						}																								\
140*cdf0e10cSrcweir 					}																									\
141*cdf0e10cSrcweir 					sBuffer.append( " )\n"													);							\
142*cdf0e10cSrcweir 					WRITE_LOGFILE( LOGFILE_TARGETPARAM, sBuffer.makeStringAndClear() )									\
143*cdf0e10cSrcweir 				}
144*cdf0e10cSrcweir 
145*cdf0e10cSrcweir 	/*_____________________________________________________________________________________________________________
146*cdf0e10cSrcweir 		LOG_RESULT_FINDFRAME( SSERVICE, SFRAMENAME, XFRAME )
147*cdf0e10cSrcweir 
148*cdf0e10cSrcweir 		With this macro you can log informations about search result of "findFrame()".
149*cdf0e10cSrcweir 		Use it at the end of this method only!
150*cdf0e10cSrcweir 	_____________________________________________________________________________________________________________*/
151*cdf0e10cSrcweir 
152*cdf0e10cSrcweir 	#define	LOG_RESULT_FINDFRAME( SSERVICE, SFRAMENAME, XFRAME )														\
153*cdf0e10cSrcweir 				/* Use new scope to prevent code against multiple variable defines! */									\
154*cdf0e10cSrcweir 				{																										\
155*cdf0e10cSrcweir 					::rtl::OStringBuffer sBufferParam(256);																\
156*cdf0e10cSrcweir 					::rtl::OStringBuffer sBufferSteps(256);																\
157*cdf0e10cSrcweir 					sBufferParam.append( SSERVICE				);														\
158*cdf0e10cSrcweir 					sBufferParam.append( "::findFrame() at \""	);														\
159*cdf0e10cSrcweir 					sBufferParam.append( U2B( SFRAMENAME )		);														\
160*cdf0e10cSrcweir 					sBufferParam.append( "\" "					);														\
161*cdf0e10cSrcweir 					if( XFRAME.is() == sal_True )																		\
162*cdf0e10cSrcweir 					{																									\
163*cdf0e10cSrcweir 						sBufferParam.append( "return with valid frame.\n"		);										\
164*cdf0e10cSrcweir 						sBufferSteps.append( "OK ["								);										\
165*cdf0e10cSrcweir 						sBufferSteps.append( U2B( XFRAME->getName() )			);										\
166*cdf0e10cSrcweir 						sBufferSteps.append( "]\n"								);										\
167*cdf0e10cSrcweir 					}																									\
168*cdf0e10cSrcweir 					else																								\
169*cdf0e10cSrcweir 					{																									\
170*cdf0e10cSrcweir 						sBufferParam.append( "return with NULL frame!\n");												\
171*cdf0e10cSrcweir 						sBufferSteps.append( "??\n"						);												\
172*cdf0e10cSrcweir 					}																									\
173*cdf0e10cSrcweir 					WRITE_LOGFILE( LOGFILE_TARGETPARAM, sBufferParam.makeStringAndClear() )								\
174*cdf0e10cSrcweir 					WRITE_LOGFILE( LOGFILE_TARGETSTEPS, sBufferSteps.makeStringAndClear() )								\
175*cdf0e10cSrcweir 				}
176*cdf0e10cSrcweir 
177*cdf0e10cSrcweir 	/*_____________________________________________________________________________________________________________
178*cdf0e10cSrcweir 		LOG_RESULT_QUERYDISPATCH( SSERVICE, SFRAMENAME, XDISPATCHER )
179*cdf0e10cSrcweir 
180*cdf0e10cSrcweir 		With this macro you can log informations about search result of "queryDispatch()".
181*cdf0e10cSrcweir 		Use it at the end of this method only!
182*cdf0e10cSrcweir 	_____________________________________________________________________________________________________________*/
183*cdf0e10cSrcweir 
184*cdf0e10cSrcweir 	#define	LOG_RESULT_QUERYDISPATCH( SSERVICE, SFRAMENAME, XDISPATCHER )												\
185*cdf0e10cSrcweir 				/* Use new scope to prevent code against multiple variable defines! */									\
186*cdf0e10cSrcweir 				{																										\
187*cdf0e10cSrcweir 					::rtl::OStringBuffer sBuffer(1024);																	\
188*cdf0e10cSrcweir 					sBuffer.append( "[ "				);																\
189*cdf0e10cSrcweir 					sBuffer.append( U2B( SFRAMENAME )	);																\
190*cdf0e10cSrcweir 					sBuffer.append( "] "				);																\
191*cdf0e10cSrcweir 					sBuffer.append( SSERVICE			);																\
192*cdf0e10cSrcweir 					if( XDISPATCHER.is() == sal_True )																	\
193*cdf0e10cSrcweir 					{																									\
194*cdf0e10cSrcweir 						sBuffer.append( "::queryDispatch() return with valid dispatcher."	);							\
195*cdf0e10cSrcweir 					}																									\
196*cdf0e10cSrcweir 					else																								\
197*cdf0e10cSrcweir 					{																									\
198*cdf0e10cSrcweir 						sBuffer.append( "::queryDispatch() return with NULL dispatcher!"	);							\
199*cdf0e10cSrcweir 					}																									\
200*cdf0e10cSrcweir 					sBuffer.append( "\n" );																				\
201*cdf0e10cSrcweir 					WRITE_LOGFILE( LOGFILE_TARGETPARAM, sBuffer.makeStringAndClear() )									\
202*cdf0e10cSrcweir 				}
203*cdf0e10cSrcweir 
204*cdf0e10cSrcweir 	/*_____________________________________________________________________________________________________________
205*cdf0e10cSrcweir 		LOG_RESULT_LOADCOMPONENTFROMURL( SSERVICE, SFRAMENAME, XCOMPONENT )
206*cdf0e10cSrcweir 
207*cdf0e10cSrcweir 		With this macro you can log informations about search result of "loadComponentFromURL()".
208*cdf0e10cSrcweir 		Use it at the end of this method only!
209*cdf0e10cSrcweir 	_____________________________________________________________________________________________________________*/
210*cdf0e10cSrcweir 
211*cdf0e10cSrcweir 	#define	LOG_RESULT_LOADCOMPONENTFROMURL( SSERVICE, SFRAMENAME, XCOMPONENT )											\
212*cdf0e10cSrcweir 				/* Use new scope to prevent code against multiple variable defines! */									\
213*cdf0e10cSrcweir 				{																										\
214*cdf0e10cSrcweir 					::rtl::OStringBuffer sBuffer(1024);																	\
215*cdf0e10cSrcweir 					sBuffer.append( "[ "				);																\
216*cdf0e10cSrcweir 					sBuffer.append( U2B( SFRAMENAME )	);																\
217*cdf0e10cSrcweir 					sBuffer.append( "] "				);																\
218*cdf0e10cSrcweir 					sBuffer.append( SSERVICE			);																\
219*cdf0e10cSrcweir 					if( XCOMPONENT.is() == sal_True )																	\
220*cdf0e10cSrcweir 					{																									\
221*cdf0e10cSrcweir 						sBuffer.append( "::loadComponentFromURL() return with valid component."	);						\
222*cdf0e10cSrcweir 					}																									\
223*cdf0e10cSrcweir 					else																								\
224*cdf0e10cSrcweir 					{																									\
225*cdf0e10cSrcweir 						sBuffer.append( "::loadComponentFromURL() return with NULL component!"	);						\
226*cdf0e10cSrcweir 					}																									\
227*cdf0e10cSrcweir 					sBuffer.append( "\n" );																				\
228*cdf0e10cSrcweir 					WRITE_LOGFILE( LOGFILE_TARGETPARAM, sBuffer.makeStringAndClear() )									\
229*cdf0e10cSrcweir 				}
230*cdf0e10cSrcweir 
231*cdf0e10cSrcweir #else	// #ifdef ENABLE_TARGETINGDEBUG
232*cdf0e10cSrcweir 
233*cdf0e10cSrcweir 	/*_____________________________________________________________________________________________________________
234*cdf0e10cSrcweir 		If right testmode is'nt set - implements these macro empty!
235*cdf0e10cSrcweir 	_____________________________________________________________________________________________________________*/
236*cdf0e10cSrcweir 
237*cdf0e10cSrcweir 	#undef	LOGFILE_TARGETPARAM
238*cdf0e10cSrcweir 	#undef	LOGFILE_TARGETSTEPS
239*cdf0e10cSrcweir 	#define	LOG_PARAMETER_FINDFRAME( SSERVICE, SFRAMENAME, STARGETNAME, NSEARCHFLAGS )
240*cdf0e10cSrcweir 	#define	LOG_PARAMETER_QUERYDISPATCH( SSERVICE, SFRAMENAME, AURL, STARGETNAME, NSEARCHFLAGS )
241*cdf0e10cSrcweir 	#define	LOG_PARAMETER_LOADCOMPONENTFROMURL( SSERVICE, SFRAMENAME, SURL, STARGETNAME, NSEARCHFLAGS, SEQPARAMETER )
242*cdf0e10cSrcweir 	#define	LOG_RESULT_FINDFRAME( SSERVICE, SFRAMENAME, XFRAME )
243*cdf0e10cSrcweir 	#define	LOG_RESULT_QUERYDISPATCH( SSERVICE, SFRAMENAME, XDISPATCHER )
244*cdf0e10cSrcweir 	#define	LOG_RESULT_LOADCOMPONENTFROMURL( SSERVICE, SFRAMENAME, XCOMPONENT )
245*cdf0e10cSrcweir 
246*cdf0e10cSrcweir #endif	// #ifdef ENABLE_TARGETINGDEBUG
247*cdf0e10cSrcweir 
248*cdf0e10cSrcweir //*****************************************************************************************************************
249*cdf0e10cSrcweir //	end of file
250*cdf0e10cSrcweir //*****************************************************************************************************************
251*cdf0e10cSrcweir 
252*cdf0e10cSrcweir #endif	// #ifndef __FRAMEWORK_MACROS_DEBUG_TARGETING_HXX_
253