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 //____________________________________________________________________________________________________________
25*b1cdbd2cSJim Jagielski //	my own includes
26*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski #include "basecontainercontrol.hxx"
29*b1cdbd2cSJim Jagielski 
30*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
31*b1cdbd2cSJim Jagielski //	includes of other projects
32*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
33*b1cdbd2cSJim Jagielski #include <cppuhelper/typeprovider.hxx>
34*b1cdbd2cSJim Jagielski 
35*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
36*b1cdbd2cSJim Jagielski //	includes of my own project
37*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
38*b1cdbd2cSJim Jagielski 
39*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
40*b1cdbd2cSJim Jagielski //	namespaces
41*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
42*b1cdbd2cSJim Jagielski 
43*b1cdbd2cSJim Jagielski using namespace ::cppu						;
44*b1cdbd2cSJim Jagielski using namespace ::osl						;
45*b1cdbd2cSJim Jagielski using namespace ::rtl						;
46*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::uno		;
47*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::lang		;
48*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::awt		;
49*b1cdbd2cSJim Jagielski using namespace ::com::sun::star::container	;
50*b1cdbd2cSJim Jagielski 
51*b1cdbd2cSJim Jagielski namespace unocontrols{
52*b1cdbd2cSJim Jagielski 
53*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
54*b1cdbd2cSJim Jagielski //	construct/destruct
55*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
56*b1cdbd2cSJim Jagielski 
BaseContainerControl(const Reference<XMultiServiceFactory> & xFactory)57*b1cdbd2cSJim Jagielski BaseContainerControl::BaseContainerControl( const Reference< XMultiServiceFactory >& xFactory )
58*b1cdbd2cSJim Jagielski 	: BaseControl	( xFactory	)
59*b1cdbd2cSJim Jagielski 	, m_aListeners	( m_aMutex	)
60*b1cdbd2cSJim Jagielski {
61*b1cdbd2cSJim Jagielski 	// initialize info list for controls
62*b1cdbd2cSJim Jagielski 	m_pControlInfoList = new IMPL_ControlInfoList ;
63*b1cdbd2cSJim Jagielski }
64*b1cdbd2cSJim Jagielski 
~BaseContainerControl()65*b1cdbd2cSJim Jagielski BaseContainerControl::~BaseContainerControl()
66*b1cdbd2cSJim Jagielski {
67*b1cdbd2cSJim Jagielski 	impl_cleanMemory();
68*b1cdbd2cSJim Jagielski }
69*b1cdbd2cSJim Jagielski 
70*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
71*b1cdbd2cSJim Jagielski //	XInterface
72*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
73*b1cdbd2cSJim Jagielski 
queryInterface(const Type & rType)74*b1cdbd2cSJim Jagielski Any SAL_CALL BaseContainerControl::queryInterface( const Type& rType ) throw( RuntimeException )
75*b1cdbd2cSJim Jagielski {
76*b1cdbd2cSJim Jagielski 	// Attention:
77*b1cdbd2cSJim Jagielski 	//	Don't use mutex or guard in this method!!! Is a method of XInterface.
78*b1cdbd2cSJim Jagielski 	Any aReturn ;
79*b1cdbd2cSJim Jagielski 	Reference< XInterface > xDel = BaseControl::impl_getDelegator();
80*b1cdbd2cSJim Jagielski 	if ( xDel.is() == sal_True )
81*b1cdbd2cSJim Jagielski 	{
82*b1cdbd2cSJim Jagielski 		// If an delegator exist, forward question to his queryInterface.
83*b1cdbd2cSJim Jagielski 		// Delegator will ask his own queryAggregation!
84*b1cdbd2cSJim Jagielski 		aReturn = xDel->queryInterface( rType );
85*b1cdbd2cSJim Jagielski 	}
86*b1cdbd2cSJim Jagielski 	else
87*b1cdbd2cSJim Jagielski 	{
88*b1cdbd2cSJim Jagielski 		// If an delegator unknown, forward question to own queryAggregation.
89*b1cdbd2cSJim Jagielski 		aReturn = queryAggregation( rType );
90*b1cdbd2cSJim Jagielski 	}
91*b1cdbd2cSJim Jagielski 
92*b1cdbd2cSJim Jagielski 	return aReturn ;
93*b1cdbd2cSJim Jagielski }
94*b1cdbd2cSJim Jagielski 
95*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
96*b1cdbd2cSJim Jagielski //	XTypeProvider
97*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
98*b1cdbd2cSJim Jagielski 
getTypes()99*b1cdbd2cSJim Jagielski Sequence< Type > SAL_CALL BaseContainerControl::getTypes() throw( RuntimeException )
100*b1cdbd2cSJim Jagielski {
101*b1cdbd2cSJim Jagielski 	// Optimize this method !
102*b1cdbd2cSJim Jagielski 	// We initialize a static variable only one time. And we don't must use a mutex at every call!
103*b1cdbd2cSJim Jagielski 	// For the first call; pTypeCollection is NULL - for the second call pTypeCollection is different from NULL!
104*b1cdbd2cSJim Jagielski 	static OTypeCollection* pTypeCollection = NULL ;
105*b1cdbd2cSJim Jagielski 
106*b1cdbd2cSJim Jagielski 	if ( pTypeCollection == NULL )
107*b1cdbd2cSJim Jagielski 	{
108*b1cdbd2cSJim Jagielski 		// Ready for multithreading; get global mutex for first call of this method only! see before
109*b1cdbd2cSJim Jagielski 		MutexGuard aGuard( Mutex::getGlobalMutex() );
110*b1cdbd2cSJim Jagielski 
111*b1cdbd2cSJim Jagielski 		// Control these pointer again ... it can be, that another instance will be faster then these!
112*b1cdbd2cSJim Jagielski 		if ( pTypeCollection == NULL )
113*b1cdbd2cSJim Jagielski 		{
114*b1cdbd2cSJim Jagielski 			// Create a static typecollection ...
115*b1cdbd2cSJim Jagielski 			static OTypeCollection aTypeCollection	(	::getCppuType(( const Reference< XControlModel		>*)NULL )	,
116*b1cdbd2cSJim Jagielski 												  		::getCppuType(( const Reference< XControlContainer	>*)NULL )	,
117*b1cdbd2cSJim Jagielski 														BaseControl::getTypes()
118*b1cdbd2cSJim Jagielski 													);
119*b1cdbd2cSJim Jagielski 			// ... and set his address to static pointer!
120*b1cdbd2cSJim Jagielski 			pTypeCollection = &aTypeCollection ;
121*b1cdbd2cSJim Jagielski 		}
122*b1cdbd2cSJim Jagielski 	}
123*b1cdbd2cSJim Jagielski 
124*b1cdbd2cSJim Jagielski 	return pTypeCollection->getTypes();
125*b1cdbd2cSJim Jagielski }
126*b1cdbd2cSJim Jagielski 
127*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
128*b1cdbd2cSJim Jagielski //	XAggregation
129*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
130*b1cdbd2cSJim Jagielski 
queryAggregation(const Type & aType)131*b1cdbd2cSJim Jagielski Any SAL_CALL BaseContainerControl::queryAggregation( const Type& aType ) throw( RuntimeException )
132*b1cdbd2cSJim Jagielski {
133*b1cdbd2cSJim Jagielski 	// Ask for my own supported interfaces ...
134*b1cdbd2cSJim Jagielski 	// Attention: XTypeProvider and XInterface are supported by OComponentHelper!
135*b1cdbd2cSJim Jagielski 	Any aReturn	( ::cppu::queryInterface(	aType										,
136*b1cdbd2cSJim Jagielski 									   		static_cast< XControlModel*		> ( this )	,
137*b1cdbd2cSJim Jagielski 									   		static_cast< XControlContainer*	> ( this )
138*b1cdbd2cSJim Jagielski 										)
139*b1cdbd2cSJim Jagielski 				);
140*b1cdbd2cSJim Jagielski 
141*b1cdbd2cSJim Jagielski 	// If searched interface supported by this class ...
142*b1cdbd2cSJim Jagielski 	if ( aReturn.hasValue() == sal_True )
143*b1cdbd2cSJim Jagielski 	{
144*b1cdbd2cSJim Jagielski 		// ... return this information.
145*b1cdbd2cSJim Jagielski 		return aReturn ;
146*b1cdbd2cSJim Jagielski 	}
147*b1cdbd2cSJim Jagielski 	else
148*b1cdbd2cSJim Jagielski 	{
149*b1cdbd2cSJim Jagielski 		// Else; ... ask baseclass for interfaces!
150*b1cdbd2cSJim Jagielski 		return BaseControl::queryAggregation( aType );
151*b1cdbd2cSJim Jagielski 	}
152*b1cdbd2cSJim Jagielski }
153*b1cdbd2cSJim Jagielski 
154*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
155*b1cdbd2cSJim Jagielski //	XControl
156*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
157*b1cdbd2cSJim Jagielski 
createPeer(const Reference<XToolkit> & xToolkit,const Reference<XWindowPeer> & xParent)158*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::createPeer(	const	Reference< XToolkit >&		xToolkit	,
159*b1cdbd2cSJim Jagielski 												const	Reference< XWindowPeer >&	xParent		) throw( RuntimeException )
160*b1cdbd2cSJim Jagielski {
161*b1cdbd2cSJim Jagielski 	if ( getPeer().is() == sal_False )
162*b1cdbd2cSJim Jagielski 	{
163*b1cdbd2cSJim Jagielski 		// create own peer
164*b1cdbd2cSJim Jagielski 		BaseControl::createPeer( xToolkit, xParent );
165*b1cdbd2cSJim Jagielski 
166*b1cdbd2cSJim Jagielski 		// create peers at all childs
167*b1cdbd2cSJim Jagielski 		Sequence< Reference< XControl > >	seqControlList	= getControls();
168*b1cdbd2cSJim Jagielski 		sal_uInt32							nControls		= seqControlList.getLength();
169*b1cdbd2cSJim Jagielski 
170*b1cdbd2cSJim Jagielski 		for ( sal_uInt32 n=0; n<nControls; n++ )
171*b1cdbd2cSJim Jagielski 		{
172*b1cdbd2cSJim Jagielski 			seqControlList.getArray()[n]->createPeer( xToolkit, getPeer() );
173*b1cdbd2cSJim Jagielski 		}
174*b1cdbd2cSJim Jagielski 
175*b1cdbd2cSJim Jagielski 		// activate new tab order
176*b1cdbd2cSJim Jagielski 		impl_activateTabControllers();
177*b1cdbd2cSJim Jagielski 
178*b1cdbd2cSJim Jagielski /*
179*b1cdbd2cSJim Jagielski 		Reference< XVclContainerPeer > xC;
180*b1cdbd2cSJim Jagielski 		mxPeer->queryInterface( ::getCppuType((const Reference< XVclContainerPeer >*)0), xC );
181*b1cdbd2cSJim Jagielski 		xC->enableDialogControl( sal_True );
182*b1cdbd2cSJim Jagielski */
183*b1cdbd2cSJim Jagielski 
184*b1cdbd2cSJim Jagielski 	}
185*b1cdbd2cSJim Jagielski }
186*b1cdbd2cSJim Jagielski 
187*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
188*b1cdbd2cSJim Jagielski //	XControl
189*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
190*b1cdbd2cSJim Jagielski 
setModel(const Reference<XControlModel> &)191*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL BaseContainerControl::setModel( const Reference< XControlModel >& ) throw( RuntimeException )
192*b1cdbd2cSJim Jagielski {
193*b1cdbd2cSJim Jagielski 	// This object has NO model.
194*b1cdbd2cSJim Jagielski 	return sal_False ;
195*b1cdbd2cSJim Jagielski }
196*b1cdbd2cSJim Jagielski 
197*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
198*b1cdbd2cSJim Jagielski //	XControl
199*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
200*b1cdbd2cSJim Jagielski 
getModel()201*b1cdbd2cSJim Jagielski Reference< XControlModel > SAL_CALL BaseContainerControl::getModel() throw( RuntimeException )
202*b1cdbd2cSJim Jagielski {
203*b1cdbd2cSJim Jagielski 	// This object has NO model.
204*b1cdbd2cSJim Jagielski 	// return (XControlModel*)this ;
205*b1cdbd2cSJim Jagielski 	return Reference< XControlModel >();
206*b1cdbd2cSJim Jagielski }
207*b1cdbd2cSJim Jagielski 
208*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
209*b1cdbd2cSJim Jagielski //	XComponent
210*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
211*b1cdbd2cSJim Jagielski 
dispose()212*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::dispose() throw( RuntimeException )
213*b1cdbd2cSJim Jagielski {
214*b1cdbd2cSJim Jagielski 	// Zuerst der Welt mitteilen, da� der Container wegfliegt. Dieses ist um einiges
215*b1cdbd2cSJim Jagielski 	// schneller wenn die Welt sowohl an den Controls als auch am Container horcht
216*b1cdbd2cSJim Jagielski 
217*b1cdbd2cSJim Jagielski 	// Ready for multithreading
218*b1cdbd2cSJim Jagielski 	MutexGuard aGuard( m_aMutex );
219*b1cdbd2cSJim Jagielski 
220*b1cdbd2cSJim Jagielski 	// remove listeners
221*b1cdbd2cSJim Jagielski 	EventObject	aObject ;
222*b1cdbd2cSJim Jagielski 
223*b1cdbd2cSJim Jagielski 	aObject.Source = Reference< XComponent > ( (XControlContainer*)this, UNO_QUERY );
224*b1cdbd2cSJim Jagielski 	m_aListeners.disposeAndClear( aObject );
225*b1cdbd2cSJim Jagielski 
226*b1cdbd2cSJim Jagielski 	// remove controls
227*b1cdbd2cSJim Jagielski 	Sequence< Reference< XControl > >	seqCtrls	=	getControls();
228*b1cdbd2cSJim Jagielski 	Reference< XControl > *				pCtrls		=	seqCtrls.getArray();
229*b1cdbd2cSJim Jagielski 	sal_uInt32							nCtrls		=	seqCtrls.getLength();
230*b1cdbd2cSJim Jagielski 	sal_uInt32							nMaxCount	=	m_pControlInfoList->Count();
231*b1cdbd2cSJim Jagielski 	sal_uInt32							nCount		=	0;
232*b1cdbd2cSJim Jagielski 
233*b1cdbd2cSJim Jagielski 	for ( nCount = 0; nCount < nMaxCount; ++nCount )
234*b1cdbd2cSJim Jagielski 	{
235*b1cdbd2cSJim Jagielski 		delete m_pControlInfoList->GetObject( 0 );
236*b1cdbd2cSJim Jagielski 	}
237*b1cdbd2cSJim Jagielski 	m_pControlInfoList->Clear();
238*b1cdbd2cSJim Jagielski 
239*b1cdbd2cSJim Jagielski 
240*b1cdbd2cSJim Jagielski 	for ( nCount = 0; nCount < nCtrls; ++nCount )
241*b1cdbd2cSJim Jagielski 	{
242*b1cdbd2cSJim Jagielski 		pCtrls [ nCount ] -> removeEventListener	( static_cast< XEventListener* >( static_cast< XWindowListener* >( this ) )	) ;
243*b1cdbd2cSJim Jagielski 		pCtrls [ nCount ] -> dispose				(		) ;
244*b1cdbd2cSJim Jagielski 	}
245*b1cdbd2cSJim Jagielski 
246*b1cdbd2cSJim Jagielski 	// call baseclass
247*b1cdbd2cSJim Jagielski 	BaseControl::dispose();
248*b1cdbd2cSJim Jagielski }
249*b1cdbd2cSJim Jagielski 
250*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
251*b1cdbd2cSJim Jagielski //	XEventListener
252*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
253*b1cdbd2cSJim Jagielski 
disposing(const EventObject & rEvent)254*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::disposing( const EventObject& rEvent ) throw( RuntimeException )
255*b1cdbd2cSJim Jagielski {
256*b1cdbd2cSJim Jagielski 	Reference< XControl > xControl( rEvent.Source, UNO_QUERY );
257*b1cdbd2cSJim Jagielski 
258*b1cdbd2cSJim Jagielski 	// "removeControl" remove only, when control is an active control
259*b1cdbd2cSJim Jagielski 	removeControl( xControl );
260*b1cdbd2cSJim Jagielski }
261*b1cdbd2cSJim Jagielski 
262*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
263*b1cdbd2cSJim Jagielski //	XControlContainer
264*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
265*b1cdbd2cSJim Jagielski 
addControl(const OUString & rName,const Reference<XControl> & rControl)266*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::addControl ( const OUString& rName, const Reference< XControl > & rControl ) throw( RuntimeException )
267*b1cdbd2cSJim Jagielski {
268*b1cdbd2cSJim Jagielski 	if ( !rControl.is () )
269*b1cdbd2cSJim Jagielski         return;
270*b1cdbd2cSJim Jagielski 
271*b1cdbd2cSJim Jagielski 	// take memory for new item
272*b1cdbd2cSJim Jagielski 	IMPL_ControlInfo* pNewControl = new IMPL_ControlInfo ;
273*b1cdbd2cSJim Jagielski 
274*b1cdbd2cSJim Jagielski 	if (pNewControl!=(IMPL_ControlInfo*)0)
275*b1cdbd2cSJim Jagielski 	{
276*b1cdbd2cSJim Jagielski 		// Ready for multithreading
277*b1cdbd2cSJim Jagielski 		MutexGuard aGuard (m_aMutex) ;
278*b1cdbd2cSJim Jagielski 
279*b1cdbd2cSJim Jagielski 		// set control
280*b1cdbd2cSJim Jagielski 		pNewControl->sName		= rName 	;
281*b1cdbd2cSJim Jagielski 		pNewControl->xControl	= rControl	;
282*b1cdbd2cSJim Jagielski 
283*b1cdbd2cSJim Jagielski 		// and insert in list
284*b1cdbd2cSJim Jagielski 		m_pControlInfoList->Insert ( pNewControl, LIST_APPEND ) ;
285*b1cdbd2cSJim Jagielski 
286*b1cdbd2cSJim Jagielski 		// initialize new control
287*b1cdbd2cSJim Jagielski 		pNewControl->xControl->setContext		( (OWeakObject*)this	) ;
288*b1cdbd2cSJim Jagielski 		pNewControl->xControl->addEventListener	( static_cast< XEventListener* >( static_cast< XWindowListener* >( this ) ) ) ;
289*b1cdbd2cSJim Jagielski 
290*b1cdbd2cSJim Jagielski 		// when container has a peer ...
291*b1cdbd2cSJim Jagielski 		if (getPeer().is())
292*b1cdbd2cSJim Jagielski 		{
293*b1cdbd2cSJim Jagielski 			// .. then create a peer on child
294*b1cdbd2cSJim Jagielski 			pNewControl->xControl->createPeer ( getPeer()->getToolkit(), getPeer() ) ;
295*b1cdbd2cSJim Jagielski 			impl_activateTabControllers () ;
296*b1cdbd2cSJim Jagielski 		}
297*b1cdbd2cSJim Jagielski 
298*b1cdbd2cSJim Jagielski 		// Send message to all listener
299*b1cdbd2cSJim Jagielski 		OInterfaceContainerHelper* pInterfaceContainer = m_aListeners.getContainer( ::getCppuType((const Reference< XContainerListener >*)0) ) ;
300*b1cdbd2cSJim Jagielski 
301*b1cdbd2cSJim Jagielski 		if (pInterfaceContainer)
302*b1cdbd2cSJim Jagielski 		{
303*b1cdbd2cSJim Jagielski 			// Build event
304*b1cdbd2cSJim Jagielski 			ContainerEvent	aEvent ;
305*b1cdbd2cSJim Jagielski 
306*b1cdbd2cSJim Jagielski 			aEvent.Source	= *this		;
307*b1cdbd2cSJim Jagielski 			aEvent.Element <<= rControl ;
308*b1cdbd2cSJim Jagielski 
309*b1cdbd2cSJim Jagielski 			// Get all listener
310*b1cdbd2cSJim Jagielski 			OInterfaceIteratorHelper	aIterator (*pInterfaceContainer) ;
311*b1cdbd2cSJim Jagielski 
312*b1cdbd2cSJim Jagielski 			// Send event
313*b1cdbd2cSJim Jagielski 			while ( aIterator.hasMoreElements() )
314*b1cdbd2cSJim Jagielski 			{
315*b1cdbd2cSJim Jagielski 				((XContainerListener*)aIterator.next())->elementInserted (aEvent) ;
316*b1cdbd2cSJim Jagielski 			}
317*b1cdbd2cSJim Jagielski 		}
318*b1cdbd2cSJim Jagielski 	}
319*b1cdbd2cSJim Jagielski }
320*b1cdbd2cSJim Jagielski 
321*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
322*b1cdbd2cSJim Jagielski //	XControlContainer
323*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
324*b1cdbd2cSJim Jagielski 
addContainerListener(const Reference<XContainerListener> & rListener)325*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::addContainerListener ( const Reference< XContainerListener > & rListener ) throw( RuntimeException )
326*b1cdbd2cSJim Jagielski {
327*b1cdbd2cSJim Jagielski 	// Ready for multithreading
328*b1cdbd2cSJim Jagielski 	MutexGuard aGuard ( m_aMutex ) ;
329*b1cdbd2cSJim Jagielski 
330*b1cdbd2cSJim Jagielski 	m_aListeners.addInterface ( ::getCppuType((const Reference< XContainerListener >*)0), rListener ) ;
331*b1cdbd2cSJim Jagielski }
332*b1cdbd2cSJim Jagielski 
333*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
334*b1cdbd2cSJim Jagielski //	XControlContainer
335*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
336*b1cdbd2cSJim Jagielski 
removeControl(const Reference<XControl> & rControl)337*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::removeControl ( const Reference< XControl > & rControl ) throw( RuntimeException )
338*b1cdbd2cSJim Jagielski {
339*b1cdbd2cSJim Jagielski 	if ( rControl.is() )
340*b1cdbd2cSJim Jagielski 	{
341*b1cdbd2cSJim Jagielski 		// Ready for multithreading
342*b1cdbd2cSJim Jagielski 		MutexGuard aGuard (m_aMutex) ;
343*b1cdbd2cSJim Jagielski 
344*b1cdbd2cSJim Jagielski 		sal_uInt32 nControls = m_pControlInfoList->Count () ;
345*b1cdbd2cSJim Jagielski 
346*b1cdbd2cSJim Jagielski 		for ( sal_uInt32 n=0; n<nControls; n++ )
347*b1cdbd2cSJim Jagielski 		{
348*b1cdbd2cSJim Jagielski 			// Search for right control
349*b1cdbd2cSJim Jagielski 			IMPL_ControlInfo* pControl = m_pControlInfoList->GetObject (n) ;
350*b1cdbd2cSJim Jagielski 			if ( rControl == pControl->xControl )
351*b1cdbd2cSJim Jagielski 			{
352*b1cdbd2cSJim Jagielski 				//.is it found ... remove listener from control
353*b1cdbd2cSJim Jagielski 				pControl->xControl->removeEventListener	(static_cast< XEventListener* >( static_cast< XWindowListener* >( this ) )) ;
354*b1cdbd2cSJim Jagielski 				pControl->xControl->setContext			( Reference< XInterface >  ()	) ;
355*b1cdbd2cSJim Jagielski 
356*b1cdbd2cSJim Jagielski 				// ... free memory
357*b1cdbd2cSJim Jagielski 				delete pControl ;
358*b1cdbd2cSJim Jagielski 				m_pControlInfoList->Remove (n) ;
359*b1cdbd2cSJim Jagielski 
360*b1cdbd2cSJim Jagielski 				// Send message to all other listener
361*b1cdbd2cSJim Jagielski 				OInterfaceContainerHelper * pInterfaceContainer = m_aListeners.getContainer( ::getCppuType((const Reference< XContainerListener >*)0) ) ;
362*b1cdbd2cSJim Jagielski 
363*b1cdbd2cSJim Jagielski 				if (pInterfaceContainer)
364*b1cdbd2cSJim Jagielski 				{
365*b1cdbd2cSJim Jagielski 					ContainerEvent	aEvent ;
366*b1cdbd2cSJim Jagielski 
367*b1cdbd2cSJim Jagielski 					aEvent.Source	 = *this	;
368*b1cdbd2cSJim Jagielski 					aEvent.Element <<= rControl	;
369*b1cdbd2cSJim Jagielski 
370*b1cdbd2cSJim Jagielski 					OInterfaceIteratorHelper	aIterator (*pInterfaceContainer) ;
371*b1cdbd2cSJim Jagielski 
372*b1cdbd2cSJim Jagielski 					while ( aIterator.hasMoreElements() )
373*b1cdbd2cSJim Jagielski 					{
374*b1cdbd2cSJim Jagielski 						((XContainerListener*)aIterator.next())->elementRemoved (aEvent) ;
375*b1cdbd2cSJim Jagielski 					}
376*b1cdbd2cSJim Jagielski 				}
377*b1cdbd2cSJim Jagielski 				// Break "for" !
378*b1cdbd2cSJim Jagielski 				break ;
379*b1cdbd2cSJim Jagielski 			}
380*b1cdbd2cSJim Jagielski 		}
381*b1cdbd2cSJim Jagielski 	}
382*b1cdbd2cSJim Jagielski }
383*b1cdbd2cSJim Jagielski 
384*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
385*b1cdbd2cSJim Jagielski //	XControlContainer
386*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
387*b1cdbd2cSJim Jagielski 
removeContainerListener(const Reference<XContainerListener> & rListener)388*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::removeContainerListener ( const Reference< XContainerListener > & rListener ) throw( RuntimeException )
389*b1cdbd2cSJim Jagielski {
390*b1cdbd2cSJim Jagielski 	// Ready for multithreading
391*b1cdbd2cSJim Jagielski 	MutexGuard aGuard ( m_aMutex ) ;
392*b1cdbd2cSJim Jagielski 
393*b1cdbd2cSJim Jagielski 	m_aListeners.removeInterface ( ::getCppuType((const Reference< XContainerListener >*)0), rListener ) ;
394*b1cdbd2cSJim Jagielski }
395*b1cdbd2cSJim Jagielski 
396*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
397*b1cdbd2cSJim Jagielski //	XControlContainer
398*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
399*b1cdbd2cSJim Jagielski 
setStatusText(const OUString & rStatusText)400*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::setStatusText ( const OUString& rStatusText ) throw( RuntimeException )
401*b1cdbd2cSJim Jagielski {
402*b1cdbd2cSJim Jagielski 	// go down to each parent
403*b1cdbd2cSJim Jagielski 	Reference< XControlContainer > 	xContainer ( getContext(), UNO_QUERY ) ;
404*b1cdbd2cSJim Jagielski 
405*b1cdbd2cSJim Jagielski 	if ( xContainer.is () )
406*b1cdbd2cSJim Jagielski 	{
407*b1cdbd2cSJim Jagielski 		xContainer->setStatusText ( rStatusText ) ;
408*b1cdbd2cSJim Jagielski 	}
409*b1cdbd2cSJim Jagielski }
410*b1cdbd2cSJim Jagielski 
411*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
412*b1cdbd2cSJim Jagielski //	XControlContainer
413*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
414*b1cdbd2cSJim Jagielski 
getControl(const OUString & rName)415*b1cdbd2cSJim Jagielski Reference< XControl > SAL_CALL BaseContainerControl::getControl ( const OUString& rName	) throw( RuntimeException )
416*b1cdbd2cSJim Jagielski {
417*b1cdbd2cSJim Jagielski 	// Ready for multithreading
418*b1cdbd2cSJim Jagielski 	MutexGuard	aGuard ( Mutex::getGlobalMutex() ) ;
419*b1cdbd2cSJim Jagielski 
420*b1cdbd2cSJim Jagielski 	Reference< XControl >  xRetControl	=	Reference< XControl >  		() ;
421*b1cdbd2cSJim Jagielski 	sal_uInt32				nControls	=	m_pControlInfoList->Count	() ;
422*b1cdbd2cSJim Jagielski 
423*b1cdbd2cSJim Jagielski 	// Search for right control
424*b1cdbd2cSJim Jagielski 	for( sal_uInt32 nCount = 0; nCount < nControls; ++nCount )
425*b1cdbd2cSJim Jagielski 	{
426*b1cdbd2cSJim Jagielski 		IMPL_ControlInfo* pSearchControl = m_pControlInfoList->GetObject ( nCount ) ;
427*b1cdbd2cSJim Jagielski 
428*b1cdbd2cSJim Jagielski 		if ( pSearchControl->sName == rName )
429*b1cdbd2cSJim Jagielski 		{
430*b1cdbd2cSJim Jagielski 			// We have found it ...
431*b1cdbd2cSJim Jagielski 			// Break operation and return.
432*b1cdbd2cSJim Jagielski 			return pSearchControl->xControl ;
433*b1cdbd2cSJim Jagielski 		}
434*b1cdbd2cSJim Jagielski 	}
435*b1cdbd2cSJim Jagielski 
436*b1cdbd2cSJim Jagielski 	// We have not found it ... return NULL.
437*b1cdbd2cSJim Jagielski 	return Reference< XControl >  () ;
438*b1cdbd2cSJim Jagielski }
439*b1cdbd2cSJim Jagielski 
440*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
441*b1cdbd2cSJim Jagielski //	XControlContainer
442*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
443*b1cdbd2cSJim Jagielski 
getControls()444*b1cdbd2cSJim Jagielski Sequence< Reference< XControl > > SAL_CALL BaseContainerControl::getControls () throw( RuntimeException )
445*b1cdbd2cSJim Jagielski {
446*b1cdbd2cSJim Jagielski 	// Ready for multithreading
447*b1cdbd2cSJim Jagielski 	MutexGuard	aGuard ( Mutex::getGlobalMutex() ) ;
448*b1cdbd2cSJim Jagielski 
449*b1cdbd2cSJim Jagielski 	sal_uInt32							nControls		= m_pControlInfoList->Count ()	;
450*b1cdbd2cSJim Jagielski 	Sequence< Reference< XControl > >	aDescriptor		( nControls )					;
451*b1cdbd2cSJim Jagielski 	Reference< XControl > *				pDestination	= aDescriptor.getArray ()		;
452*b1cdbd2cSJim Jagielski 	sal_uInt32							nCount			= 0								;
453*b1cdbd2cSJim Jagielski 
454*b1cdbd2cSJim Jagielski 	// Copy controls to sequence
455*b1cdbd2cSJim Jagielski 	for( nCount = 0; nCount < nControls; ++nCount )
456*b1cdbd2cSJim Jagielski 	{
457*b1cdbd2cSJim Jagielski 		IMPL_ControlInfo* pCopyControl = m_pControlInfoList->GetObject ( nCount ) ;
458*b1cdbd2cSJim Jagielski 		pDestination [ nCount ] = pCopyControl->xControl ;
459*b1cdbd2cSJim Jagielski 	}
460*b1cdbd2cSJim Jagielski 
461*b1cdbd2cSJim Jagielski 	// Return sequence
462*b1cdbd2cSJim Jagielski 	return aDescriptor ;
463*b1cdbd2cSJim Jagielski }
464*b1cdbd2cSJim Jagielski 
465*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
466*b1cdbd2cSJim Jagielski //	XUnoControlContainer
467*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
468*b1cdbd2cSJim Jagielski 
addTabController(const Reference<XTabController> & rTabController)469*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::addTabController ( const Reference< XTabController > & rTabController ) throw( RuntimeException )
470*b1cdbd2cSJim Jagielski {
471*b1cdbd2cSJim Jagielski 	// Ready for multithreading
472*b1cdbd2cSJim Jagielski 	MutexGuard aGuard (m_aMutex) ;
473*b1cdbd2cSJim Jagielski 
474*b1cdbd2cSJim Jagielski 	sal_uInt32									nOldCount	= m_xTabControllerList.getLength () ;
475*b1cdbd2cSJim Jagielski 	Sequence< Reference< XTabController >  >	aNewList	( nOldCount + 1 ) 					;
476*b1cdbd2cSJim Jagielski 	sal_uInt32									nCount		= 0									;
477*b1cdbd2cSJim Jagielski 
478*b1cdbd2cSJim Jagielski 	// Copy old elements of sequence to new list.
479*b1cdbd2cSJim Jagielski 	for ( nCount = 0; nCount < nOldCount; ++nCount )
480*b1cdbd2cSJim Jagielski 	{
481*b1cdbd2cSJim Jagielski 		aNewList.getArray () [nCount] = m_xTabControllerList.getConstArray () [nCount] ;
482*b1cdbd2cSJim Jagielski 	}
483*b1cdbd2cSJim Jagielski 
484*b1cdbd2cSJim Jagielski 	// Add new controller
485*b1cdbd2cSJim Jagielski 	aNewList.getArray () [nOldCount] = rTabController ;
486*b1cdbd2cSJim Jagielski 
487*b1cdbd2cSJim Jagielski 	// change old and new list
488*b1cdbd2cSJim Jagielski 	m_xTabControllerList = aNewList ;
489*b1cdbd2cSJim Jagielski }
490*b1cdbd2cSJim Jagielski 
491*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
492*b1cdbd2cSJim Jagielski //	XUnoControlContainer
493*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
494*b1cdbd2cSJim Jagielski 
removeTabController(const Reference<XTabController> & rTabController)495*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::removeTabController ( const Reference< XTabController > & rTabController ) throw( RuntimeException )
496*b1cdbd2cSJim Jagielski {
497*b1cdbd2cSJim Jagielski 	// Ready for multithreading
498*b1cdbd2cSJim Jagielski 	MutexGuard aGuard (m_aMutex) ;
499*b1cdbd2cSJim Jagielski 
500*b1cdbd2cSJim Jagielski 	sal_uInt32	nMaxCount	= m_xTabControllerList.getLength ()	;
501*b1cdbd2cSJim Jagielski 	sal_uInt32	nCount		= 0									;
502*b1cdbd2cSJim Jagielski 
503*b1cdbd2cSJim Jagielski 	// Search right tabcontroller ...
504*b1cdbd2cSJim Jagielski 	for ( nCount = 0; nCount < nMaxCount; ++nCount )
505*b1cdbd2cSJim Jagielski 	{
506*b1cdbd2cSJim Jagielski 		if ( m_xTabControllerList.getConstArray () [nCount] == rTabController )
507*b1cdbd2cSJim Jagielski 		{
508*b1cdbd2cSJim Jagielski 			// ... if is it found ... remove it from list.
509*b1cdbd2cSJim Jagielski 			m_xTabControllerList.getArray()[ nCount ] = Reference< XTabController >() ;
510*b1cdbd2cSJim Jagielski 			break ;
511*b1cdbd2cSJim Jagielski 		}
512*b1cdbd2cSJim Jagielski 	}
513*b1cdbd2cSJim Jagielski }
514*b1cdbd2cSJim Jagielski 
515*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
516*b1cdbd2cSJim Jagielski //	XUnoControlContainer
517*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
518*b1cdbd2cSJim Jagielski 
setTabControllers(const Sequence<Reference<XTabController>> & rTabControllers)519*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::setTabControllers ( const Sequence< Reference< XTabController >  >& rTabControllers ) throw( RuntimeException )
520*b1cdbd2cSJim Jagielski {
521*b1cdbd2cSJim Jagielski 	// Ready for multithreading
522*b1cdbd2cSJim Jagielski 	MutexGuard aGuard (m_aMutex) ;
523*b1cdbd2cSJim Jagielski 
524*b1cdbd2cSJim Jagielski 	m_xTabControllerList = rTabControllers ;
525*b1cdbd2cSJim Jagielski }
526*b1cdbd2cSJim Jagielski 
getTabControllers()527*b1cdbd2cSJim Jagielski Sequence<Reference< XTabController > > SAL_CALL BaseContainerControl::getTabControllers () throw( RuntimeException )
528*b1cdbd2cSJim Jagielski {
529*b1cdbd2cSJim Jagielski 	// Ready for multithreading
530*b1cdbd2cSJim Jagielski 	MutexGuard aGuard (m_aMutex) ;
531*b1cdbd2cSJim Jagielski 
532*b1cdbd2cSJim Jagielski 	return m_xTabControllerList ;
533*b1cdbd2cSJim Jagielski }
534*b1cdbd2cSJim Jagielski 
535*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
536*b1cdbd2cSJim Jagielski //	XWindow
537*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
538*b1cdbd2cSJim Jagielski 
setVisible(sal_Bool bVisible)539*b1cdbd2cSJim Jagielski void SAL_CALL BaseContainerControl::setVisible ( sal_Bool bVisible ) throw( RuntimeException )
540*b1cdbd2cSJim Jagielski {
541*b1cdbd2cSJim Jagielski 	// override baseclass definition
542*b1cdbd2cSJim Jagielski 	BaseControl::setVisible ( bVisible ) ;
543*b1cdbd2cSJim Jagielski 
544*b1cdbd2cSJim Jagielski 	// is it a top window ?
545*b1cdbd2cSJim Jagielski 	if ( !getContext().is() && bVisible )
546*b1cdbd2cSJim Jagielski 	{
547*b1cdbd2cSJim Jagielski 		// then show it automaticly
548*b1cdbd2cSJim Jagielski 		createPeer ( Reference< XToolkit > (), Reference< XWindowPeer > () ) ;
549*b1cdbd2cSJim Jagielski 	}
550*b1cdbd2cSJim Jagielski }
551*b1cdbd2cSJim Jagielski 
552*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
553*b1cdbd2cSJim Jagielski //	protected method
554*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
555*b1cdbd2cSJim Jagielski 
impl_getWindowDescriptor(const Reference<XWindowPeer> & rParentPeer)556*b1cdbd2cSJim Jagielski WindowDescriptor* BaseContainerControl::impl_getWindowDescriptor ( const Reference< XWindowPeer > & rParentPeer )
557*b1cdbd2cSJim Jagielski {
558*b1cdbd2cSJim Jagielski 	// - used from "createPeer()" to set the values of an WindowDescriptor !!!
559*b1cdbd2cSJim Jagielski 	// - if you will change the descriptor-values, you must override thid virtuell function
560*b1cdbd2cSJim Jagielski 	// - the caller must release the memory for this dynamical descriptor !!!
561*b1cdbd2cSJim Jagielski 
562*b1cdbd2cSJim Jagielski 	WindowDescriptor	*	aDescriptor	= new WindowDescriptor ;
563*b1cdbd2cSJim Jagielski 
564*b1cdbd2cSJim Jagielski 	aDescriptor->Type				= WindowClass_CONTAINER								;
565*b1cdbd2cSJim Jagielski 	aDescriptor->WindowServiceName	= OUString(RTL_CONSTASCII_USTRINGPARAM("window"))	;
566*b1cdbd2cSJim Jagielski 	aDescriptor->ParentIndex		= -1												;
567*b1cdbd2cSJim Jagielski 	aDescriptor->Parent				= rParentPeer										;
568*b1cdbd2cSJim Jagielski 	aDescriptor->Bounds				= getPosSize ()										;
569*b1cdbd2cSJim Jagielski 	aDescriptor->WindowAttributes	= 0													;
570*b1cdbd2cSJim Jagielski 
571*b1cdbd2cSJim Jagielski 	return aDescriptor ;
572*b1cdbd2cSJim Jagielski }
573*b1cdbd2cSJim Jagielski 
574*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
575*b1cdbd2cSJim Jagielski //	protected method
576*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
577*b1cdbd2cSJim Jagielski 
impl_paint(sal_Int32,sal_Int32,const Reference<XGraphics> &)578*b1cdbd2cSJim Jagielski void BaseContainerControl::impl_paint ( sal_Int32 /*nX*/, sal_Int32 /*nY*/, const Reference< XGraphics > & /*rGraphics*/ )
579*b1cdbd2cSJim Jagielski {
580*b1cdbd2cSJim Jagielski /*
581*b1cdbd2cSJim Jagielski 	if (rGraphics.is())
582*b1cdbd2cSJim Jagielski 	{
583*b1cdbd2cSJim Jagielski 		for ( sal_uInt32 n=m_pControlInfoList->Count(); n; )
584*b1cdbd2cSJim Jagielski 		{
585*b1cdbd2cSJim Jagielski 			ControlInfo* pSearchControl = m_pControlInfoList->GetObject (--n) ;
586*b1cdbd2cSJim Jagielski 
587*b1cdbd2cSJim Jagielski 			pSearchControl->xControl->paint ( nX, nY, rGraphics ) ;
588*b1cdbd2cSJim Jagielski 		}
589*b1cdbd2cSJim Jagielski 	}
590*b1cdbd2cSJim Jagielski */
591*b1cdbd2cSJim Jagielski }
592*b1cdbd2cSJim Jagielski 
593*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
594*b1cdbd2cSJim Jagielski //	private method
595*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
596*b1cdbd2cSJim Jagielski 
impl_activateTabControllers()597*b1cdbd2cSJim Jagielski void BaseContainerControl::impl_activateTabControllers ()
598*b1cdbd2cSJim Jagielski {
599*b1cdbd2cSJim Jagielski 	// Ready for multithreading
600*b1cdbd2cSJim Jagielski 	MutexGuard aGuard (m_aMutex) ;
601*b1cdbd2cSJim Jagielski 
602*b1cdbd2cSJim Jagielski 	sal_uInt32	nMaxCount	=	m_xTabControllerList.getLength ()	;
603*b1cdbd2cSJim Jagielski 	sal_uInt32	nCount		=	0									;
604*b1cdbd2cSJim Jagielski 
605*b1cdbd2cSJim Jagielski 	for ( nCount = 0; nCount < nMaxCount; ++nCount )
606*b1cdbd2cSJim Jagielski 	{
607*b1cdbd2cSJim Jagielski  		m_xTabControllerList.getArray () [nCount]->setContainer		( this	) ;
608*b1cdbd2cSJim Jagielski  		m_xTabControllerList.getArray () [nCount]->activateTabOrder	(		) ;
609*b1cdbd2cSJim Jagielski 	}
610*b1cdbd2cSJim Jagielski }
611*b1cdbd2cSJim Jagielski 
612*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
613*b1cdbd2cSJim Jagielski //	private method
614*b1cdbd2cSJim Jagielski //____________________________________________________________________________________________________________
615*b1cdbd2cSJim Jagielski 
impl_cleanMemory()616*b1cdbd2cSJim Jagielski void BaseContainerControl::impl_cleanMemory ()
617*b1cdbd2cSJim Jagielski {
618*b1cdbd2cSJim Jagielski 	// Get count of listitems.
619*b1cdbd2cSJim Jagielski 	sal_uInt32	nMaxCount	=	m_pControlInfoList->Count ()	;
620*b1cdbd2cSJim Jagielski 	sal_uInt32	nCount		=	0								;
621*b1cdbd2cSJim Jagielski 
622*b1cdbd2cSJim Jagielski 	// Delete all items.
623*b1cdbd2cSJim Jagielski 	for ( nCount = 0; nCount < nMaxCount; ++nCount )
624*b1cdbd2cSJim Jagielski 	{
625*b1cdbd2cSJim Jagielski 		// Delete everytime first element of list!
626*b1cdbd2cSJim Jagielski 		// We count from 0 to MAX, where "MAX=count of items" BEFORE we delete some elements!
627*b1cdbd2cSJim Jagielski 		// If we use "GetObject ( nCount )" ... it can be, that we have an index greater then count of current elements!
628*b1cdbd2cSJim Jagielski 
629*b1cdbd2cSJim Jagielski 		IMPL_ControlInfo* pSearchControl = m_pControlInfoList->GetObject ( 0 ) ;
630*b1cdbd2cSJim Jagielski 		delete pSearchControl ;
631*b1cdbd2cSJim Jagielski 	}
632*b1cdbd2cSJim Jagielski 
633*b1cdbd2cSJim Jagielski 	// Delete list himself.
634*b1cdbd2cSJim Jagielski 	m_pControlInfoList->Clear () ;
635*b1cdbd2cSJim Jagielski 	delete m_pControlInfoList ;
636*b1cdbd2cSJim Jagielski }
637*b1cdbd2cSJim Jagielski 
638*b1cdbd2cSJim Jagielski } // namespace unocontrols
639