diff options
-rw-r--r-- | framework/source/helper/statusindicatorfactory.cxx | 44 |
1 files changed, 25 insertions, 19 deletions
diff --git a/framework/source/helper/statusindicatorfactory.cxx b/framework/source/helper/statusindicatorfactory.cxx index 779f37e05a27..fb8e2fcc58ac 100644 --- a/framework/source/helper/statusindicatorfactory.cxx +++ b/framework/source/helper/statusindicatorfactory.cxx @@ -2,9 +2,9 @@ * * $RCSfile: statusindicatorfactory.cxx,v $ * - * $Revision: 1.4 $ + * $Revision: 1.5 $ * - * last change: $Author: cd $ $Date: 2001-10-22 06:48:39 $ + * last change: $Author: as $ $Date: 2001-10-24 14:06:12 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -187,18 +187,13 @@ StatusIndicatorFactory::StatusIndicatorFactory( const css::uno::Reference< css:: , m_xFactory ( xFactory ) , m_xOwner ( xOwner ) , m_xParentWindow ( xParentWindow ) + , m_pStatusBar (NULL) { // Safe impossible cases LOG_ASSERT2( implcp_StatusIndicatorFactory( xFactory, xOwner, xParentWindow ), "StatusIndicatorFactory::StatusIndicatorFactory()", "Invalid parameter detected!" ) try { - { - // Create status indicator window to shared it for all created indictaor objects by this factory. - vos::OGuard aGuard( Application::GetSolarMutex() ); - m_pStatusBar = new StatusBar( VCLUnoHelper::GetWindow( m_xParentWindow ), WB_3DLOOK|WB_BORDER ); - } - m_xParentWindow->addWindowListener( this ); // We must be listener for disposing of our owner frame too. @@ -368,14 +363,6 @@ void SAL_CALL StatusIndicatorFactory::disposing( const css::lang::EventObject& a m_xParentWindow->removeWindowListener( this ); m_xOwner->removeEventListener ( this ); - // Destroy shared status indicator. - // Attention: Don't do it after destroying of parent or indicator window! - // Otherwhise vcl say: "parent with living child destroyed ..." - { - vos::OGuard aGuard( Application::GetSolarMutex() ); - delete m_pStatusBar; - m_pStatusBar = NULL; - } // Let owner, parent and all other references die ... m_xParentWindow = css::uno::Reference< css::awt::XWindow >(); @@ -457,6 +444,14 @@ void StatusIndicatorFactory::start( const css::uno::Reference< css::task::XStatu try { + + { + // Create status indicator window to shared it for all created indictaor objects by this factory. + vos::OGuard aGuard( Application::GetSolarMutex() ); + if( m_pStatusBar == NULL ) + m_pStatusBar = new StatusBar( VCLUnoHelper::GetWindow( m_xParentWindow ), WB_3DLOOK|WB_BORDER ); + } + vos::OGuard aGuard( Application::GetSolarMutex() ); Window* pParentWindow = VCLUnoHelper::GetWindow( m_xParentWindow ); @@ -541,6 +536,14 @@ void StatusIndicatorFactory::end( const css::uno::Reference< css::task::XStatusI } m_pStatusBar->Show( sal_False ); + // Destroy shared status indicator. + // Attention: Don't do it after destroying of parent or indicator window! + // Otherwhise vcl say: "parent with living child destroyed ..." + { + vos::OGuard aGuard( Application::GetSolarMutex() ); + delete m_pStatusBar; + m_pStatusBar = NULL; + } m_xActiveIndicator = css::uno::Reference< css::task::XStatusIndicator >(); } } @@ -695,10 +698,13 @@ void StatusIndicatorFactory::implts_recalcLayout() { vos::OGuard aGuard( Application::GetSolarMutex() ); { - css::awt::Rectangle aParentSize = m_xParentWindow->getPosSize(); - Size aStatusBarSize = m_pStatusBar->GetSizePixel(); + if( m_pStatusBar != NULL ) + { + css::awt::Rectangle aParentSize = m_xParentWindow->getPosSize(); + Size aStatusBarSize = m_pStatusBar->GetSizePixel(); - m_pStatusBar->SetPosSizePixel( 0, aParentSize.Height-aStatusBarSize.Height(), aParentSize.Width, aStatusBarSize.Height() ); + m_pStatusBar->SetPosSizePixel( 0, aParentSize.Height-aStatusBarSize.Height(), aParentSize.Width, aStatusBarSize.Height() ); + } } } catch( css::uno::RuntimeException& ) |