summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--svx/source/form/fmshimp.cxx13
1 files changed, 11 insertions, 2 deletions
diff --git a/svx/source/form/fmshimp.cxx b/svx/source/form/fmshimp.cxx
index 294967c3a36b..bc252580def1 100644
--- a/svx/source/form/fmshimp.cxx
+++ b/svx/source/form/fmshimp.cxx
@@ -4,9 +4,9 @@
*
* $RCSfile: fmshimp.cxx,v $
*
- * $Revision: 1.72 $
+ * $Revision: 1.73 $
*
- * last change: $Author: obo $ $Date: 2006-01-16 15:22:01 $
+ * last change: $Author: obo $ $Date: 2006-01-19 15:40:05 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
@@ -918,6 +918,8 @@ void FmXFormShell::disposing()
m_aMarkTimer.Stop();
}
+ DisableNotification();
+
// we are disposed from within the destructor of our shell, so now the shell pointer is invalid ....
m_pShell = NULL;
m_xActiveController = NULL;
@@ -962,6 +964,9 @@ void FmXFormShell::UpdateSlot( sal_Int16 _nId )
void FmXFormShell::InvalidateSlot( sal_Int16 nId, sal_Bool bWithId )
{
OSL_ENSURE(!FmXFormShell_BASE::rBHelper.bDisposed,"FmXFormShell: Object already disposed!");
+ if ( FmXFormShell_BASE::rBHelper.bDisposed )
+ return /*throw DisposedException()*/ ;
+
::osl::MutexGuard aGuard(m_aInvalidationSafety);
if (m_nLockSlotInvalidation)
{
@@ -3829,6 +3834,10 @@ void FmXFormShell::implAdjustConfigCache()
//------------------------------------------------------------------------
void FmXFormShell::Notify( const com::sun::star::uno::Sequence< rtl::OUString >& _rPropertyNames)
{
+ OSL_ENSURE(!FmXFormShell_BASE::rBHelper.bDisposed,"FmXFormShell: Object already disposed!");
+ if ( FmXFormShell_BASE::rBHelper.bDisposed )
+ return /*throw DisposedException()*/ ;
+
const ::rtl::OUString* pSearch = _rPropertyNames.getConstArray();
const ::rtl::OUString* pSearchTil = pSearch + _rPropertyNames.getLength();
for (;pSearch < pSearchTil; ++pSearch)