diff options
author | RĂ¼diger Timm <rt@openoffice.org> | 2007-07-25 07:45:54 +0000 |
---|---|---|
committer | RĂ¼diger Timm <rt@openoffice.org> | 2007-07-25 07:45:54 +0000 |
commit | 4f831d7906e41cd9fb1dc57b58236b4b390056c6 (patch) | |
tree | 574e37b7d5bc7b9592c4eecb24bfa03edc955306 /chart2/source/controller/main/UndoCommandDispatch.cxx | |
parent | INTEGRATION: CWS chart07 (1.2.12); FILE MERGED (diff) | |
download | core-4f831d7906e41cd9fb1dc57b58236b4b390056c6.tar.gz core-4f831d7906e41cd9fb1dc57b58236b4b390056c6.zip |
INTEGRATION: CWS chart07 (1.2.12); FILE MERGED
2007/06/26 11:19:05 bm 1.2.12.2: #i78793# fix for (broken) gcc 3.3 for Mac OS/X Panther applied
2007/06/25 12:52:11 bm 1.2.12.1: #i74653# store undo manager at model to be able to do an undo even after inplace re-activation
Diffstat (limited to 'chart2/source/controller/main/UndoCommandDispatch.cxx')
-rw-r--r-- | chart2/source/controller/main/UndoCommandDispatch.cxx | 65 |
1 files changed, 33 insertions, 32 deletions
diff --git a/chart2/source/controller/main/UndoCommandDispatch.cxx b/chart2/source/controller/main/UndoCommandDispatch.cxx index 63b30dd5eac4..9f4203b4a1d9 100644 --- a/chart2/source/controller/main/UndoCommandDispatch.cxx +++ b/chart2/source/controller/main/UndoCommandDispatch.cxx @@ -4,9 +4,9 @@ * * $RCSfile: UndoCommandDispatch.cxx,v $ * - * $Revision: 1.2 $ + * $Revision: 1.3 $ * - * last change: $Author: vg $ $Date: 2007-05-22 18:09:48 $ + * last change: $Author: rt $ $Date: 2007-07-25 08:45:54 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. @@ -39,16 +39,11 @@ #include "UndoCommandDispatch.hxx" #include "macros.hxx" -#ifndef _COM_SUN_STAR_UTIL_XMODIFYBROADCASTER_HPP_ +#include <com/sun/star/chart2/XUndoSupplier.hpp> #include <com/sun/star/util/XModifyBroadcaster.hpp> -#endif -#ifndef _VOS_MUTEX_HXX_ #include <vos/mutex.hxx> -#endif -#ifndef _SV_SVAPP_HXX #include <vcl/svapp.hxx> -#endif // for ressource strings STR_UNDO and STR_REDO #include <sfx2/sfx.hrc> @@ -66,21 +61,25 @@ namespace chart UndoCommandDispatch::UndoCommandDispatch( const Reference< uno::XComponentContext > & xContext, - UndoManager * pUndoManager, const Reference< frame::XModel > & xModel ) : CommandDispatch( xContext ), - m_pUndoManager( pUndoManager ), m_xModel( xModel ) -{} +{ + Reference< chart2::XUndoSupplier > xUndoSupplier( xModel, uno::UNO_QUERY ); + OSL_ASSERT( xUndoSupplier.is()); + if( xUndoSupplier.is()) + m_xUndoManager.set( xUndoSupplier->getUndoManager()); +} UndoCommandDispatch::~UndoCommandDispatch() {} void UndoCommandDispatch::initialize() { - if( m_pUndoManager ) + Reference< util::XModifyBroadcaster > xBroadcaster( m_xUndoManager, uno::UNO_QUERY ); + if( xBroadcaster.is() ) { - m_pUndoManager->addModifyListener( this ); + xBroadcaster->addModifyListener( this ); } } @@ -88,43 +87,45 @@ void UndoCommandDispatch::fireStatusEvent( const OUString & rURL, const Reference< frame::XStatusListener > & xSingleListener /* = 0 */ ) { - if( m_pUndoManager ) + if( m_xUndoManager.is() ) { bool bFireAll = (rURL.getLength() == 0); uno::Any aUndoState, aRedoState; - if( m_pUndoManager->canUndo()) + if( m_xUndoManager->undoPossible()) { - OUString aUndo( String( SchResId( STR_UNDO ))); - aUndoState <<= ( aUndo + m_pUndoManager->getCurrentUndoString()); + // using assignment for broken gcc 3.3 + OUString aUndo = OUString( String( SchResId( STR_UNDO ))); + aUndoState <<= ( aUndo + m_xUndoManager->getCurrentUndoString()); } - if( m_pUndoManager->canRedo()) + if( m_xUndoManager->redoPossible()) { - OUString aRedo( String( SchResId( STR_REDO ))); - aRedoState <<= ( aRedo + m_pUndoManager->getCurrentRedoString()); + // using assignment for broken gcc 3.3 + OUString aRedo = OUString( String( SchResId( STR_REDO ))); + aRedoState <<= ( aRedo + m_xUndoManager->getCurrentRedoString()); } if( bFireAll || rURL.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(".uno:Undo"))) - fireStatusEventForURL( C2U(".uno:Undo"), aUndoState, m_pUndoManager->canUndo(), xSingleListener ); + fireStatusEventForURL( C2U(".uno:Undo"), aUndoState, m_xUndoManager->undoPossible(), xSingleListener ); if( bFireAll || rURL.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(".uno:Redo"))) - fireStatusEventForURL( C2U(".uno:Redo"), aRedoState, m_pUndoManager->canRedo(), xSingleListener ); + fireStatusEventForURL( C2U(".uno:Redo"), aRedoState, m_xUndoManager->redoPossible(), xSingleListener ); } } // ____ XDispatch ____ void SAL_CALL UndoCommandDispatch::dispatch( const util::URL& URL, - const Sequence< beans::PropertyValue >& Arguments ) + const Sequence< beans::PropertyValue >& /* Arguments */ ) throw (uno::RuntimeException) { - if( m_pUndoManager ) + if( m_xUndoManager.is() ) { // why is it necessary to lock the solar mutex here? // /-- ::vos::OGuard aSolarGuard( Application::GetSolarMutex()); if( URL.Path.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "Undo" ))) - m_pUndoManager->undo( m_xModel ); + m_xUndoManager->undo( m_xModel ); else - m_pUndoManager->redo( m_xModel ); + m_xUndoManager->redo( m_xModel ); // \-- } } @@ -133,21 +134,21 @@ void SAL_CALL UndoCommandDispatch::dispatch( /// is called when this is disposed void SAL_CALL UndoCommandDispatch::disposing() { - if( m_pUndoManager ) + Reference< util::XModifyBroadcaster > xBroadcaster( m_xUndoManager, uno::UNO_QUERY ); + if( xBroadcaster.is() ) { - m_pUndoManager->removeModifyListener( this ); - // not owner - m_pUndoManager = 0; + xBroadcaster->removeModifyListener( this ); } + m_xUndoManager.clear(); m_xModel.clear(); } // ____ XEventListener (base of XModifyListener) ____ -void SAL_CALL UndoCommandDispatch::disposing( const lang::EventObject& Source ) +void SAL_CALL UndoCommandDispatch::disposing( const lang::EventObject& /* Source */ ) throw (uno::RuntimeException) { - m_pUndoManager = 0; + m_xUndoManager.clear(); m_xModel.clear(); } |