/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_forms.hxx" #include "controlfeatureinterception.hxx" #include "urltransformer.hxx" /** === begin UNO includes === **/ /** === end UNO includes === **/ #include //........................................................................ namespace frm { //........................................................................ using namespace ::com::sun::star::uno; using namespace ::com::sun::star::frame; using namespace ::com::sun::star::util; using namespace ::com::sun::star::lang; //==================================================================== //= ControlFeatureInterception //==================================================================== //-------------------------------------------------------------------- ControlFeatureInterception::ControlFeatureInterception( const Reference< XMultiServiceFactory >& _rxORB ) :m_pUrlTransformer( new UrlTransformer( _rxORB ) ) { } //-------------------------------------------------------------------- void SAL_CALL ControlFeatureInterception::registerDispatchProviderInterceptor( const Reference< XDispatchProviderInterceptor >& _rxInterceptor ) throw (RuntimeException ) { if ( !_rxInterceptor.is() ) { DBG_ERROR( "ControlFeatureInterception::registerDispatchProviderInterceptor: invalid interceptor!" ); return; } if ( m_xFirstDispatchInterceptor.is() ) { // there is already an interceptor; the new one will become its master Reference< XDispatchProvider > xFirstProvider( m_xFirstDispatchInterceptor, UNO_QUERY ); _rxInterceptor->setSlaveDispatchProvider( xFirstProvider ); m_xFirstDispatchInterceptor->setMasterDispatchProvider( xFirstProvider ); } // we are the master of the chain's first interceptor m_xFirstDispatchInterceptor = _rxInterceptor; m_xFirstDispatchInterceptor->setMasterDispatchProvider( NULL ); // it's the first of the interceptor chain } //-------------------------------------------------------------------- void SAL_CALL ControlFeatureInterception::releaseDispatchProviderInterceptor( const Reference< XDispatchProviderInterceptor >& _rxInterceptor ) throw (RuntimeException ) { if ( !_rxInterceptor.is() ) { DBG_ERROR( "ControlFeatureInterception::releaseDispatchProviderInterceptor: invalid interceptor!" ); return; } Reference< XDispatchProviderInterceptor > xChainWalk( m_xFirstDispatchInterceptor ); if ( m_xFirstDispatchInterceptor == _rxInterceptor ) { // our chain will have a new first element Reference< XDispatchProviderInterceptor > xSlave( m_xFirstDispatchInterceptor->getSlaveDispatchProvider(), UNO_QUERY ); m_xFirstDispatchInterceptor = xSlave; } // do this before removing the interceptor from the chain as we won't know it's slave afterwards) while ( xChainWalk.is() ) { // walk along the chain of interceptors and look for the interceptor that has to be removed Reference< XDispatchProviderInterceptor > xSlave( xChainWalk->getSlaveDispatchProvider(), UNO_QUERY ); if ( xChainWalk == _rxInterceptor ) { // old master may be an interceptor too Reference< XDispatchProviderInterceptor > xMaster( xChainWalk->getMasterDispatchProvider(), UNO_QUERY ); // unchain the interceptor that has to be removed xChainWalk->setSlaveDispatchProvider( NULL ); xChainWalk->setMasterDispatchProvider( NULL ); // reconnect the chain if ( xMaster.is() ) { xMaster->setSlaveDispatchProvider( Reference< XDispatchProvider >::query( xSlave ) ); } // if somebody has registered the same interceptor twice, then we will remove // it once per call ... break; } xChainWalk = xSlave; } } //-------------------------------------------------------------------- void ControlFeatureInterception::dispose() { // release all interceptors Reference< XDispatchProviderInterceptor > xInterceptor( m_xFirstDispatchInterceptor ); m_xFirstDispatchInterceptor.clear(); while ( xInterceptor.is() ) { // tell the interceptor it has a new (means no) predecessor xInterceptor->setMasterDispatchProvider( NULL ); // ask for it's successor Reference< XDispatchProvider > xSlave = xInterceptor->getSlaveDispatchProvider(); // and give it the new (means no) successoert xInterceptor->setSlaveDispatchProvider( NULL ); // start over with the next chain element xInterceptor = xInterceptor.query( xSlave ); } } //-------------------------------------------------------------------- Reference< XDispatch > ControlFeatureInterception::queryDispatch( const URL& _rURL, const ::rtl::OUString& _rTargetFrameName, ::sal_Int32 _nSearchFlags ) SAL_THROW((RuntimeException)) { Reference< XDispatch > xDispatcher; if ( m_xFirstDispatchInterceptor.is() ) xDispatcher = m_xFirstDispatchInterceptor->queryDispatch( _rURL, _rTargetFrameName, _nSearchFlags ); return xDispatcher; } //-------------------------------------------------------------------- Reference< XDispatch > ControlFeatureInterception::queryDispatch( const URL& _rURL ) SAL_THROW((RuntimeException)) { return queryDispatch( _rURL, ::rtl::OUString(), 0 ); } //-------------------------------------------------------------------- Reference< XDispatch > ControlFeatureInterception::queryDispatch( const sal_Char* _pAsciiURL ) SAL_THROW((RuntimeException)) { return queryDispatch( m_pUrlTransformer->getStrictURLFromAscii( _pAsciiURL ) ); } //........................................................................ } // namespace frm //........................................................................