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_EVENT_HXX_
25*b1cdbd2cSJim Jagielski #define __FRAMEWORK_MACROS_DEBUG_EVENT_HXX_
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski //*************************************************************************************************************
28*b1cdbd2cSJim Jagielski //	special macros for event handling
29*b1cdbd2cSJim Jagielski //*************************************************************************************************************
30*b1cdbd2cSJim Jagielski 
31*b1cdbd2cSJim Jagielski #ifdef	ENABLE_EVENTDEBUG
32*b1cdbd2cSJim Jagielski 
33*b1cdbd2cSJim Jagielski 	//_________________________________________________________________________________________________________________
34*b1cdbd2cSJim Jagielski 	//	includes
35*b1cdbd2cSJim Jagielski 	//_________________________________________________________________________________________________________________
36*b1cdbd2cSJim Jagielski 
37*b1cdbd2cSJim Jagielski 	#ifndef _RTL_STRBUF_HXX_
38*b1cdbd2cSJim Jagielski 	#include <rtl/strbuf.hxx>
39*b1cdbd2cSJim Jagielski 	#endif
40*b1cdbd2cSJim Jagielski 
41*b1cdbd2cSJim Jagielski 	/*_____________________________________________________________________________________________________________
42*b1cdbd2cSJim Jagielski 		LOGFILE_EVENTDEBUG
43*b1cdbd2cSJim Jagielski 
44*b1cdbd2cSJim Jagielski 		For follow macros we need a special log file. If user forget to specify anyone, we must do it for him!
45*b1cdbd2cSJim Jagielski 	_____________________________________________________________________________________________________________*/
46*b1cdbd2cSJim Jagielski 
47*b1cdbd2cSJim Jagielski 	#ifndef	LOGFILE_EVENTDEBUG
48*b1cdbd2cSJim Jagielski 		#define	LOGFILE_EVENTDEBUG																										\
49*b1cdbd2cSJim Jagielski 					"events.log"
50*b1cdbd2cSJim Jagielski 	#endif
51*b1cdbd2cSJim Jagielski 
52*b1cdbd2cSJim Jagielski 	/*_____________________________________________________________________________________________________________
53*b1cdbd2cSJim Jagielski 		LOG_FRAMEACTIONEVENT( SFRAMETYPE, SFRAMENAME, AFRAMEACTION )
54*b1cdbd2cSJim Jagielski 
55*b1cdbd2cSJim Jagielski 		Use this macro to print debug informations about sending of events to listener for controling right order.
56*b1cdbd2cSJim Jagielski 		( Use new scope in macro to declare sBuffer more then on time in same "parentscope"! )
57*b1cdbd2cSJim Jagielski 	_____________________________________________________________________________________________________________*/
58*b1cdbd2cSJim Jagielski 
59*b1cdbd2cSJim Jagielski 	#define LOG_FRAMEACTIONEVENT( SFRAMETYPE, SFRAMENAME, AFRAMEACTION )																\
60*b1cdbd2cSJim Jagielski 				{																														\
61*b1cdbd2cSJim Jagielski 					::rtl::OStringBuffer sBuffer(1024);																					\
62*b1cdbd2cSJim Jagielski 					sBuffer.append( "[ "				);																				\
63*b1cdbd2cSJim Jagielski 					sBuffer.append( SFRAMETYPE			);																				\
64*b1cdbd2cSJim Jagielski 					sBuffer.append( " ] \""				);																				\
65*b1cdbd2cSJim Jagielski 					sBuffer.append( U2B( SFRAMENAME )	);																				\
66*b1cdbd2cSJim Jagielski 					sBuffer.append( "\" send event \""	);																				\
67*b1cdbd2cSJim Jagielski 					switch( AFRAMEACTION )																								\
68*b1cdbd2cSJim Jagielski 					{																													\
69*b1cdbd2cSJim Jagielski 						case ::com::sun::star::frame::FrameAction_COMPONENT_ATTACHED	:	sBuffer.append("COMPONENT ATTACHED"		);	\
70*b1cdbd2cSJim Jagielski 																							break;										\
71*b1cdbd2cSJim Jagielski 						case ::com::sun::star::frame::FrameAction_COMPONENT_DETACHING	:	sBuffer.append("COMPONENT DETACHING"	);	\
72*b1cdbd2cSJim Jagielski 																							break;										\
73*b1cdbd2cSJim Jagielski 						case ::com::sun::star::frame::FrameAction_COMPONENT_REATTACHED	:	sBuffer.append("COMPONENT REATTACHED"	);	\
74*b1cdbd2cSJim Jagielski 																							break;										\
75*b1cdbd2cSJim Jagielski 						case ::com::sun::star::frame::FrameAction_FRAME_ACTIVATED		:	sBuffer.append("FRAME ACTIVATED"		);	\
76*b1cdbd2cSJim Jagielski 																							break;										\
77*b1cdbd2cSJim Jagielski 						case ::com::sun::star::frame::FrameAction_FRAME_DEACTIVATING	:	sBuffer.append("FRAME DEACTIVATING"		);	\
78*b1cdbd2cSJim Jagielski 																							break;										\
79*b1cdbd2cSJim Jagielski 						case ::com::sun::star::frame::FrameAction_CONTEXT_CHANGED		:	sBuffer.append("CONTEXT CHANGED"		);	\
80*b1cdbd2cSJim Jagielski 																							break;										\
81*b1cdbd2cSJim Jagielski 						case ::com::sun::star::frame::FrameAction_FRAME_UI_ACTIVATED	:	sBuffer.append("FRAME UI ACTIVATED"		);	\
82*b1cdbd2cSJim Jagielski 																							break;										\
83*b1cdbd2cSJim Jagielski 						case ::com::sun::star::frame::FrameAction_FRAME_UI_DEACTIVATING	:	sBuffer.append("FRAME UI DEACTIVATING"	);	\
84*b1cdbd2cSJim Jagielski 																							break;										\
85*b1cdbd2cSJim Jagielski 						case ::com::sun::star::frame::FrameAction_MAKE_FIXED_SIZE		:	sBuffer.append("MAKE_FIXED_SIZE"		);	\
86*b1cdbd2cSJim Jagielski 																							break;										\
87*b1cdbd2cSJim Jagielski 						default:	sBuffer.append("... ERROR: invalid FrameAction detected!"	);										\
88*b1cdbd2cSJim Jagielski 									break;																								\
89*b1cdbd2cSJim Jagielski 					}																													\
90*b1cdbd2cSJim Jagielski 					sBuffer.append( " ... event to listener.\n\n" );																	\
91*b1cdbd2cSJim Jagielski 					WRITE_LOGFILE( LOGFILE_EVENTDEBUG, sBuffer.makeStringAndClear() )													\
92*b1cdbd2cSJim Jagielski 				}
93*b1cdbd2cSJim Jagielski 
94*b1cdbd2cSJim Jagielski 	/*_____________________________________________________________________________________________________________
95*b1cdbd2cSJim Jagielski 		LOG_FRAMEACTIONEVENT( SFRAMETYPE, SFRAMENAME )
96*b1cdbd2cSJim Jagielski 
97*b1cdbd2cSJim Jagielski 		These macro log information about sending of dispose events to listener.
98*b1cdbd2cSJim Jagielski 		( Use new scope in macro to declare sBuffer more then on time in same "parentscope"! )
99*b1cdbd2cSJim Jagielski 	_____________________________________________________________________________________________________________*/
100*b1cdbd2cSJim Jagielski 
101*b1cdbd2cSJim Jagielski 	#define	LOG_DISPOSEEVENT( SFRAMETYPE, SFRAMENAME )																					\
102*b1cdbd2cSJim Jagielski 				{																														\
103*b1cdbd2cSJim Jagielski 					::rtl::OStringBuffer sBuffer(1024);																					\
104*b1cdbd2cSJim Jagielski 					sBuffer.append( "[ "									);															\
105*b1cdbd2cSJim Jagielski 					sBuffer.append( SFRAMETYPE								);															\
106*b1cdbd2cSJim Jagielski 					sBuffer.append( " ] \""									);															\
107*b1cdbd2cSJim Jagielski 					sBuffer.append( U2B( SFRAMENAME )						);															\
108*b1cdbd2cSJim Jagielski 					sBuffer.append( "\" send dispose event to listener.\n\n");															\
109*b1cdbd2cSJim Jagielski 					WRITE_LOGFILE( LOGFILE_EVENTDEBUG, sBuffer.makeStringAndClear() )													\
110*b1cdbd2cSJim Jagielski 				}
111*b1cdbd2cSJim Jagielski 
112*b1cdbd2cSJim Jagielski #else	// #ifdef ENABLE_EVENTDEBUG
113*b1cdbd2cSJim Jagielski 
114*b1cdbd2cSJim Jagielski 	/*_____________________________________________________________________________________________________________
115*b1cdbd2cSJim Jagielski 		If right testmode is'nt set - implements these macros empty!
116*b1cdbd2cSJim Jagielski 	_____________________________________________________________________________________________________________*/
117*b1cdbd2cSJim Jagielski 
118*b1cdbd2cSJim Jagielski 	#undef	LOGFILE_EVENTDEBUG
119*b1cdbd2cSJim Jagielski 	#define LOG_FRAMEACTIONEVENT( SFRAMETYPE, SFRAMENAME, AFRAMEACTION )
120*b1cdbd2cSJim Jagielski 	#define	LOG_DISPOSEEVENT( SFRAMETYPE, SFRAMENAME )
121*b1cdbd2cSJim Jagielski 
122*b1cdbd2cSJim Jagielski #endif	// #ifdef ENABLE_EVENTDEBUG
123*b1cdbd2cSJim Jagielski 
124*b1cdbd2cSJim Jagielski //*****************************************************************************************************************
125*b1cdbd2cSJim Jagielski //	end of file
126*b1cdbd2cSJim Jagielski //*****************************************************************************************************************
127*b1cdbd2cSJim Jagielski 
128*b1cdbd2cSJim Jagielski #endif	// #ifndef __FRAMEWORK_MACROS_DEBUG_EVENT_HXX_
129