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_DISPATCH_MENUDISPATCHER_HXX_
25*b1cdbd2cSJim Jagielski #define __FRAMEWORK_DISPATCH_MENUDISPATCHER_HXX_
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
28*b1cdbd2cSJim Jagielski //	my own includes
29*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
30*b1cdbd2cSJim Jagielski 
31*b1cdbd2cSJim Jagielski #include <classes/taskcreator.hxx>
32*b1cdbd2cSJim Jagielski #include <services/frame.hxx>
33*b1cdbd2cSJim Jagielski #include <macros/generic.hxx>
34*b1cdbd2cSJim Jagielski #include <macros/xinterface.hxx>
35*b1cdbd2cSJim Jagielski #include <macros/xtypeprovider.hxx>
36*b1cdbd2cSJim Jagielski #include <macros/debug.hxx>
37*b1cdbd2cSJim Jagielski #include <threadhelp/threadhelpbase.hxx>
38*b1cdbd2cSJim Jagielski #include <classes/menumanager.hxx>
39*b1cdbd2cSJim Jagielski #include <general.h>
40*b1cdbd2cSJim Jagielski #include <stdtypes.h>
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
43*b1cdbd2cSJim Jagielski //	interface includes
44*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
45*b1cdbd2cSJim Jagielski #include <com/sun/star/lang/XTypeProvider.hpp>
46*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XDispatch.hpp>
47*b1cdbd2cSJim Jagielski #include <com/sun/star/util/URL.hpp>
48*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/DispatchDescriptor.hpp>
49*b1cdbd2cSJim Jagielski #include <com/sun/star/beans/PropertyValue.hpp>
50*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XStatusListener.hpp>
51*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XFrameLoader.hpp>
52*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XLoadEventListener.hpp>
53*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XDesktop.hpp>
54*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/FeatureStateEvent.hpp>
55*b1cdbd2cSJim Jagielski #include <com/sun/star/frame/XFrameActionListener.hpp>
56*b1cdbd2cSJim Jagielski 
57*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
58*b1cdbd2cSJim Jagielski //	other includes
59*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
60*b1cdbd2cSJim Jagielski #include <cppuhelper/weak.hxx>
61*b1cdbd2cSJim Jagielski #include <cppuhelper/weakref.hxx>
62*b1cdbd2cSJim Jagielski #include <cppuhelper/interfacecontainer.h>
63*b1cdbd2cSJim Jagielski 
64*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
65*b1cdbd2cSJim Jagielski //	namespace
66*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
67*b1cdbd2cSJim Jagielski 
68*b1cdbd2cSJim Jagielski namespace framework{
69*b1cdbd2cSJim Jagielski 
70*b1cdbd2cSJim Jagielski 
71*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
72*b1cdbd2cSJim Jagielski //	exported const
73*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
74*b1cdbd2cSJim Jagielski 
75*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
76*b1cdbd2cSJim Jagielski //	exported definitions
77*b1cdbd2cSJim Jagielski //_________________________________________________________________________________________________________________
78*b1cdbd2cSJim Jagielski 
79*b1cdbd2cSJim Jagielski /*-************************************************************************************************************//**
80*b1cdbd2cSJim Jagielski 	We must save informations about our listener and URL for listening.
81*b1cdbd2cSJim Jagielski 	We implement this as a hashtable for strings.
82*b1cdbd2cSJim Jagielski *//*-*************************************************************************************************************/
83*b1cdbd2cSJim Jagielski 
84*b1cdbd2cSJim Jagielski typedef ::cppu::OMultiTypeInterfaceContainerHelperVar<	::rtl::OUString			,
85*b1cdbd2cSJim Jagielski 														rtl::OUStringHash,
86*b1cdbd2cSJim Jagielski 														std::equal_to< ::rtl::OUString > > IMPL_ListenerHashContainer;
87*b1cdbd2cSJim Jagielski 
88*b1cdbd2cSJim Jagielski 
89*b1cdbd2cSJim Jagielski /*-************************************************************************************************************//**
90*b1cdbd2cSJim Jagielski 	@short			helper for desktop only(!) to create new tasks on demand for dispatches
91*b1cdbd2cSJim Jagielski 	@descr			Use this class as member only! Never use it as baseclass.
92*b1cdbd2cSJim Jagielski 					XInterface will be ambigous and we hold a weakcss::uno::Reference to ouer OWNER - not to ouer SUPERCLASS!
93*b1cdbd2cSJim Jagielski 
94*b1cdbd2cSJim Jagielski 	@implements		XInterface
95*b1cdbd2cSJim Jagielski 					XDispatch
96*b1cdbd2cSJim Jagielski 					XLoadEventListener
97*b1cdbd2cSJim Jagielski 					XFrameActionListener
98*b1cdbd2cSJim Jagielski 					XEventListener
99*b1cdbd2cSJim Jagielski 	@base			ThreadHelpBase
100*b1cdbd2cSJim Jagielski 					OWeakObject
101*b1cdbd2cSJim Jagielski 
102*b1cdbd2cSJim Jagielski 	@devstatus		ready to use
103*b1cdbd2cSJim Jagielski *//*-*************************************************************************************************************/
104*b1cdbd2cSJim Jagielski class MenuDispatcher   :   // interfaces
105*b1cdbd2cSJim Jagielski 								public css::lang::XTypeProvider			,
106*b1cdbd2cSJim Jagielski 								public css::frame::XDispatch			,
107*b1cdbd2cSJim Jagielski 								public css::frame::XFrameActionListener	,
108*b1cdbd2cSJim Jagielski 								// baseclasses
109*b1cdbd2cSJim Jagielski 								// Order is neccessary for right initialization!
110*b1cdbd2cSJim Jagielski 								public ThreadHelpBase						,
111*b1cdbd2cSJim Jagielski 								public cppu::OWeakObject
112*b1cdbd2cSJim Jagielski {
113*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
114*b1cdbd2cSJim Jagielski 	//	public methods
115*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
116*b1cdbd2cSJim Jagielski 
117*b1cdbd2cSJim Jagielski 	public:
118*b1cdbd2cSJim Jagielski 
119*b1cdbd2cSJim Jagielski 		//---------------------------------------------------------------------------------------------------------
120*b1cdbd2cSJim Jagielski 		//	constructor / destructor
121*b1cdbd2cSJim Jagielski 		//---------------------------------------------------------------------------------------------------------
122*b1cdbd2cSJim Jagielski 
123*b1cdbd2cSJim Jagielski 		/*-****************************************************************************************************//**
124*b1cdbd2cSJim Jagielski 			@short		standard ctor
125*b1cdbd2cSJim Jagielski 			@descr		These initialize a new instance of ths class with needed informations for work.
126*b1cdbd2cSJim Jagielski 
127*b1cdbd2cSJim Jagielski 			@seealso	using at owner
128*b1cdbd2cSJim Jagielski 
129*b1cdbd2cSJim Jagielski 			@param		"xFactory"	, css::uno::Reference to servicemanager for creation of new services
130*b1cdbd2cSJim Jagielski 			@param		"xOwner"	, css::uno::Reference to our owner, the Desktop!!!
131*b1cdbd2cSJim Jagielski 			@return		-
132*b1cdbd2cSJim Jagielski 
133*b1cdbd2cSJim Jagielski 			@onerror	-
134*b1cdbd2cSJim Jagielski 		*//*-*****************************************************************************************************/
135*b1cdbd2cSJim Jagielski 
136*b1cdbd2cSJim Jagielski         MenuDispatcher(    const   css::uno::Reference< css::lang::XMultiServiceFactory >& xFactory    ,
137*b1cdbd2cSJim Jagielski 							const	css::uno::Reference< css::frame::XFrame >&				xOwner		);
138*b1cdbd2cSJim Jagielski 
139*b1cdbd2cSJim Jagielski 		//---------------------------------------------------------------------------------------------------------
140*b1cdbd2cSJim Jagielski 		//	XInterface
141*b1cdbd2cSJim Jagielski 		//---------------------------------------------------------------------------------------------------------
142*b1cdbd2cSJim Jagielski 
143*b1cdbd2cSJim Jagielski 		FWK_DECLARE_XINTERFACE
144*b1cdbd2cSJim Jagielski 		FWK_DECLARE_XTYPEPROVIDER
145*b1cdbd2cSJim Jagielski 
146*b1cdbd2cSJim Jagielski 		//---------------------------------------------------------------------------------------------------------
147*b1cdbd2cSJim Jagielski 		//	XDispatch
148*b1cdbd2cSJim Jagielski 		//---------------------------------------------------------------------------------------------------------
149*b1cdbd2cSJim Jagielski 
150*b1cdbd2cSJim Jagielski 		/*-****************************************************************************************************//**
151*b1cdbd2cSJim Jagielski 			@short      dispatch URL with arguments
152*b1cdbd2cSJim Jagielski 			@descr		Every dispatch create a new task. If load of URL failed task will deleted automaticly!
153*b1cdbd2cSJim Jagielski 
154*b1cdbd2cSJim Jagielski 			@seealso	-
155*b1cdbd2cSJim Jagielski 
156*b1cdbd2cSJim Jagielski 			@param		"aURL"			, URL to dispatch.
157*b1cdbd2cSJim Jagielski 			@param		"seqArguments"	, list of optional arguments.
158*b1cdbd2cSJim Jagielski 			@return		-
159*b1cdbd2cSJim Jagielski 
160*b1cdbd2cSJim Jagielski 			@onerror	-
161*b1cdbd2cSJim Jagielski 		*//*-*****************************************************************************************************/
162*b1cdbd2cSJim Jagielski 
163*b1cdbd2cSJim Jagielski 		virtual void SAL_CALL dispatch(	const	css::util::URL&										aURL			,
164*b1cdbd2cSJim Jagielski 										const	css::uno::Sequence< css::beans::PropertyValue >&	seqProperties	) throw( css::uno::RuntimeException );
165*b1cdbd2cSJim Jagielski 
166*b1cdbd2cSJim Jagielski 		/*-****************************************************************************************************//**
167*b1cdbd2cSJim Jagielski 			@short      add listener for state events
168*b1cdbd2cSJim Jagielski 			@descr		You can add a listener to get information about status of dispatch: OK or Failed.
169*b1cdbd2cSJim Jagielski 
170*b1cdbd2cSJim Jagielski 			@seealso	method loadFinished()
171*b1cdbd2cSJim Jagielski 			@seealso	method loadCancelled()
172*b1cdbd2cSJim Jagielski 
173*b1cdbd2cSJim Jagielski 			@param		"xControl"	, css::uno::Reference to a valid listener for state events.
174*b1cdbd2cSJim Jagielski 			@param		"aURL"		, URL about listener will be informed, if something occured.
175*b1cdbd2cSJim Jagielski 			@return		-
176*b1cdbd2cSJim Jagielski 
177*b1cdbd2cSJim Jagielski 			@onerror	-
178*b1cdbd2cSJim Jagielski 		*//*-*****************************************************************************************************/
179*b1cdbd2cSJim Jagielski 
180*b1cdbd2cSJim Jagielski 		virtual void SAL_CALL addStatusListener(	const	css::uno::Reference< css::frame::XStatusListener >&	xControl,
181*b1cdbd2cSJim Jagielski 													const	css::util::URL&										aURL	) throw( css::uno::RuntimeException );
182*b1cdbd2cSJim Jagielski 
183*b1cdbd2cSJim Jagielski 		/*-****************************************************************************************************//**
184*b1cdbd2cSJim Jagielski 			@short      remove listener for state events
185*b1cdbd2cSJim Jagielski 			@descr		You can remove a listener if information of dispatch isn't important for you any longer.
186*b1cdbd2cSJim Jagielski 
187*b1cdbd2cSJim Jagielski 			@seealso	method loadFinished()
188*b1cdbd2cSJim Jagielski 			@seealso	method loadCancelled()
189*b1cdbd2cSJim Jagielski 
190*b1cdbd2cSJim Jagielski 			@param		"xControl"	, css::uno::Reference to a valid listener.
191*b1cdbd2cSJim Jagielski 			@param		"aURL"		, URL on which listener has registered.
192*b1cdbd2cSJim Jagielski 			@return		-
193*b1cdbd2cSJim Jagielski 
194*b1cdbd2cSJim Jagielski 			@onerror	-
195*b1cdbd2cSJim Jagielski 		*//*-*****************************************************************************************************/
196*b1cdbd2cSJim Jagielski 
197*b1cdbd2cSJim Jagielski     	virtual void SAL_CALL removeStatusListener(	const	css::uno::Reference< css::frame::XStatusListener >&	xControl,
198*b1cdbd2cSJim Jagielski 													const	css::util::URL&										aURL	) throw( css::uno::RuntimeException );
199*b1cdbd2cSJim Jagielski 
200*b1cdbd2cSJim Jagielski 
201*b1cdbd2cSJim Jagielski 		//---------------------------------------------------------------------------------------------------------
202*b1cdbd2cSJim Jagielski 		//	 XFrameActionListener
203*b1cdbd2cSJim Jagielski 		//---------------------------------------------------------------------------------------------------------
204*b1cdbd2cSJim Jagielski 
205*b1cdbd2cSJim Jagielski 		virtual void SAL_CALL frameAction( const css::frame::FrameActionEvent& aEvent ) throw ( css::uno::RuntimeException );
206*b1cdbd2cSJim Jagielski 
207*b1cdbd2cSJim Jagielski 		//---------------------------------------------------------------------------------------------------------
208*b1cdbd2cSJim Jagielski 		//	 XEventListener
209*b1cdbd2cSJim Jagielski 		//---------------------------------------------------------------------------------------------------------
210*b1cdbd2cSJim Jagielski 
211*b1cdbd2cSJim Jagielski 		/*-****************************************************************************************************//**
212*b1cdbd2cSJim Jagielski 			@short		dispose current instance
213*b1cdbd2cSJim Jagielski 			@descr		If service helper isn't required any longer call this method to release all used ressources.
214*b1cdbd2cSJim Jagielski 
215*b1cdbd2cSJim Jagielski 			@seealso	-
216*b1cdbd2cSJim Jagielski 
217*b1cdbd2cSJim Jagielski 			@param		"aEvent", information about source of this event.
218*b1cdbd2cSJim Jagielski 			@return		-
219*b1cdbd2cSJim Jagielski 
220*b1cdbd2cSJim Jagielski 			@onerror	-
221*b1cdbd2cSJim Jagielski 		*//*-*****************************************************************************************************/
222*b1cdbd2cSJim Jagielski 
223*b1cdbd2cSJim Jagielski 		void SAL_CALL disposing( const EVENTOBJECT& aEvent ) throw( css::uno::RuntimeException );
224*b1cdbd2cSJim Jagielski 
225*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
226*b1cdbd2cSJim Jagielski 	//	protected methods
227*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
228*b1cdbd2cSJim Jagielski 
229*b1cdbd2cSJim Jagielski 	protected:
230*b1cdbd2cSJim Jagielski 
231*b1cdbd2cSJim Jagielski 		/*-****************************************************************************************************//**
232*b1cdbd2cSJim Jagielski 			@short		standard destructor
233*b1cdbd2cSJim Jagielski 			@descr		This method destruct an instance of this class and clear some member.
234*b1cdbd2cSJim Jagielski 						This method is protected, because its not allowed to use an instance of this class as a member!
235*b1cdbd2cSJim Jagielski 						You MUST use a pointer.
236*b1cdbd2cSJim Jagielski 
237*b1cdbd2cSJim Jagielski 			@seealso	-
238*b1cdbd2cSJim Jagielski 
239*b1cdbd2cSJim Jagielski 			@param		-
240*b1cdbd2cSJim Jagielski 			@return		-
241*b1cdbd2cSJim Jagielski 
242*b1cdbd2cSJim Jagielski 			@onerror	-
243*b1cdbd2cSJim Jagielski 		*//*-*****************************************************************************************************/
244*b1cdbd2cSJim Jagielski 
245*b1cdbd2cSJim Jagielski         virtual ~MenuDispatcher();
246*b1cdbd2cSJim Jagielski 
247*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
248*b1cdbd2cSJim Jagielski 	//	private methods
249*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
250*b1cdbd2cSJim Jagielski 
251*b1cdbd2cSJim Jagielski 	private:
252*b1cdbd2cSJim Jagielski 
253*b1cdbd2cSJim Jagielski         DECL_LINK( Close_Impl, void* );
254*b1cdbd2cSJim Jagielski 
255*b1cdbd2cSJim Jagielski 		/*-****************************************************************************************************//**
256*b1cdbd2cSJim Jagielski 			@short		-
257*b1cdbd2cSJim Jagielski 			@descr		-
258*b1cdbd2cSJim Jagielski 
259*b1cdbd2cSJim Jagielski 			@seealso	-
260*b1cdbd2cSJim Jagielski 
261*b1cdbd2cSJim Jagielski 			@param		-
262*b1cdbd2cSJim Jagielski 			@return		-
263*b1cdbd2cSJim Jagielski 
264*b1cdbd2cSJim Jagielski 			@onerror	-
265*b1cdbd2cSJim Jagielski 		*//*-*****************************************************************************************************/
266*b1cdbd2cSJim Jagielski 
267*b1cdbd2cSJim Jagielski 		sal_Bool impl_setMenuBar( MenuBar* pMenuBar, sal_Bool bMenuFromResource = sal_False );
268*b1cdbd2cSJim Jagielski 
269*b1cdbd2cSJim Jagielski 		/*-****************************************************************************************************//**
270*b1cdbd2cSJim Jagielski 			@short		-
271*b1cdbd2cSJim Jagielski 			@descr		-
272*b1cdbd2cSJim Jagielski 
273*b1cdbd2cSJim Jagielski 			@seealso	-
274*b1cdbd2cSJim Jagielski 
275*b1cdbd2cSJim Jagielski 			@param		-
276*b1cdbd2cSJim Jagielski 			@return		-
277*b1cdbd2cSJim Jagielski 
278*b1cdbd2cSJim Jagielski 			@onerror	-
279*b1cdbd2cSJim Jagielski 		*//*-*****************************************************************************************************/
280*b1cdbd2cSJim Jagielski 
281*b1cdbd2cSJim Jagielski         void impl_setAccelerators( Menu* pMenu, const Accelerator& aAccel );
282*b1cdbd2cSJim Jagielski 
283*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
284*b1cdbd2cSJim Jagielski 	//	debug methods
285*b1cdbd2cSJim Jagielski 	//	(should be private everyway!)
286*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
287*b1cdbd2cSJim Jagielski 
288*b1cdbd2cSJim Jagielski 		/*-****************************************************************************************************//**
289*b1cdbd2cSJim Jagielski 			@short		debug-method to check incoming parameter of some other mehods of this class
290*b1cdbd2cSJim Jagielski 			@descr		The following methods are used to check parameters for other methods
291*b1cdbd2cSJim Jagielski 						of this class. The return value is used directly for an ASSERT(...).
292*b1cdbd2cSJim Jagielski 
293*b1cdbd2cSJim Jagielski 			@seealso	ASSERTs in implementation!
294*b1cdbd2cSJim Jagielski 
295*b1cdbd2cSJim Jagielski 			@param		css::uno::References to checking variables
296*b1cdbd2cSJim Jagielski 			@return		sal_False on invalid parameter<BR>
297*b1cdbd2cSJim Jagielski 						sal_True  otherway
298*b1cdbd2cSJim Jagielski 
299*b1cdbd2cSJim Jagielski 			@onerror	-
300*b1cdbd2cSJim Jagielski 		*//*-*****************************************************************************************************/
301*b1cdbd2cSJim Jagielski 
302*b1cdbd2cSJim Jagielski 	#ifdef ENABLE_ASSERTIONS
303*b1cdbd2cSJim Jagielski 
304*b1cdbd2cSJim Jagielski 	private:
305*b1cdbd2cSJim Jagielski 
306*b1cdbd2cSJim Jagielski         static sal_Bool impldbg_checkParameter_MenuDispatcher      (   const   css::uno::Reference< css::lang::XMultiServiceFactory >& xFactory        ,
307*b1cdbd2cSJim Jagielski 																		const	css::uno::Reference< css::frame::XFrame >&				xOwner			);
308*b1cdbd2cSJim Jagielski 		static sal_Bool impldbg_checkParameter_addStatusListener	(	const	css::uno::Reference< css::frame::XStatusListener >&		xControl		,
309*b1cdbd2cSJim Jagielski 																		const	css::util::URL&											aURL			);
310*b1cdbd2cSJim Jagielski 		static sal_Bool impldbg_checkParameter_removeStatusListener	(	const	css::uno::Reference< css::frame::XStatusListener >&		xControl		,
311*b1cdbd2cSJim Jagielski 																		const	css::util::URL&											aURL			);
312*b1cdbd2cSJim Jagielski 	#endif	// #ifdef ENABLE_ASSERTIONS
313*b1cdbd2cSJim Jagielski 
314*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
315*b1cdbd2cSJim Jagielski 	//	variables
316*b1cdbd2cSJim Jagielski 	//	(should be private everyway!)
317*b1cdbd2cSJim Jagielski 	//-------------------------------------------------------------------------------------------------------------
318*b1cdbd2cSJim Jagielski 
319*b1cdbd2cSJim Jagielski 	private:
320*b1cdbd2cSJim Jagielski 
321*b1cdbd2cSJim Jagielski 		css::uno::WeakReference< css::frame::XFrame >			m_xOwnerWeak		;	/// css::uno::WeakReference to owner (Don't use a hard css::uno::Reference. Owner can't delete us then!)
322*b1cdbd2cSJim Jagielski 		css::uno::Reference< css::lang::XMultiServiceFactory >	m_xFactory			;	/// factory shared with our owner to create new services!
323*b1cdbd2cSJim Jagielski 		IMPL_ListenerHashContainer								m_aListenerContainer;	/// hash table for listener at specified URLs
324*b1cdbd2cSJim Jagielski 		sal_Bool												m_bAlreadyDisposed	;	/// Protection against multiple disposing calls.
325*b1cdbd2cSJim Jagielski 		sal_Bool												m_bActivateListener ;	/// dispatcher is listener for frame activation
326*b1cdbd2cSJim Jagielski 		MenuManager*											m_pMenuManager		;	/// menu manager controlling menu dispatches
327*b1cdbd2cSJim Jagielski 
328*b1cdbd2cSJim Jagielski };      //  class MenuDispatcher
329*b1cdbd2cSJim Jagielski 
330*b1cdbd2cSJim Jagielski }		//	namespace framework
331*b1cdbd2cSJim Jagielski 
332*b1cdbd2cSJim Jagielski #endif  //  #ifndef __FRAMEWORK_DISPATCH_MENUDISPATCHER_HXX_
333