xref: /AOO41X/main/sot/source/base/factory.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
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 // MARKER(update_precomp.py): autogen include statement, do not remove
29*cdf0e10cSrcweir #include "precompiled_sot.hxx"
30*cdf0e10cSrcweir 
31*cdf0e10cSrcweir #define _SOT_FACTORY_CXX
32*cdf0e10cSrcweir #define SOT_STRING_LIST
33*cdf0e10cSrcweir 
34*cdf0e10cSrcweir #include <sot/factory.hxx>
35*cdf0e10cSrcweir #include <tools/debug.hxx>
36*cdf0e10cSrcweir #include <tools/string.hxx>
37*cdf0e10cSrcweir #include <sot/object.hxx>
38*cdf0e10cSrcweir #include <sot/sotdata.hxx>
39*cdf0e10cSrcweir #include <sot/clsids.hxx>
40*cdf0e10cSrcweir #include <rtl/instance.hxx>
41*cdf0e10cSrcweir #include <com/sun/star/datatransfer/DataFlavor.hpp>
42*cdf0e10cSrcweir 
43*cdf0e10cSrcweir /************** class SotData_Impl *********************************************/
44*cdf0e10cSrcweir /*************************************************************************
45*cdf0e10cSrcweir |*    SotData_Impl::SotData_Impl
46*cdf0e10cSrcweir |*
47*cdf0e10cSrcweir |*    Beschreibung
48*cdf0e10cSrcweir *************************************************************************/
49*cdf0e10cSrcweir SotData_Impl::SotData_Impl()
50*cdf0e10cSrcweir     : nSvObjCount( 0 )
51*cdf0e10cSrcweir     , pObjectList( NULL )
52*cdf0e10cSrcweir     , pFactoryList( NULL )
53*cdf0e10cSrcweir     , pSotObjectFactory( NULL )
54*cdf0e10cSrcweir     , pSotStorageStreamFactory( NULL )
55*cdf0e10cSrcweir     , pSotStorageFactory( NULL )
56*cdf0e10cSrcweir     , pDataFlavorList( NULL )
57*cdf0e10cSrcweir {
58*cdf0e10cSrcweir }
59*cdf0e10cSrcweir /*************************************************************************
60*cdf0e10cSrcweir |*    SOTDATA()
61*cdf0e10cSrcweir |*
62*cdf0e10cSrcweir |*    Beschreibung
63*cdf0e10cSrcweir *************************************************************************/
64*cdf0e10cSrcweir namespace { struct ImplData : public rtl::Static<SotData_Impl, ImplData> {}; }
65*cdf0e10cSrcweir SotData_Impl * SOTDATA()
66*cdf0e10cSrcweir {
67*cdf0e10cSrcweir 	return &ImplData::get();
68*cdf0e10cSrcweir }
69*cdf0e10cSrcweir 
70*cdf0e10cSrcweir /*************************************************************************
71*cdf0e10cSrcweir |*    SotFactory::DeInit()
72*cdf0e10cSrcweir |*
73*cdf0e10cSrcweir |*    Beschreibung
74*cdf0e10cSrcweir *************************************************************************/
75*cdf0e10cSrcweir void SotFactory::DeInit()
76*cdf0e10cSrcweir {
77*cdf0e10cSrcweir     SotData_Impl * pSotData = SOTDATA();
78*cdf0e10cSrcweir 
79*cdf0e10cSrcweir     if( pSotData->nSvObjCount )
80*cdf0e10cSrcweir     {
81*cdf0e10cSrcweir #ifdef DBG_UTIL
82*cdf0e10cSrcweir 		ByteString aStr( "Objects alive: " );
83*cdf0e10cSrcweir 		aStr.Append( ByteString::CreateFromInt32( pSotData->nSvObjCount ) );
84*cdf0e10cSrcweir         DBG_WARNING(  aStr.GetBuffer()  );
85*cdf0e10cSrcweir 
86*cdf0e10cSrcweir /*
87*cdf0e10cSrcweir         SotObjectList *pObjList = pSotData->pObjectList;
88*cdf0e10cSrcweir 
89*cdf0e10cSrcweir         if( pObjList )
90*cdf0e10cSrcweir         {
91*cdf0e10cSrcweir             SotObject * p = pObjList->First();
92*cdf0e10cSrcweir             while( p )
93*cdf0e10cSrcweir             {
94*cdf0e10cSrcweir                 String aStr( "Factory: " );
95*cdf0e10cSrcweir                 aStr += p->GetSvFactory()->GetClassName();
96*cdf0e10cSrcweir                 aStr += " Count: ";
97*cdf0e10cSrcweir                 aStr += p->GetRefCount();
98*cdf0e10cSrcweir                 DBG_TRACE( "\tReferences:" );
99*cdf0e10cSrcweir                 p->TestObjRef( sal_False );
100*cdf0e10cSrcweir #ifdef TEST_INVARIANT
101*cdf0e10cSrcweir                 DBG_TRACE( "\tInvariant:" );
102*cdf0e10cSrcweir                 p->TestInvariant( sal_True );
103*cdf0e10cSrcweir #endif
104*cdf0e10cSrcweir                 p = pObjList->Next();
105*cdf0e10cSrcweir             }
106*cdf0e10cSrcweir         }
107*cdf0e10cSrcweir */
108*cdf0e10cSrcweir #endif
109*cdf0e10cSrcweir         return;
110*cdf0e10cSrcweir     }
111*cdf0e10cSrcweir 
112*cdf0e10cSrcweir     // Muss von hinten nach vorne zerstoert werden. Das ist die umgekehrte
113*cdf0e10cSrcweir     // Reihenfolge der Erzeugung
114*cdf0e10cSrcweir     SotFactoryList* pFactoryList = pSotData->pFactoryList;
115*cdf0e10cSrcweir     if( pFactoryList )
116*cdf0e10cSrcweir     {
117*cdf0e10cSrcweir         SotFactory * pFact = pFactoryList->Last();
118*cdf0e10cSrcweir         while( NULL != (pFact = pFactoryList->Remove()) )
119*cdf0e10cSrcweir         {
120*cdf0e10cSrcweir             delete pFact;
121*cdf0e10cSrcweir             pFact = pFactoryList->Last();
122*cdf0e10cSrcweir         }
123*cdf0e10cSrcweir         delete pFactoryList;
124*cdf0e10cSrcweir         pSotData->pFactoryList = NULL;
125*cdf0e10cSrcweir     }
126*cdf0e10cSrcweir 
127*cdf0e10cSrcweir     delete pSotData->pObjectList;
128*cdf0e10cSrcweir     pSotData->pObjectList = NULL;
129*cdf0e10cSrcweir 	if( pSotData->pDataFlavorList )
130*cdf0e10cSrcweir 	{
131*cdf0e10cSrcweir 
132*cdf0e10cSrcweir 		for( sal_uLong i = 0, nMax = pSotData->pDataFlavorList->Count(); i < nMax; i++ )
133*cdf0e10cSrcweir 			delete (::com::sun::star::datatransfer::DataFlavor*) pSotData->pDataFlavorList->GetObject( i );
134*cdf0e10cSrcweir 		delete pSotData->pDataFlavorList;
135*cdf0e10cSrcweir 		pSotData->pDataFlavorList = NULL;
136*cdf0e10cSrcweir 	}
137*cdf0e10cSrcweir     //delete pSOTDATA();
138*cdf0e10cSrcweir     //SOTDATA() = NULL;
139*cdf0e10cSrcweir }
140*cdf0e10cSrcweir 
141*cdf0e10cSrcweir 
142*cdf0e10cSrcweir /************** class SotFactory *****************************************/
143*cdf0e10cSrcweir /*************************************************************************
144*cdf0e10cSrcweir |*    SotFactory::SotFactory()
145*cdf0e10cSrcweir |*
146*cdf0e10cSrcweir |*    Beschreibung
147*cdf0e10cSrcweir *************************************************************************/
148*cdf0e10cSrcweir TYPEINIT0(SotFactory);
149*cdf0e10cSrcweir 
150*cdf0e10cSrcweir SotFactory::SotFactory( const SvGlobalName & rName,
151*cdf0e10cSrcweir                       const String & rClassName,
152*cdf0e10cSrcweir                       CreateInstanceType pCreateFuncP )
153*cdf0e10cSrcweir     : SvGlobalName  ( rName )
154*cdf0e10cSrcweir     , nSuperCount   ( 0 )
155*cdf0e10cSrcweir     , pSuperClasses ( NULL )
156*cdf0e10cSrcweir     , pCreateFunc   ( pCreateFuncP )
157*cdf0e10cSrcweir     , aClassName    ( rClassName )
158*cdf0e10cSrcweir {
159*cdf0e10cSrcweir #ifdef DBG_UTIL
160*cdf0e10cSrcweir     SvGlobalName aEmptyName;
161*cdf0e10cSrcweir     if( aEmptyName != *this )
162*cdf0e10cSrcweir     { // wegen Sfx-BasicFactories
163*cdf0e10cSrcweir     DBG_ASSERT( aEmptyName != *this, "create factory without SvGlobalName" );
164*cdf0e10cSrcweir     if( Find( *this ) )
165*cdf0e10cSrcweir     {
166*cdf0e10cSrcweir 		/*
167*cdf0e10cSrcweir         String aStr( GetClassName() );
168*cdf0e10cSrcweir         aStr += ", UniqueName: ";
169*cdf0e10cSrcweir         aStr += GetHexName();
170*cdf0e10cSrcweir         aStr += ", create factories with the same unique name";
171*cdf0e10cSrcweir         DBG_ERROR( aStr );
172*cdf0e10cSrcweir 		*/
173*cdf0e10cSrcweir         DBG_ERROR( "create factories with the same unique name" );
174*cdf0e10cSrcweir     }
175*cdf0e10cSrcweir     }
176*cdf0e10cSrcweir #endif
177*cdf0e10cSrcweir     SotData_Impl * pSotData = SOTDATA();
178*cdf0e10cSrcweir     if( !pSotData->pFactoryList )
179*cdf0e10cSrcweir         pSotData->pFactoryList = new SotFactoryList();
180*cdf0e10cSrcweir     // muss nach hinten, wegen Reihenfolge beim zerstoeren
181*cdf0e10cSrcweir     pSotData->pFactoryList->Insert( this, LIST_APPEND );
182*cdf0e10cSrcweir }
183*cdf0e10cSrcweir 
184*cdf0e10cSrcweir 
185*cdf0e10cSrcweir //=========================================================================
186*cdf0e10cSrcweir SotFactory::~SotFactory()
187*cdf0e10cSrcweir {
188*cdf0e10cSrcweir     delete [] pSuperClasses;
189*cdf0e10cSrcweir }
190*cdf0e10cSrcweir 
191*cdf0e10cSrcweir 
192*cdf0e10cSrcweir /*************************************************************************
193*cdf0e10cSrcweir |*    SotFactory::
194*cdf0e10cSrcweir |*
195*cdf0e10cSrcweir |*    Beschreibung      Zugriffsmethoden auf SotData_Impl-Daten
196*cdf0e10cSrcweir *************************************************************************/
197*cdf0e10cSrcweir sal_uInt32 SotFactory::GetSvObjectCount()
198*cdf0e10cSrcweir {
199*cdf0e10cSrcweir     return SOTDATA()->nSvObjCount;
200*cdf0e10cSrcweir }
201*cdf0e10cSrcweir 
202*cdf0e10cSrcweir 
203*cdf0e10cSrcweir const SotFactoryList * SotFactory::GetFactoryList()
204*cdf0e10cSrcweir {
205*cdf0e10cSrcweir     return SOTDATA()->pFactoryList;
206*cdf0e10cSrcweir }
207*cdf0e10cSrcweir 
208*cdf0e10cSrcweir /*************************************************************************
209*cdf0e10cSrcweir |*    SotFactory::Find()
210*cdf0e10cSrcweir |*
211*cdf0e10cSrcweir |*    Beschreibung
212*cdf0e10cSrcweir *************************************************************************/
213*cdf0e10cSrcweir const SotFactory* SotFactory::Find( const SvGlobalName & rFactName )
214*cdf0e10cSrcweir {
215*cdf0e10cSrcweir     SvGlobalName aEmpty;
216*cdf0e10cSrcweir     SotData_Impl * pSotData = SOTDATA();
217*cdf0e10cSrcweir     if( rFactName != aEmpty && pSotData->pFactoryList )
218*cdf0e10cSrcweir     {
219*cdf0e10cSrcweir         SotFactory * pFact = pSotData->pFactoryList->First();
220*cdf0e10cSrcweir         while( pFact )
221*cdf0e10cSrcweir         {
222*cdf0e10cSrcweir             if( *pFact == rFactName )
223*cdf0e10cSrcweir                 return pFact;
224*cdf0e10cSrcweir             pFact = pSotData->pFactoryList->Next();
225*cdf0e10cSrcweir         }
226*cdf0e10cSrcweir     }
227*cdf0e10cSrcweir 
228*cdf0e10cSrcweir 	return 0;
229*cdf0e10cSrcweir }
230*cdf0e10cSrcweir 
231*cdf0e10cSrcweir /*************************************************************************
232*cdf0e10cSrcweir |*    SotFactory::PutSuperClass()
233*cdf0e10cSrcweir |*
234*cdf0e10cSrcweir |*    Beschreibung
235*cdf0e10cSrcweir *************************************************************************/
236*cdf0e10cSrcweir void SotFactory::PutSuperClass( const SotFactory * pFact )
237*cdf0e10cSrcweir {
238*cdf0e10cSrcweir     nSuperCount++;
239*cdf0e10cSrcweir     if( !pSuperClasses )
240*cdf0e10cSrcweir         pSuperClasses = new const SotFactory * [ nSuperCount ];
241*cdf0e10cSrcweir     else
242*cdf0e10cSrcweir     {
243*cdf0e10cSrcweir         const SotFactory ** pTmp = new const SotFactory * [ nSuperCount ];
244*cdf0e10cSrcweir         memcpy( (void *)pTmp, (void *)pSuperClasses,
245*cdf0e10cSrcweir                 sizeof( void * ) * (nSuperCount -1) );
246*cdf0e10cSrcweir         delete [] pSuperClasses;
247*cdf0e10cSrcweir         pSuperClasses = pTmp;
248*cdf0e10cSrcweir     }
249*cdf0e10cSrcweir     pSuperClasses[ nSuperCount -1 ] = pFact;
250*cdf0e10cSrcweir }
251*cdf0e10cSrcweir 
252*cdf0e10cSrcweir 
253*cdf0e10cSrcweir /*************************************************************************
254*cdf0e10cSrcweir |*    SotFactory::IncSvObjectCount()
255*cdf0e10cSrcweir |*
256*cdf0e10cSrcweir |*    Beschreibung
257*cdf0e10cSrcweir *************************************************************************/
258*cdf0e10cSrcweir void SotFactory::IncSvObjectCount( SotObject * pObj )
259*cdf0e10cSrcweir {
260*cdf0e10cSrcweir     SotData_Impl * pSotData = SOTDATA();
261*cdf0e10cSrcweir     pSotData->nSvObjCount++;
262*cdf0e10cSrcweir     if( !pSotData->pObjectList )
263*cdf0e10cSrcweir         pSotData->pObjectList = new SotObjectList();
264*cdf0e10cSrcweir     if( pObj )
265*cdf0e10cSrcweir         pSotData->pObjectList->Insert( pObj );
266*cdf0e10cSrcweir }
267*cdf0e10cSrcweir 
268*cdf0e10cSrcweir 
269*cdf0e10cSrcweir /*************************************************************************
270*cdf0e10cSrcweir |*    SotFactory::DecSvObjectCount()
271*cdf0e10cSrcweir |*
272*cdf0e10cSrcweir |*    Beschreibung
273*cdf0e10cSrcweir *************************************************************************/
274*cdf0e10cSrcweir void SotFactory::DecSvObjectCount( SotObject * pObj )
275*cdf0e10cSrcweir {
276*cdf0e10cSrcweir     SotData_Impl * pSotData = SOTDATA();
277*cdf0e10cSrcweir     pSotData->nSvObjCount--;
278*cdf0e10cSrcweir     if( pObj )
279*cdf0e10cSrcweir         pSotData->pObjectList->Remove( pObj );
280*cdf0e10cSrcweir     if( !pSotData->nSvObjCount )
281*cdf0e10cSrcweir     {
282*cdf0e10cSrcweir         //keine internen und externen Referenzen mehr
283*cdf0e10cSrcweir     }
284*cdf0e10cSrcweir }
285*cdf0e10cSrcweir 
286*cdf0e10cSrcweir 
287*cdf0e10cSrcweir /*************************************************************************
288*cdf0e10cSrcweir |*    SotFactory::TestInvariant()
289*cdf0e10cSrcweir |*
290*cdf0e10cSrcweir |*    Beschreibung
291*cdf0e10cSrcweir *************************************************************************/
292*cdf0e10cSrcweir void SotFactory::TestInvariant()
293*cdf0e10cSrcweir {
294*cdf0e10cSrcweir #ifdef TEST_INVARIANT
295*cdf0e10cSrcweir     SotData_Impl * pSotData = SOTDATA();
296*cdf0e10cSrcweir     if( pSotData->pObjectList )
297*cdf0e10cSrcweir     {
298*cdf0e10cSrcweir         sal_uLong nCount = pSotData->pObjectList->Count();
299*cdf0e10cSrcweir         for( sal_uLong i = 0; i < nCount ; i++ )
300*cdf0e10cSrcweir         {
301*cdf0e10cSrcweir             pSotData->pObjectList->GetObject( i )->TestInvariant( sal_False );
302*cdf0e10cSrcweir         }
303*cdf0e10cSrcweir     }
304*cdf0e10cSrcweir #endif
305*cdf0e10cSrcweir }
306*cdf0e10cSrcweir 
307*cdf0e10cSrcweir /*************************************************************************
308*cdf0e10cSrcweir |*    SotFactory::CreateInstance()
309*cdf0e10cSrcweir |*
310*cdf0e10cSrcweir |*    Beschreibung
311*cdf0e10cSrcweir *************************************************************************/
312*cdf0e10cSrcweir void * SotFactory::CreateInstance( SotObject ** ppObj ) const
313*cdf0e10cSrcweir {
314*cdf0e10cSrcweir     DBG_ASSERT( pCreateFunc, "SotFactory::CreateInstance: pCreateFunc == 0" );
315*cdf0e10cSrcweir     return pCreateFunc( ppObj );
316*cdf0e10cSrcweir }
317*cdf0e10cSrcweir 
318*cdf0e10cSrcweir //=========================================================================
319*cdf0e10cSrcweir void * SotFactory::CastAndAddRef
320*cdf0e10cSrcweir (
321*cdf0e10cSrcweir     SotObject * pObj /* Das Objekt von dem der Typ gepr"uft wird. */
322*cdf0e10cSrcweir ) const
323*cdf0e10cSrcweir /*  [Beschreibung]
324*cdf0e10cSrcweir 
325*cdf0e10cSrcweir     Ist eine Optimierung, damit die Ref-Klassen k"urzer implementiert
326*cdf0e10cSrcweir     werden k"onnen. pObj wird auf den Typ der Factory gecastet.
327*cdf0e10cSrcweir     In c++ (wenn es immer erlaubt w"are) w"urde der void * wie im
328*cdf0e10cSrcweir     Beispiel gebildet.
329*cdf0e10cSrcweir     Factory der Klasse SvPersist.
330*cdf0e10cSrcweir     void * p = (void *)(SvPersist *)pObj;
331*cdf0e10cSrcweir 
332*cdf0e10cSrcweir     [R"uckgabewert]
333*cdf0e10cSrcweir 
334*cdf0e10cSrcweir     void *,     NULL, pObj war NULL oder das Objekt war nicht vom Typ
335*cdf0e10cSrcweir                 der Factory.
336*cdf0e10cSrcweir                 Ansonsten wird pObj zuerst auf den Typ der Factory
337*cdf0e10cSrcweir                 gecastet und dann auf void *.
338*cdf0e10cSrcweir 
339*cdf0e10cSrcweir     [Querverweise]
340*cdf0e10cSrcweir 
341*cdf0e10cSrcweir     <SotObject::CastAndAddRef>
342*cdf0e10cSrcweir */
343*cdf0e10cSrcweir {
344*cdf0e10cSrcweir     return pObj ? pObj->CastAndAddRef( this ) : NULL;
345*cdf0e10cSrcweir }
346*cdf0e10cSrcweir 
347*cdf0e10cSrcweir /*************************************************************************
348*cdf0e10cSrcweir |*    SotFactory::Is()
349*cdf0e10cSrcweir |*
350*cdf0e10cSrcweir |*    Beschreibung
351*cdf0e10cSrcweir *************************************************************************/
352*cdf0e10cSrcweir sal_Bool SotFactory::Is( const SotFactory * pSuperCl ) const
353*cdf0e10cSrcweir {
354*cdf0e10cSrcweir     if( this == pSuperCl )
355*cdf0e10cSrcweir         return sal_True;
356*cdf0e10cSrcweir 
357*cdf0e10cSrcweir     for( sal_uInt16 i = 0; i < nSuperCount; i++ )
358*cdf0e10cSrcweir     {
359*cdf0e10cSrcweir         if( pSuperClasses[ i ]->Is( pSuperCl ) )
360*cdf0e10cSrcweir             return sal_True;
361*cdf0e10cSrcweir     }
362*cdf0e10cSrcweir     return sal_False;
363*cdf0e10cSrcweir }
364*cdf0e10cSrcweir 
365*cdf0e10cSrcweir 
366*cdf0e10cSrcweir 
367*cdf0e10cSrcweir 
368