update dev300-m58
[ooovba.git] / embeddedobj / source / commonembedding / miscobj.cxx
blob5a2bc87b6ef5c2b7c2d5feb7a9d5c681653a6ae0
1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: miscobj.cxx,v $
10 * $Revision: 1.25 $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
31 // MARKER(update_precomp.py): autogen include statement, do not remove
32 #include "precompiled_embeddedobj.hxx"
34 #include <commonembobj.hxx>
35 #include <com/sun/star/embed/EmbedStates.hpp>
36 #include <com/sun/star/embed/EmbedVerbs.hpp>
37 #include <com/sun/star/embed/XStorage.hpp>
38 #include <com/sun/star/embed/EmbedUpdateModes.hpp>
39 #include <com/sun/star/embed/XInplaceClient.hpp>
40 #include <com/sun/star/lang/DisposedException.hpp>
41 #include <com/sun/star/beans/NamedValue.hpp>
43 #include <cppuhelper/typeprovider.hxx>
44 #include <cppuhelper/interfacecontainer.h>
46 #include "closepreventer.hxx"
47 #include "intercept.hxx"
49 using namespace ::com::sun::star;
52 uno::Sequence< beans::PropertyValue > GetValuableArgs_Impl( const uno::Sequence< beans::PropertyValue >& aMedDescr,
53 sal_Bool bCanUseDocumentBaseURL );
55 //------------------------------------------------------
56 OCommonEmbeddedObject::OCommonEmbeddedObject( const uno::Reference< lang::XMultiServiceFactory >& xFactory,
57 const uno::Sequence< beans::NamedValue >& aObjProps )
58 : m_pDocHolder( NULL )
59 , m_pInterfaceContainer( NULL )
60 , m_bReadOnly( sal_False )
61 , m_bDisposed( sal_False )
62 , m_bClosed( sal_False )
63 , m_nObjectState( -1 )
64 , m_nTargetState( -1 )
65 , m_nUpdateMode ( embed::EmbedUpdateModes::ALWAYS_UPDATE )
66 , m_xFactory( xFactory )
67 , m_nMiscStatus( 0 )
68 , m_bEmbeddedScriptSupport( sal_True )
69 , m_bWaitSaveCompleted( sal_False )
70 , m_bIsLink( sal_False )
71 , m_bLinkHasPassword( sal_False )
72 , m_bHasClonedSize( sal_False )
73 , m_nClonedMapUnit( 0 )
75 CommonInit_Impl( aObjProps );
78 //------------------------------------------------------
79 OCommonEmbeddedObject::OCommonEmbeddedObject(
80 const uno::Reference< lang::XMultiServiceFactory >& xFactory,
81 const uno::Sequence< beans::NamedValue >& aObjProps,
82 const uno::Sequence< beans::PropertyValue >& aMediaDescr,
83 const uno::Sequence< beans::PropertyValue >& aObjectDescr )
84 : m_pDocHolder( NULL )
85 , m_pInterfaceContainer( NULL )
86 , m_bReadOnly( sal_False )
87 , m_bDisposed( sal_False )
88 , m_bClosed( sal_False )
89 , m_nObjectState( embed::EmbedStates::LOADED )
90 , m_nTargetState( -1 )
91 , m_nUpdateMode ( embed::EmbedUpdateModes::ALWAYS_UPDATE )
92 , m_xFactory( xFactory )
93 , m_nMiscStatus( 0 )
94 , m_bEmbeddedScriptSupport( sal_True )
95 , m_bWaitSaveCompleted( sal_False )
96 , m_bIsLink( sal_True )
97 , m_bLinkHasPassword( sal_False )
98 , m_bHasClonedSize( sal_False )
99 , m_nClonedMapUnit( 0 )
101 // linked object has no own persistence so it is in loaded state starting from creation
102 LinkInit_Impl( aObjProps, aMediaDescr, aObjectDescr );
105 //------------------------------------------------------
106 void OCommonEmbeddedObject::CommonInit_Impl( const uno::Sequence< beans::NamedValue >& aObjectProps )
108 OSL_ENSURE( m_xFactory.is(), "No ServiceFactory is provided!\n" );
109 if ( !m_xFactory.is() )
110 throw uno::RuntimeException();
112 m_pDocHolder = new DocumentHolder( m_xFactory, this );
113 m_pDocHolder->acquire();
115 // parse configuration entries
116 // TODO/LATER: in future UI names can be also provided here
117 for ( sal_Int32 nInd = 0; nInd < aObjectProps.getLength(); nInd++ )
119 if ( aObjectProps[nInd].Name.equalsAscii( "ClassID" ) )
120 aObjectProps[nInd].Value >>= m_aClassID;
121 else if ( aObjectProps[nInd].Name.equalsAscii( "ObjectDocumentServiceName" ) )
122 aObjectProps[nInd].Value >>= m_aDocServiceName;
123 else if ( aObjectProps[nInd].Name.equalsAscii( "ObjectDocumentFilterName" ) )
124 aObjectProps[nInd].Value >>= m_aPresetFilterName;
125 else if ( aObjectProps[nInd].Name.equalsAscii( "ObjectMiscStatus" ) )
126 aObjectProps[nInd].Value >>= m_nMiscStatus;
127 else if ( aObjectProps[nInd].Name.equalsAscii( "ObjectVerbs" ) )
128 aObjectProps[nInd].Value >>= m_aObjectVerbs;
131 if ( m_aClassID.getLength() != 16 /*|| !m_aDocServiceName.getLength()*/ )
132 throw uno::RuntimeException(); // something goes really wrong
134 // accepted states
135 m_aAcceptedStates.realloc( NUM_SUPPORTED_STATES );
137 m_aAcceptedStates[0] = embed::EmbedStates::LOADED;
138 m_aAcceptedStates[1] = embed::EmbedStates::RUNNING;
139 m_aAcceptedStates[2] = embed::EmbedStates::INPLACE_ACTIVE;
140 m_aAcceptedStates[3] = embed::EmbedStates::UI_ACTIVE;
141 m_aAcceptedStates[4] = embed::EmbedStates::ACTIVE;
144 // intermediate states
145 // In the following table the first index points to starting state,
146 // the second one to the target state, and the sequence referenced by
147 // first two indexes contains intermediate states, that should be
148 // passed by object to reach the target state.
149 // If the sequence is empty that means that indirect switch from start
150 // state to the target state is forbidden, only if direct switch is possible
151 // the state can be reached.
153 m_pIntermediateStatesSeqs[0][2].realloc( 1 );
154 m_pIntermediateStatesSeqs[0][2][0] = embed::EmbedStates::RUNNING;
156 m_pIntermediateStatesSeqs[0][3].realloc( 2 );
157 m_pIntermediateStatesSeqs[0][3][0] = embed::EmbedStates::RUNNING;
158 m_pIntermediateStatesSeqs[0][3][1] = embed::EmbedStates::INPLACE_ACTIVE;
160 m_pIntermediateStatesSeqs[0][4].realloc( 1 );
161 m_pIntermediateStatesSeqs[0][4][0] = embed::EmbedStates::RUNNING;
163 m_pIntermediateStatesSeqs[1][3].realloc( 1 );
164 m_pIntermediateStatesSeqs[1][3][0] = embed::EmbedStates::INPLACE_ACTIVE;
166 m_pIntermediateStatesSeqs[2][0].realloc( 1 );
167 m_pIntermediateStatesSeqs[2][0][0] = embed::EmbedStates::RUNNING;
169 m_pIntermediateStatesSeqs[3][0].realloc( 2 );
170 m_pIntermediateStatesSeqs[3][0][0] = embed::EmbedStates::INPLACE_ACTIVE;
171 m_pIntermediateStatesSeqs[3][0][1] = embed::EmbedStates::RUNNING;
173 m_pIntermediateStatesSeqs[3][1].realloc( 1 );
174 m_pIntermediateStatesSeqs[3][1][0] = embed::EmbedStates::INPLACE_ACTIVE;
176 m_pIntermediateStatesSeqs[4][0].realloc( 1 );
177 m_pIntermediateStatesSeqs[4][0][0] = embed::EmbedStates::RUNNING;
179 // verbs table
180 sal_Int32 nVerbTableSize = 0;
181 for ( sal_Int32 nVerbInd = 0; nVerbInd < m_aObjectVerbs.getLength(); nVerbInd++ )
183 if ( m_aObjectVerbs[nVerbInd].VerbID == embed::EmbedVerbs::MS_OLEVERB_PRIMARY )
185 m_aVerbTable.realloc( ++nVerbTableSize );
186 m_aVerbTable[nVerbTableSize - 1].realloc( 2 );
187 m_aVerbTable[nVerbTableSize - 1][0] = m_aObjectVerbs[nVerbInd].VerbID;
188 m_aVerbTable[nVerbTableSize - 1][1] = embed::EmbedStates::UI_ACTIVE;
190 else if ( m_aObjectVerbs[nVerbInd].VerbID == embed::EmbedVerbs::MS_OLEVERB_SHOW )
192 m_aVerbTable.realloc( ++nVerbTableSize );
193 m_aVerbTable[nVerbTableSize - 1].realloc( 2 );
194 m_aVerbTable[nVerbTableSize - 1][0] = m_aObjectVerbs[nVerbInd].VerbID;
195 m_aVerbTable[nVerbTableSize - 1][1] = embed::EmbedStates::UI_ACTIVE;
197 else if ( m_aObjectVerbs[nVerbInd].VerbID == embed::EmbedVerbs::MS_OLEVERB_OPEN )
199 m_aVerbTable.realloc( ++nVerbTableSize );
200 m_aVerbTable[nVerbTableSize - 1].realloc( 2 );
201 m_aVerbTable[nVerbTableSize - 1][0] = m_aObjectVerbs[nVerbInd].VerbID;
202 m_aVerbTable[nVerbTableSize - 1][1] = embed::EmbedStates::ACTIVE;
204 else if ( m_aObjectVerbs[nVerbInd].VerbID == embed::EmbedVerbs::MS_OLEVERB_IPACTIVATE )
206 m_aVerbTable.realloc( ++nVerbTableSize );
207 m_aVerbTable[nVerbTableSize - 1].realloc( 2 );
208 m_aVerbTable[nVerbTableSize - 1][0] = m_aObjectVerbs[nVerbInd].VerbID;
209 m_aVerbTable[nVerbTableSize - 1][1] = embed::EmbedStates::INPLACE_ACTIVE;
211 else if ( m_aObjectVerbs[nVerbInd].VerbID == embed::EmbedVerbs::MS_OLEVERB_UIACTIVATE )
213 m_aVerbTable.realloc( ++nVerbTableSize );
214 m_aVerbTable[nVerbTableSize - 1].realloc( 2 );
215 m_aVerbTable[nVerbTableSize - 1][0] = m_aObjectVerbs[nVerbInd].VerbID;
216 m_aVerbTable[nVerbTableSize - 1][1] = embed::EmbedStates::UI_ACTIVE;
218 else if ( m_aObjectVerbs[nVerbInd].VerbID == embed::EmbedVerbs::MS_OLEVERB_HIDE )
220 m_aVerbTable.realloc( ++nVerbTableSize );
221 m_aVerbTable[nVerbTableSize - 1].realloc( 2 );
222 m_aVerbTable[nVerbTableSize - 1][0] = m_aObjectVerbs[nVerbInd].VerbID;
223 m_aVerbTable[nVerbTableSize - 1][1] = embed::EmbedStates::RUNNING;
228 //------------------------------------------------------
229 void OCommonEmbeddedObject::LinkInit_Impl(
230 const uno::Sequence< beans::NamedValue >& aObjectProps,
231 const uno::Sequence< beans::PropertyValue >& aMediaDescr,
232 const uno::Sequence< beans::PropertyValue >& aObjectDescr )
234 // setPersistance has no effect on own links, so the complete initialization must be done here
236 for ( sal_Int32 nInd = 0; nInd < aMediaDescr.getLength(); nInd++ )
237 if ( aMediaDescr[nInd].Name.equalsAscii( "URL" ) )
238 aMediaDescr[nInd].Value >>= m_aLinkURL;
239 else if ( aMediaDescr[nInd].Name.equalsAscii( "FilterName" ) )
240 aMediaDescr[nInd].Value >>= m_aLinkFilterName;
242 OSL_ENSURE( m_aLinkURL.getLength() && m_aLinkFilterName.getLength(), "Filter and URL must be provided!\n" );
244 m_aDocMediaDescriptor = GetValuableArgs_Impl( aMediaDescr, sal_False );
246 uno::Reference< frame::XDispatchProviderInterceptor > xDispatchInterceptor;
247 for ( sal_Int32 nObjInd = 0; nObjInd < aObjectDescr.getLength(); nObjInd++ )
248 if ( aObjectDescr[nObjInd].Name.equalsAscii( "OutplaceDispatchInterceptor" ) )
250 aObjectDescr[nObjInd].Value >>= xDispatchInterceptor;
251 break;
253 else if ( aObjectDescr[nObjInd].Name.equalsAscii( "Parent" ) )
255 aObjectDescr[nObjInd].Value >>= m_xParent;
258 CommonInit_Impl( aObjectProps );
260 if ( xDispatchInterceptor.is() )
261 m_pDocHolder->SetOutplaceDispatchInterceptor( xDispatchInterceptor );
264 //------------------------------------------------------
265 OCommonEmbeddedObject::~OCommonEmbeddedObject()
267 if ( m_pInterfaceContainer || m_pDocHolder )
269 m_refCount++;
270 try {
271 lang::EventObject aSource( static_cast< ::cppu::OWeakObject* >( this ) );
273 if ( m_pInterfaceContainer )
275 m_pInterfaceContainer->disposeAndClear( aSource );
277 delete m_pInterfaceContainer;
278 m_pInterfaceContainer = NULL;
280 } catch( uno::Exception& ) {}
282 try {
283 if ( m_pDocHolder )
285 m_pDocHolder->CloseFrame();
286 try {
287 m_pDocHolder->CloseDocument( sal_True, sal_True );
288 } catch ( uno::Exception& ) {}
289 m_pDocHolder->FreeOffice();
291 m_pDocHolder->release();
292 m_pDocHolder = NULL;
294 } catch( uno::Exception& ) {}
298 //------------------------------------------------------
299 void OCommonEmbeddedObject::requestPositioning( const awt::Rectangle& aRect )
301 // the method is called in case object is inplace active and the object window was resized
303 OSL_ENSURE( m_xClientSite.is(), "The client site must be set for inplace active object!\n" );
304 if ( m_xClientSite.is() )
306 uno::Reference< embed::XInplaceClient > xInplaceClient( m_xClientSite, uno::UNO_QUERY );
308 OSL_ENSURE( xInplaceClient.is(), "The client site must support XInplaceClient to allow inplace activation!\n" );
309 if ( xInplaceClient.is() )
311 try {
312 xInplaceClient->changedPlacement( aRect );
314 catch( uno::Exception& )
316 OSL_ENSURE( sal_False, "Exception on request to resize!\n" );
322 //------------------------------------------------------
323 void OCommonEmbeddedObject::PostEvent_Impl( const ::rtl::OUString& aEventName,
324 const uno::Reference< uno::XInterface >& /*xSource*/ )
326 if ( m_pInterfaceContainer )
328 ::cppu::OInterfaceContainerHelper* pIC = m_pInterfaceContainer->getContainer(
329 ::getCppuType((const uno::Reference< document::XEventListener >*)0) );
330 if( pIC )
332 document::EventObject aEvent;
333 aEvent.EventName = aEventName;
334 aEvent.Source = uno::Reference< uno::XInterface >( static_cast< ::cppu::OWeakObject* >( this ) );
335 // For now all the events are sent as object events
336 // aEvent.Source = ( xSource.is() ? xSource
337 // : uno::Reference< uno::XInterface >( static_cast< ::cppu::OWeakObject* >( this ) ) );
338 ::cppu::OInterfaceIteratorHelper aIt( *pIC );
339 while( aIt.hasMoreElements() )
343 ((document::XEventListener *)aIt.next())->notifyEvent( aEvent );
345 catch( uno::RuntimeException& )
347 aIt.remove();
350 // the listener could dispose the object.
351 if ( m_bDisposed )
352 return;
358 //------------------------------------------------------
359 uno::Any SAL_CALL OCommonEmbeddedObject::queryInterface( const uno::Type& rType )
360 throw( uno::RuntimeException )
362 uno::Any aReturn;
364 aReturn <<= ::cppu::queryInterface(
365 rType,
366 static_cast< embed::XEmbeddedObject* >( this ),
367 static_cast< embed::XInplaceObject* >( this ),
368 static_cast< embed::XVisualObject* >( this ),
369 static_cast< embed::XCommonEmbedPersist* >( static_cast< embed::XEmbedPersist* >( this ) ),
370 static_cast< embed::XEmbedPersist* >( this ),
371 static_cast< embed::XLinkageSupport* >( this ),
372 static_cast< embed::XStateChangeBroadcaster* >( this ),
373 static_cast< embed::XClassifiedObject* >( this ),
374 static_cast< embed::XComponentSupplier* >( this ),
375 static_cast< util::XCloseable* >( this ),
376 static_cast< container::XChild* >( this ),
377 static_cast< document::XEventBroadcaster* >( this ) );
379 if ( aReturn.hasValue() )
380 return aReturn;
381 else
382 return ::cppu::OWeakObject::queryInterface( rType ) ;
386 //------------------------------------------------------
387 void SAL_CALL OCommonEmbeddedObject::acquire()
388 throw()
390 ::cppu::OWeakObject::acquire() ;
393 //------------------------------------------------------
394 void SAL_CALL OCommonEmbeddedObject::release()
395 throw()
397 ::cppu::OWeakObject::release() ;
400 //------------------------------------------------------
401 uno::Sequence< uno::Type > SAL_CALL OCommonEmbeddedObject::getTypes()
402 throw( uno::RuntimeException )
404 static ::cppu::OTypeCollection* pTypeCollection = NULL;
406 if ( !pTypeCollection )
408 ::osl::MutexGuard aGuard( ::osl::Mutex::getGlobalMutex() );
409 if ( !pTypeCollection )
411 if ( m_bIsLink )
413 static ::cppu::OTypeCollection aTypeCollection(
414 ::getCppuType( (const uno::Reference< lang::XTypeProvider >*)NULL ),
415 ::getCppuType( (const uno::Reference< embed::XEmbeddedObject >*)NULL ),
416 ::getCppuType( (const uno::Reference< embed::XInplaceObject >*)NULL ),
417 ::getCppuType( (const uno::Reference< embed::XCommonEmbedPersist >*)NULL ),
418 ::getCppuType( (const uno::Reference< container::XChild >*)NULL ),
419 ::getCppuType( (const uno::Reference< embed::XLinkageSupport >*)NULL ) );
421 pTypeCollection = &aTypeCollection ;
423 else
425 static ::cppu::OTypeCollection aTypeCollection(
426 ::getCppuType( (const uno::Reference< lang::XTypeProvider >*)NULL ),
427 ::getCppuType( (const uno::Reference< embed::XEmbeddedObject >*)NULL ),
428 ::getCppuType( (const uno::Reference< embed::XInplaceObject >*)NULL ),
429 ::getCppuType( (const uno::Reference< embed::XCommonEmbedPersist >*)NULL ),
430 ::getCppuType( (const uno::Reference< container::XChild >*)NULL ),
431 ::getCppuType( (const uno::Reference< embed::XEmbedPersist >*)NULL ) );
433 pTypeCollection = &aTypeCollection ;
438 return pTypeCollection->getTypes() ;
442 //------------------------------------------------------
443 uno::Sequence< sal_Int8 > SAL_CALL OCommonEmbeddedObject::getImplementationId()
444 throw( uno::RuntimeException )
446 static ::cppu::OImplementationId* pID = NULL ;
448 if ( !pID )
450 ::osl::MutexGuard aGuard( ::osl::Mutex::getGlobalMutex() ) ;
451 if ( !pID )
453 static ::cppu::OImplementationId aID( sal_False ) ;
454 pID = &aID ;
458 return pID->getImplementationId() ;
461 //------------------------------------------------------
462 uno::Sequence< sal_Int8 > SAL_CALL OCommonEmbeddedObject::getClassID()
463 throw ( uno::RuntimeException )
465 ::osl::MutexGuard aGuard( m_aMutex );
466 if ( m_bDisposed )
467 throw lang::DisposedException(); // TODO
469 return m_aClassID;
472 //------------------------------------------------------
473 ::rtl::OUString SAL_CALL OCommonEmbeddedObject::getClassName()
474 throw ( uno::RuntimeException )
476 ::osl::MutexGuard aGuard( m_aMutex );
477 if ( m_bDisposed )
478 throw lang::DisposedException(); // TODO
480 return m_aClassName;
483 //------------------------------------------------------
484 void SAL_CALL OCommonEmbeddedObject::setClassInfo(
485 const uno::Sequence< sal_Int8 >& /*aClassID*/, const ::rtl::OUString& /*aClassName*/ )
486 throw ( lang::NoSupportException,
487 uno::RuntimeException )
489 // the object class info can not be changed explicitly
490 throw lang::NoSupportException(); //TODO:
493 //------------------------------------------------------
494 uno::Reference< util::XCloseable > SAL_CALL OCommonEmbeddedObject::getComponent()
495 throw ( uno::RuntimeException )
497 ::osl::MutexGuard aGuard( m_aMutex );
498 if ( m_bDisposed )
499 throw lang::DisposedException(); // TODO
501 // add an exception
502 if ( m_nObjectState == -1 )
504 // the object is still not loaded
505 throw uno::RuntimeException( ::rtl::OUString::createFromAscii( "Can't store object without persistence!\n" ),
506 uno::Reference< uno::XInterface >( static_cast< ::cppu::OWeakObject* >(this) ) );
509 // if ( m_bWaitSaveCompleted )
510 // throw embed::WrongStateException(
511 // ::rtl::OUString::createFromAscii( "The object waits for saveCompleted() call!\n" ),
512 // uno::Reference< uno::XInterface >( reinterpret_cast< ::cppu::OWeakObject* >(this) ) );
514 return uno::Reference< util::XCloseable >( m_pDocHolder->GetComponent(), uno::UNO_QUERY );
517 //----------------------------------------------
518 void SAL_CALL OCommonEmbeddedObject::addStateChangeListener( const uno::Reference< embed::XStateChangeListener >& xListener )
519 throw ( uno::RuntimeException )
521 ::osl::MutexGuard aGuard( m_aMutex );
522 if ( m_bDisposed )
523 throw lang::DisposedException(); // TODO
525 if ( !m_pInterfaceContainer )
526 m_pInterfaceContainer = new ::cppu::OMultiTypeInterfaceContainerHelper( m_aMutex );
528 m_pInterfaceContainer->addInterface( ::getCppuType( (const uno::Reference< embed::XStateChangeListener >*)0 ),
529 xListener );
532 //----------------------------------------------
533 void SAL_CALL OCommonEmbeddedObject::removeStateChangeListener(
534 const uno::Reference< embed::XStateChangeListener >& xListener )
535 throw (uno::RuntimeException)
537 ::osl::MutexGuard aGuard( m_aMutex );
538 if ( m_pInterfaceContainer )
539 m_pInterfaceContainer->removeInterface( ::getCppuType( (const uno::Reference< embed::XStateChangeListener >*)0 ),
540 xListener );
543 //----------------------------------------------
544 void SAL_CALL OCommonEmbeddedObject::close( sal_Bool bDeliverOwnership )
545 throw ( util::CloseVetoException,
546 uno::RuntimeException )
548 ::osl::MutexGuard aGuard( m_aMutex );
549 if ( m_bClosed )
550 throw lang::DisposedException(); // TODO
552 uno::Reference< uno::XInterface > xSelfHold( static_cast< ::cppu::OWeakObject* >( this ) );
553 lang::EventObject aSource( static_cast< ::cppu::OWeakObject* >( this ) );
555 if ( m_pInterfaceContainer )
557 ::cppu::OInterfaceContainerHelper* pContainer =
558 m_pInterfaceContainer->getContainer( ::getCppuType( ( const uno::Reference< util::XCloseListener >*) NULL ) );
559 if ( pContainer != NULL )
561 ::cppu::OInterfaceIteratorHelper pIterator(*pContainer);
562 while (pIterator.hasMoreElements())
566 ((util::XCloseListener*)pIterator.next())->queryClosing( aSource, bDeliverOwnership );
568 catch( uno::RuntimeException& )
570 pIterator.remove();
575 pContainer = m_pInterfaceContainer->getContainer(
576 ::getCppuType( ( const uno::Reference< util::XCloseListener >*) NULL ) );
577 if ( pContainer != NULL )
579 ::cppu::OInterfaceIteratorHelper pCloseIterator(*pContainer);
580 while (pCloseIterator.hasMoreElements())
584 ((util::XCloseListener*)pCloseIterator.next())->notifyClosing( aSource );
586 catch( uno::RuntimeException& )
588 pCloseIterator.remove();
593 m_pInterfaceContainer->disposeAndClear( aSource );
596 m_bDisposed = sal_True; // the object is disposed now for outside
598 // it is possible that the document can not be closed, in this case if the argument is false
599 // the exception will be thrown otherwise in addition to exception the object must register itself
600 // as termination listener and listen for document events
602 if ( m_pDocHolder )
604 m_pDocHolder->CloseFrame();
606 try {
607 m_pDocHolder->CloseDocument( bDeliverOwnership, bDeliverOwnership );
609 catch( uno::Exception& )
611 if ( bDeliverOwnership )
613 m_pDocHolder->release();
614 m_pDocHolder = NULL;
615 m_bClosed = sal_True;
618 throw;
621 m_pDocHolder->FreeOffice();
623 m_pDocHolder->release();
624 m_pDocHolder = NULL;
627 // TODO: for now the storage will be disposed by the object, but after the document
628 // will use the storage, the storage will be disposed by the document and recreated by the object
629 if ( m_xObjectStorage.is() )
631 uno::Reference< lang::XComponent > xComp( m_xObjectStorage, uno::UNO_QUERY );
632 OSL_ENSURE( xComp.is(), "Storage does not support XComponent!\n" );
634 if ( xComp.is() )
636 try {
637 xComp->dispose();
638 } catch ( uno::Exception& ) {}
641 m_xObjectStorage = uno::Reference< embed::XStorage >();
644 m_bClosed = sal_True; // the closing succeeded
647 //----------------------------------------------
648 void SAL_CALL OCommonEmbeddedObject::addCloseListener( const uno::Reference< util::XCloseListener >& xListener )
649 throw ( uno::RuntimeException )
651 ::osl::MutexGuard aGuard( m_aMutex );
652 if ( m_bDisposed )
653 throw lang::DisposedException(); // TODO
655 if ( !m_pInterfaceContainer )
656 m_pInterfaceContainer = new ::cppu::OMultiTypeInterfaceContainerHelper( m_aMutex );
658 m_pInterfaceContainer->addInterface( ::getCppuType( (const uno::Reference< util::XCloseListener >*)0 ), xListener );
661 //----------------------------------------------
662 void SAL_CALL OCommonEmbeddedObject::removeCloseListener( const uno::Reference< util::XCloseListener >& xListener )
663 throw (uno::RuntimeException)
665 ::osl::MutexGuard aGuard( m_aMutex );
666 if ( m_pInterfaceContainer )
667 m_pInterfaceContainer->removeInterface( ::getCppuType( (const uno::Reference< util::XCloseListener >*)0 ),
668 xListener );
671 //------------------------------------------------------
672 void SAL_CALL OCommonEmbeddedObject::addEventListener( const uno::Reference< document::XEventListener >& xListener )
673 throw ( uno::RuntimeException )
675 ::osl::MutexGuard aGuard( m_aMutex );
676 if ( m_bDisposed )
677 throw lang::DisposedException(); // TODO
679 if ( !m_pInterfaceContainer )
680 m_pInterfaceContainer = new ::cppu::OMultiTypeInterfaceContainerHelper( m_aMutex );
682 m_pInterfaceContainer->addInterface( ::getCppuType( (const uno::Reference< document::XEventListener >*)0 ), xListener );
685 //------------------------------------------------------
686 void SAL_CALL OCommonEmbeddedObject::removeEventListener( const uno::Reference< document::XEventListener >& xListener )
687 throw ( uno::RuntimeException )
689 ::osl::MutexGuard aGuard( m_aMutex );
690 if ( m_pInterfaceContainer )
691 m_pInterfaceContainer->removeInterface( ::getCppuType( (const uno::Reference< document::XEventListener >*)0 ),
692 xListener );