/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: appopen.cxx,v $ * * $Revision: 1.111 $ * * last change: $Author: hr $ $Date: 2007-06-27 12:54:40 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_sfx2.hxx" #ifndef _COM_SUN_STAR_UNO_REFERENCE_H_ #include #endif #ifndef _COM_SUN_STAR_BEANS_PROPERTYVALUE_HPP_ #include #endif #ifndef _COM_SUN_STAR_FRAME_FRAMESEARCHFLAG_HPP_ #include #endif #ifndef _COM_SUN_STAR_FRAME_XCOMPONENTLOADER_HPP_ #include #endif #ifndef _COM_SUN_STAR_FRAME_XNOTIFYINGDISPATCH_HPP_ #include #endif #ifndef _COM_SUN_STAR_FRAME_XDISPATCHPROVIDER_HPP_ #include #endif #ifndef _COM_SUN_STAR_UTIL_XCLOSEABLE_HPP_ #include #endif #ifndef _COM_SUN_STAR_FRAME_XFRAME_HPP_ #include #endif #ifndef _COM_SUN_STAR_FRAME_XDESKTOP_HPP_ #include #endif #ifndef _COM_SUN_STAR_FRAME_DISPATCHRESULTSTATE_HPP_ #include #endif #ifndef _COM_SUN_STAR_FRAME_XDISPATCHRESULTLISTENER_HPP_ #include #endif #ifndef _COM_SUN_STAR_UTIL_URL_HPP_ #include #endif #ifndef _COM_SUN_STAR_UTIL_XURLTRANSFORMER_HPP_ #include #endif #ifndef _COM_SUN_STAR_SYSTEM_XSYSTEMSHELLEXECUTE_HPP_ #include #endif #ifndef _COM_SUN_STAR_DOCUMENT_XTYPEDETECTION_HPP_ #include #endif #ifndef _COM_SUN_STAR_SYSTEM_SYSTEMSHELLEXECUTEFLAGS_HPP_ #include #endif #ifndef _COM_SUN_STAR_DOCUMENT_MACROEXECMODE_HPP_ #include #endif #ifndef _COM_SUN_STAR_DOCUMENT_UPDATEDOCMODE_HPP_ #include #endif #ifndef _COM_SUN_STAR_TASK_XINTERACTIONREQUEST_HPP_ #include #endif #ifndef _COM_SUN_STAR_TASK_ERRORCODEREQUEST_HPP_ #include #endif #ifndef _COM_SUN_STAR_BEANS_XPROPERTYSET_HPP_ #include #endif #ifndef _COM_SUN_STAR_EMBED_ELEMENTMODES_HPP_ #include #endif #ifndef _COMPHELPER_PROCESSFACTORY_HXX_ #include #endif #ifndef _CPPUHELPER_IMPLBASE1_HXX_ #include #endif #ifndef _COMPHELPER_STORAGEHELPER_HXX_ #include #endif #ifndef _SV_WRKWIN_HXX #include #endif #ifndef _SFXINTITEM_HXX //autogen #include #endif #ifndef _SV_MSGBOX_HXX #include #endif #ifndef _SFXSTRITEM_HXX //autogen #include #endif #ifndef _SFXENUMITEM_HXX //autogen #include #endif #ifndef _SFXDOCTEMPL_HXX //autogen #include #endif #ifndef _SFXECODE_HXX #include #endif #ifndef __FRAMEWORK_INTERACTION_PREVENTDUPLICATEINTERACTION_HXX_ #include #endif #include #include #include #include #ifndef INCLUDED_SVTOOLS_PATHOPTIONS_HXX #include #endif #ifndef INCLUDED_SVTOOLS_MODULEOPTIONS_HXX #include #endif #ifndef _SVTOOLS_TEMPLDLG_HXX #include #endif #ifndef _OSL_FILE_HXX_ #include #endif #include #include #include #include #include #ifndef GCC #endif #include "app.hxx" #include "bindings.hxx" #include "dispatch.hxx" #include "docfile.hxx" #include "docinf.hxx" #include "fcontnr.hxx" #include "new.hxx" #include "objitem.hxx" #include "objsh.hxx" #include "objshimp.hxx" #include "openflag.hxx" #include "passwd.hxx" #include "referers.hxx" #include "request.hxx" #include "sfxresid.hxx" #include "viewsh.hxx" #include "app.hrc" #include "topfrm.hxx" #include "sfxuno.hxx" #include "objface.hxx" #include "filedlghelper.hxx" #include "docfac.hxx" #include "event.hxx" #define _SVSTDARR_STRINGSDTOR #include using namespace ::com::sun::star; using namespace ::com::sun::star::beans; using namespace ::com::sun::star::frame; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::util; using namespace ::com::sun::star::system; using namespace ::com::sun::star::task; using namespace ::cppu; using namespace ::sfx2; namespace css = ::com::sun::star; //========================================================================= class SfxOpenDocStatusListener_Impl : public WeakImplHelper1< XDispatchResultListener > { public: BOOL bFinished; BOOL bSuccess; virtual void SAL_CALL dispatchFinished( const DispatchResultEvent& Event ) throw(RuntimeException); virtual void SAL_CALL disposing( const EventObject& Source ) throw(RuntimeException); SfxOpenDocStatusListener_Impl() : bFinished( FALSE ) , bSuccess( FALSE ) {} }; void SAL_CALL SfxOpenDocStatusListener_Impl::dispatchFinished( const DispatchResultEvent& aEvent ) throw(RuntimeException) { bSuccess = ( aEvent.State == DispatchResultState::SUCCESS ); bFinished = TRUE; } void SAL_CALL SfxOpenDocStatusListener_Impl::disposing( const EventObject& ) throw(RuntimeException) { } SfxObjectShellRef SfxApplication::DocAlreadyLoaded ( const String& rName, // Name des Dokuments mit Pfad BOOL bSilent, // TRUE: nicht nach neuer Sicht fragen BOOL bActivate, // soll bestehende Sicht aktiviert werden BOOL bForbidVisible, const String* pPostStr ) /* [Beschreibung] Stellt fest, ob ein Dokument mit dem Namen 'rName' bereits geladen ist und liefert einen Pointer darauf zu"uck. Ist das Dokument noch nicht geladen, wird ein 0-Pointer zur"uckgeliefert. */ { // zu suchenden Namen als URL aufbereiten INetURLObject aUrlToFind( rName ); DBG_ASSERT( aUrlToFind.GetProtocol() != INET_PROT_NOT_VALID, "Invalid URL" ); String aPostString; if ( pPostStr ) aPostString = *pPostStr; // noch offen? SfxObjectShellRef xDoc; if ( !aUrlToFind.HasError() ) { // dann bei den normal geoeffneten Docs if ( !xDoc.Is() ) { xDoc = SfxObjectShell::GetFirst( 0, FALSE ); // auch hidden Docs while( xDoc.Is() ) { if ( xDoc->GetMedium() && xDoc->GetCreateMode() == SFX_CREATE_MODE_STANDARD && !xDoc->IsAbortingImport() && !xDoc->IsLoading() ) { // Vergleiche anhand der URLs INetURLObject aUrl( xDoc->GetMedium()->GetName() ); if ( !aUrl.HasError() && aUrl == aUrlToFind && (!bForbidVisible || !SfxViewFrame::GetFirst( xDoc, 0, TRUE )) && !xDoc->IsLoading()) { break; } } xDoc = SfxObjectShell::GetNext( *xDoc, 0, FALSE ); } } } // gefunden? if ( xDoc.Is() && bActivate ) { DBG_ASSERT( !bForbidVisible, "Unsichtbares kann nicht aktiviert werden" ); SfxTopViewFrame *pFrame; for( pFrame = (SfxTopViewFrame*) SfxViewFrame::GetFirst( xDoc, TYPE(SfxTopViewFrame) ); pFrame && !pFrame->IsVisible_Impl(); pFrame = (SfxTopViewFrame*) SfxViewFrame::GetNext( *pFrame, xDoc, TYPE(SfxTopViewFrame) ) ); if ( pFrame ) { SfxViewFrame *pCur = SfxViewFrame::Current(); if ( !bSilent && pFrame == pCur ) InfoBox( 0, SfxResId(RID_DOCALREADYLOADED_DLG)).Execute(); if ( bActivate ) { pFrame->MakeActive_Impl( TRUE ); } } } return xDoc; } //==================================================================== void SetTemplate_Impl( const String &rFileName, const String &rLongName, SfxObjectShell *pDoc) { // write TemplateName to DocumentInfo of document // TemplateDate stays as default (=current date) SfxDocumentInfo &rInfo = pDoc->GetDocInfo(); rInfo.ResetFromTemplate( rLongName, rFileName ); pDoc->FlushDocInfo(); } //-------------------------------------------------------------------- ULONG CheckPasswd_Impl ( //Window *pWin, // Parent des Dialogs SfxObjectShell* pDoc, SfxItemPool& /*rPool*/, // Pool, falls ein Set erzeugt werden mus SfxMedium* pFile // das Medium, dessen Passwort gfs. erfragt werden soll ) /* [Beschreibung] Zu einem Medium das Passwort erfragen; funktioniert nur, wenn es sich um einen Storage handelt. Wenn in der Documentinfo das Passwort-Flag gesetzt ist, wird das Passwort vom Benutzer per Dialog erfragt und an dem Set des Mediums gesetzt; das Set wird, wenn nicht vorhanden, erzeugt. */ { ULONG nRet = ERRCODE_NONE; if( ( !pFile->GetFilter() || pFile->IsStorage() ) ) { uno::Reference< embed::XStorage > xStorage = pFile->GetStorage(); if( xStorage.is() ) { uno::Reference< beans::XPropertySet > xStorageProps( xStorage, uno::UNO_QUERY ); if ( xStorageProps.is() ) { sal_Bool bIsEncrypted = sal_False; try { xStorageProps->getPropertyValue( ::rtl::OUString::createFromAscii("HasEncryptedEntries") ) >>= bIsEncrypted; } catch( uno::Exception& ) { // TODO/LATER: // the storage either has no encrypted elements or it's just // does not allow to detect it, probably it should be implemented laiter /* SfxDocumentInfo aInfo; bIsEncrypted = ( aInfo.Load( xStorage ) && aInfo.IsPasswd() ); */ } if ( bIsEncrypted ) { Window* pWin = pDoc ? pDoc->GetDialogParent( pFile ) : NULL; if ( pWin ) pWin->Show(); nRet = ERRCODE_SFX_CANTGETPASSWD; SfxItemSet *pSet = pFile->GetItemSet(); if( pSet ) { Reference< ::com::sun::star::task::XInteractionHandler > xInteractionHandler = pFile->GetInteractionHandler(); if( xInteractionHandler.is() ) { RequestDocumentPassword* pPasswordRequest = new RequestDocumentPassword( ::com::sun::star::task::PasswordRequestMode_PASSWORD_ENTER, INetURLObject( pFile->GetOrigURL() ).GetName( INetURLObject::DECODE_WITH_CHARSET ) ); Reference< XInteractionRequest > rRequest( pPasswordRequest ); xInteractionHandler->handle( rRequest ); if ( pPasswordRequest->isPassword() ) { pSet->Put( SfxStringItem( SID_PASSWORD, pPasswordRequest->getPassword() ) ); try { ::comphelper::OStorageHelper::SetCommonStoragePassword( xStorage, pPasswordRequest->getPassword() ); // update the version list of the medium using the new password pFile->GetVersionList(); } catch( uno::Exception& ) { // TODO/LATER: set the error code } nRet = ERRCODE_NONE; } else nRet = ERRCODE_IO_ABORT; } } } } else { OSL_ENSURE( sal_False, "A storage must implement XPropertySet interface!" ); nRet = ERRCODE_SFX_CANTGETPASSWD; } } } return nRet; } //-------------------------------------------------------------------- ULONG SfxApplication::LoadTemplate( SfxObjectShellLock& xDoc, const String &rFileName, BOOL bCopy, SfxItemSet* pSet ) { const SfxFilter* pFilter = NULL; SfxMedium aMedium( rFileName, ( STREAM_READ | STREAM_SHARE_DENYNONE ), FALSE ); if ( !aMedium.GetStorage().is() ) aMedium.GetInStream(); if ( aMedium.GetError() ) { delete pSet; return aMedium.GetErrorCode(); } aMedium.UseInteractionHandler( TRUE ); ULONG nErr = GetFilterMatcher().GuessFilter( aMedium,&pFilter,SFX_FILTER_TEMPLATE, 0 ); if ( 0 != nErr) { delete pSet; return ERRCODE_SFX_NOTATEMPLATE; } if( !pFilter || !pFilter->IsAllowedAsTemplate() ) { delete pSet; return ERRCODE_SFX_NOTATEMPLATE; } if ( pFilter->GetFilterFlags() & SFX_FILTER_STARONEFILTER ) { DBG_ASSERT( !xDoc.Is(), "Sorry, not implemented!" ); delete pSet; SfxStringItem aName( SID_FILE_NAME, rFileName ); SfxStringItem aReferer( SID_REFERER, String::CreateFromAscii("private:user") ); SfxStringItem aFlags( SID_OPTIONS, String::CreateFromAscii("T") ); SfxBoolItem aHidden( SID_HIDDEN, TRUE ); const SfxPoolItem *pRet = GetDispatcher_Impl()->Execute( SID_OPENDOC, SFX_CALLMODE_SYNCHRON, &aName, &aHidden, &aReferer, &aFlags, 0L ); const SfxObjectItem *pObj = PTR_CAST( SfxObjectItem, pRet ); if ( pObj ) xDoc = PTR_CAST( SfxObjectShell, pObj->GetShell() ); else { const SfxViewFrameItem *pView = PTR_CAST( SfxViewFrameItem, pRet ); if ( pView ) { SfxViewFrame *pFrame = pView->GetFrame(); if ( pFrame ) xDoc = pFrame->GetObjectShell(); } } if ( !xDoc.Is() ) return ERRCODE_SFX_DOLOADFAILED; } else { if ( !xDoc.Is() ) xDoc = SfxObjectShell::CreateObject( pFilter->GetServiceName() ); SfxMedium *pMedium = new SfxMedium( rFileName, STREAM_STD_READ, FALSE, pFilter, pSet ); if(!xDoc->DoLoad(pMedium)) { ErrCode nErrCode = xDoc->GetErrorCode(); xDoc->DoClose(); xDoc.Clear(); return nErrCode; } } if( bCopy ) { try { // TODO: introduce error handling uno::Reference< embed::XStorage > xTempStorage = ::comphelper::OStorageHelper::GetTemporaryStorage(); if( !xTempStorage.is() ) throw uno::RuntimeException(); xDoc->GetStorage()->copyToStorage( xTempStorage ); //REMOVE // the following operations should be done in one step //REMOVE xDoc->DoHandsOff(); if ( !xDoc->DoSaveCompleted( new SfxMedium( xTempStorage, String() ) ) ) throw uno::RuntimeException(); } catch( uno::Exception& ) { xDoc->DoClose(); xDoc.Clear(); // TODO: transfer correct error outside return ERRCODE_SFX_GENERAL; } SetTemplate_Impl( rFileName, String(), xDoc ); } else SetTemplate_Impl( rFileName, String(), xDoc ); xDoc->Broadcast( SfxDocumentInfoHint( &xDoc->GetDocInfo() ) ); xDoc->SetNoName(); xDoc->InvalidateName(); xDoc->SetModified(FALSE); xDoc->ResetError(); ::com::sun::star::uno::Reference< ::com::sun::star::frame::XModel > xModel ( xDoc->GetModel(), ::com::sun::star::uno::UNO_QUERY ); if ( xModel.is() ) { SfxItemSet* pNew = xDoc->GetMedium()->GetItemSet()->Clone(); pNew->ClearItem( SID_PROGRESS_STATUSBAR_CONTROL ); pNew->ClearItem( SID_FILTER_NAME ); //pNew->Put( SfxStringItem( SID_FILTER_NAME, xDoc->GetFactory().GetFilter(0)->GetFilterName() ) ); ::com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue > aArgs; TransformItems( SID_OPENDOC, *pNew, aArgs ); sal_Int32 nLength = aArgs.getLength(); aArgs.realloc( nLength + 1 ); aArgs[nLength].Name = DEFINE_CONST_UNICODE("Title"); aArgs[nLength].Value <<= ::rtl::OUString( xDoc->GetTitle( SFX_TITLE_DETECT ) ); xModel->attachResource( ::rtl::OUString(), aArgs ); delete pNew; } return xDoc->GetErrorCode(); } //-------------------------------------------------------------------- SfxObjectShellLock SfxApplication::NewDoc_Impl( const String& rFact, const SfxItemSet *pSet ) { SfxObjectShellLock xDoc; String aFact( rFact ); String aPrefix = String::CreateFromAscii( "private:factory/" ); if ( aPrefix.Len() == aFact.Match( aPrefix ) ) aFact.Erase( 0, aPrefix.Len() ); USHORT nPos = aFact.Search( '?' ); String aParam; if ( nPos != STRING_NOTFOUND ) { aParam = aFact.Copy( nPos, aFact.Len() ); aFact.Erase( nPos, aFact.Len() ); aParam.Erase(0,1); } xDoc = SfxObjectShell::CreateObjectByFactoryName( aFact ); aParam = INetURLObject::decode( aParam, '%', INetURLObject::DECODE_WITH_CHARSET ); if( xDoc.Is() ) xDoc->DoInitNew_Impl( aParam ); if ( xDoc.Is() ) { if ( pSet ) { SFX_ITEMSET_ARG( pSet, pTitleItem, SfxStringItem, SID_DOCINFO_TITLE, FALSE ); if ( pTitleItem ) xDoc->GetMedium()->GetItemSet()->Put( *pTitleItem ); } ::com::sun::star::uno::Reference< ::com::sun::star::frame::XModel > xModel ( xDoc->GetModel(), ::com::sun::star::uno::UNO_QUERY ); if ( xModel.is() ) { SfxItemSet* pNew = xDoc->GetMedium()->GetItemSet()->Clone(); pNew->ClearItem( SID_PROGRESS_STATUSBAR_CONTROL ); ::com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue > aArgs; TransformItems( SID_OPENDOC, *pNew, aArgs ); sal_Int32 nLength = aArgs.getLength(); aArgs.realloc( nLength + 1 ); aArgs[nLength].Name = DEFINE_CONST_UNICODE("Title"); aArgs[nLength].Value <<= ::rtl::OUString( xDoc->GetTitle( SFX_TITLE_DETECT ) ); xModel->attachResource( ::rtl::OUString(), aArgs ); delete pNew; } } return xDoc; } void SfxApplication::NewDocDirectExec_Impl( SfxRequest& rReq ) { DBG_MEMTEST(); SFX_REQUEST_ARG( rReq, pFactoryItem, SfxStringItem, SID_NEWDOCDIRECT, FALSE); String aFactName; if ( pFactoryItem ) aFactName = pFactoryItem->GetValue(); else aFactName = SvtModuleOptions().GetDefaultModuleName(); SfxRequest aReq( SID_OPENDOC, SFX_CALLMODE_SYNCHRON, GetPool() ); String aFact = String::CreateFromAscii("private:factory/"); aFact += aFactName; aReq.AppendItem( SfxStringItem( SID_FILE_NAME, aFact ) ); aReq.AppendItem( SfxFrameItem( SID_DOCFRAME, GetFrame() ) ); aReq.AppendItem( SfxStringItem( SID_TARGETNAME, String::CreateFromAscii( "_default" ) ) ); SFX_APP()->ExecuteSlot( aReq ); const SfxViewFrameItem* pItem = PTR_CAST( SfxViewFrameItem, aReq.GetReturnValue() ); if ( pItem ) rReq.SetReturnValue( SfxFrameItem( 0, pItem->GetFrame() ) ); } const SfxPoolItem* SfxApplication::NewDocDirectExec_ImplOld( SfxRequest& rReq ) { DBG_MEMTEST(); /* SFX_REQUEST_ARG(rReq, pHidden, SfxBoolItem, SID_HIDDEN, FALSE); //(mba)/task if ( !pHidden || !pHidden->GetValue() ) Application::GetAppWindow()->EnterWait(); */ SfxObjectShellLock xDoc; // Factory-RegNo kann per Parameter angegeben sein SfxErrorContext aEc(ERRCTX_SFX_NEWDOCDIRECT); rReq.GetArgs(); // -Wall required?? String aFactory; rReq.AppendItem( SfxBoolItem( SID_TEMPLATE, TRUE ) ); SFX_REQUEST_ARG( rReq, pFactoryName, SfxStringItem, SID_NEWDOCDIRECT, FALSE ); if( pFactoryName ) aFactory = pFactoryName->GetValue(); else aFactory = SvtModuleOptions().GetDefaultModuleName(); SFX_REQUEST_ARG( rReq, pFileFlagsItem, SfxStringItem, SID_OPTIONS, FALSE); if ( pFileFlagsItem ) { // Werte auf einzelne Items verteilen String aFileFlags = pFileFlagsItem->GetValue(); aFileFlags.ToUpperAscii(); if ( STRING_NOTFOUND != aFileFlags.Search( 0x0054 ) ) // T = 54h rReq.AppendItem( SfxBoolItem( SID_TEMPLATE, TRUE ) ); if ( STRING_NOTFOUND != aFileFlags.Search( 0x0048 ) ) // H = 48h rReq.AppendItem( SfxBoolItem( SID_HIDDEN, TRUE ) ); if ( STRING_NOTFOUND != aFileFlags.Search( 0x0052 ) ) // R = 52h rReq.AppendItem( SfxBoolItem( SID_DOC_READONLY, TRUE ) ); if ( STRING_NOTFOUND != aFileFlags.Search( 0x0042 ) ) // B = 42h rReq.AppendItem( SfxBoolItem( SID_PREVIEW, TRUE ) ); if ( STRING_NOTFOUND != aFileFlags.Search( 0x0053 ) ) // S = 53h rReq.AppendItem( SfxBoolItem( SID_SILENT, TRUE ) ); } xDoc = NewDoc_Impl( aFactory, rReq.GetArgs() ); if ( xDoc.Is() ) { SFX_REQUEST_ARG(rReq, pReadonly, SfxBoolItem, SID_DOC_READONLY, FALSE); if ( pReadonly ) xDoc->GetMedium()->GetItemSet()->Put( *pReadonly ); SFX_REQUEST_ARG(rReq, pPreview, SfxBoolItem, SID_PREVIEW, FALSE); if ( pPreview ) xDoc->GetMedium()->GetItemSet()->Put( *pPreview ); SFX_REQUEST_ARG(rReq, pSilent, SfxBoolItem, SID_SILENT, FALSE); if ( pSilent ) xDoc->GetMedium()->GetItemSet()->Put( *pSilent ); SFX_REQUEST_ARG(rReq, pFlags, SfxStringItem, SID_OPTIONS, FALSE); if ( pFlags ) xDoc->GetMedium()->GetItemSet()->Put( *pFlags ); } // View erzeugen if ( xDoc.Is() ) { SFX_REQUEST_ARG(rReq, pHidden, SfxBoolItem, SID_HIDDEN, FALSE); BOOL bHidden = FALSE; if ( pHidden ) { xDoc->GetMedium()->GetItemSet()->Put( *pHidden, SID_HIDDEN ); bHidden = pHidden->GetValue(); } SFX_REQUEST_ARG(rReq, pViewId, SfxUInt16Item, SID_VIEW_ID, FALSE); USHORT nViewId = 0; if ( pViewId ) { xDoc->GetMedium()->GetItemSet()->Put( *pViewId, SID_VIEW_ID ); nViewId = pViewId->GetValue(); } xDoc->SetActivateEvent_Impl( SFX_EVENT_CREATEDOC ); // xDoc->Get_Impl()->nLoadedFlags = SFX_LOADED_ALL; const SfxItemSet* pInternalArgs = rReq.GetInternalArgs_Impl(); if( pInternalArgs ) xDoc->GetMedium()->GetItemSet()->Put( *pInternalArgs ); SFX_REQUEST_ARG(rReq, pFrameItem, SfxFrameItem, SID_DOCFRAME, FALSE); SfxFrame* pFrame = NULL; if (pFrameItem) pFrame = pFrameItem->GetFrame(); else pFrame = (SfxFrame*)SfxTopFrame::Create(xDoc, nViewId, bHidden, pInternalArgs); if ( pFrame ) { if ( pFrame->GetCurrentDocument() == xDoc || pFrame->PrepareClose_Impl( TRUE, TRUE ) == TRUE ) { if ( bHidden ) { xDoc->RestoreNoDelete(); xDoc->OwnerLock( TRUE ); xDoc->Get_Impl()->bHiddenLockedByAPI = TRUE; } if ( pFrame->GetCurrentDocument() != xDoc ) { if ( pFrame->InsertDocument( xDoc ) ) rReq.SetReturnValue( SfxFrameItem( 0, pFrame ) ); else xDoc->DoClose(); } } else xDoc.Clear(); } } return rReq.GetReturnValue(); //(mba)/task /* if ( !pHidden || !pHidden->GetValue() ) Application::GetAppWindow()->LeaveWait(); */ } //-------------------------------------------------------------------- void SfxApplication::NewDocExec_Impl( SfxRequest& rReq ) { DBG_MEMTEST(); // keine Parameter vom BASIC nur Factory angegeben? SFX_REQUEST_ARG(rReq, pTemplNameItem, SfxStringItem, SID_TEMPLATE_NAME, FALSE); SFX_REQUEST_ARG(rReq, pTemplFileNameItem, SfxStringItem, SID_FILE_NAME, FALSE); SFX_REQUEST_ARG(rReq, pTemplRegionNameItem, SfxStringItem, SID_TEMPLATE_REGIONNAME, FALSE); SfxObjectShellLock xDoc; String aTemplateRegion, aTemplateName, aTemplateFileName; BOOL bDirect = FALSE; // "uber FileName anstelle Region/Template SfxErrorContext aEc(ERRCTX_SFX_NEWDOC); if ( !pTemplNameItem && !pTemplFileNameItem ) { Window* pTopWin = GetTopWindow(); SvtDocumentTemplateDialog* pDocTemplDlg = new SvtDocumentTemplateDialog( NULL ); int nRet = pDocTemplDlg->Execute(); sal_Bool bNewWin = sal_False; if ( nRet == RET_OK ) { rReq.Done(); if ( pTopWin != GetTopWindow() ) { // the dialogue opens a document -> a new TopWindow appears pTopWin = GetTopWindow(); bNewWin = sal_True; } } delete pDocTemplDlg; if ( bNewWin && pTopWin ) // after the destruction of the dialogue its parent comes to top, // but we want that the new document is on top pTopWin->ToTop(); return; } else { // Template-Name if ( pTemplNameItem ) aTemplateName = pTemplNameItem->GetValue(); // Template-Region if ( pTemplRegionNameItem ) aTemplateRegion = pTemplRegionNameItem->GetValue(); // Template-File-Name if ( pTemplFileNameItem ) { aTemplateFileName = pTemplFileNameItem->GetValue(); bDirect = TRUE; } } ULONG lErr = 0; SfxItemSet* pSet = new SfxAllItemSet( GetPool() ); pSet->Put( SfxBoolItem( SID_TEMPLATE, TRUE ) ); if ( !bDirect ) { SfxDocumentTemplates aTmpFac; if( !aTemplateFileName.Len() ) aTmpFac.GetFull( aTemplateRegion, aTemplateName, aTemplateFileName ); if( !aTemplateFileName.Len() ) lErr = ERRCODE_SFX_TEMPLATENOTFOUND; } INetURLObject aObj( aTemplateFileName ); SfxErrorContext aEC( ERRCTX_SFX_LOADTEMPLATE, aObj.PathToFileName() ); if ( lErr != ERRCODE_NONE ) { ULONG lFatalErr = ERRCODE_TOERROR(lErr); if ( lFatalErr ) ErrorHandler::HandleError(lErr); } else { SfxCallMode eMode = SFX_CALLMODE_SYNCHRON; const SfxPoolItem *pRet=0; SfxStringItem aReferer( SID_REFERER, DEFINE_CONST_UNICODE("private:user") ); SfxStringItem aTarget( SID_TARGETNAME, DEFINE_CONST_UNICODE("_default") ); if ( aTemplateFileName.Len() ) { DBG_ASSERT( aObj.GetProtocol() != INET_PROT_NOT_VALID, "Illegal URL!" ); SfxStringItem aName( SID_FILE_NAME, aObj.GetMainURL( INetURLObject::NO_DECODE ) ); SfxStringItem aTemplName( SID_TEMPLATE_NAME, aTemplateName ); SfxStringItem aTemplRegionName( SID_TEMPLATE_REGIONNAME, aTemplateRegion ); pRet = GetDispatcher_Impl()->Execute( SID_OPENDOC, eMode, &aName, &aTarget, &aReferer, &aTemplName, &aTemplRegionName, 0L ); } else { SfxStringItem aName( SID_FILE_NAME, DEFINE_CONST_UNICODE("private:factory") ); pRet = GetDispatcher_Impl()->Execute( SID_OPENDOC, eMode, &aName, &aTarget, &aReferer, 0L ); } if ( pRet ) rReq.SetReturnValue( *pRet ); } } //--------------------------------------------------------------------------- void SfxApplication::OpenDocExec_Impl( SfxRequest& rReq ) { DBG_MEMTEST(); USHORT nSID = rReq.GetSlot(); SFX_REQUEST_ARG( rReq, pFileNameItem, SfxStringItem, SID_FILE_NAME, FALSE ); if ( pFileNameItem ) { String aCommand( pFileNameItem->GetValue() ); const SfxSlot* pSlot = GetInterface()->GetSlot( aCommand ); if ( pSlot ) { pFileNameItem = NULL; } else { sal_Int32 nIndex = aCommand.SearchAscii("slot:"); if ( !nIndex ) { USHORT nSlotId = (USHORT) String( aCommand, 5, aCommand.Len()-5 ).ToInt32(); if ( nSlotId == SID_OPENDOC ) pFileNameItem = NULL; } } } if ( !pFileNameItem ) { // get FileName from dialog SvStringsDtor* pURLList = NULL; String aFilter; SfxItemSet* pSet = NULL; String aPath; if ( nSID == SID_OPENTEMPLATE ) { aPath = SvtPathOptions().GetTemplatePath(); sal_Int32 nTokenCount = aPath.GetTokenCount( ';' ); aPath = aPath.GetToken( sal::static_int_cast< xub_StrLen >( nTokenCount ? ( nTokenCount - 1 ) : 0 ), ';' ); } ULONG nErr = sfx2::FileOpenDialog_Impl( WB_OPEN | SFXWB_MULTISELECTION | SFXWB_SHOWVERSIONS, String(), pURLList, aFilter, pSet, &aPath ); if ( nErr == ERRCODE_ABORT ) { delete pURLList; return; } rReq.SetArgs( *(SfxAllItemSet*)pSet ); if (aFilter.Len() >0 ) rReq.AppendItem( SfxStringItem( SID_FILTER_NAME, aFilter ) ); rReq.AppendItem( SfxStringItem( SID_TARGETNAME, String::CreateFromAscii("_default") ) ); rReq.AppendItem( SfxStringItem( SID_REFERER, String::CreateFromAscii(SFX_REFERER_USER) ) ); delete pSet; if ( pURLList->Count() ) { if ( nSID == SID_OPENTEMPLATE ) rReq.AppendItem( SfxBoolItem( SID_TEMPLATE, FALSE ) ); // This helper wraps an existing (or may new created InteractionHandler) // intercept all incoming interactions and provide usefull informations // later if the following transaction was finished. ::framework::PreventDuplicateInteraction* pHandler = new ::framework::PreventDuplicateInteraction(::comphelper::getProcessServiceFactory()); css::uno::Reference< css::task::XInteractionHandler > xHandler (static_cast< css::task::XInteractionHandler* >(pHandler), css::uno::UNO_QUERY); css::uno::Reference< css::task::XInteractionHandler > xWrappedHandler; // wrap existing handler or create new UUI handler SFX_REQUEST_ARG(rReq, pInteractionItem, SfxUnoAnyItem, SID_INTERACTIONHANDLER, FALSE); if (pInteractionItem) { pInteractionItem->GetValue() >>= xWrappedHandler; rReq.RemoveItem( SID_INTERACTIONHANDLER ); } if (xWrappedHandler.is()) pHandler->setHandler(xWrappedHandler); else pHandler->useDefaultUUIHandler(); rReq.AppendItem( SfxUnoAnyItem(SID_INTERACTIONHANDLER,::com::sun::star::uno::makeAny(xHandler)) ); // define rules for this handler css::uno::Type aInteraction = ::getCppuType(static_cast< css::task::ErrorCodeRequest* >(0)); ::framework::PreventDuplicateInteraction::InteractionInfo aRule (aInteraction, 1); pHandler->addInteractionRule(aRule); for ( USHORT i = 0; i < pURLList->Count(); ++i ) { String aURL = *(pURLList->GetObject(i)); rReq.RemoveItem( SID_FILE_NAME ); rReq.AppendItem( SfxStringItem( SID_FILE_NAME, aURL ) ); // synchron ausf"uhren, damit beim Reschedulen nicht schon das n"achste Dokument // geladen wird // TODO/LATER: use URLList argument and always remove one document after another, each step in asychronous execution, until finished // but only if reschedule is a problem GetDispatcher_Impl()->Execute( SID_OPENDOC, SFX_CALLMODE_SYNCHRON, *rReq.GetArgs() ); // check for special interaction "NO MORE DOCUMENTS ALLOWED" and // break loop then. Otherwise we risk showing the same interaction more then once. if ( pHandler->getInteractionInfo(aInteraction, &aRule) ) { if (aRule.m_nCallCount > 0) { if (aRule.m_xRequest.is()) { css::task::ErrorCodeRequest aRequest; if (aRule.m_xRequest->getRequest() >>= aRequest) { if (aRequest.ErrCode == sal::static_int_cast< sal_Int32 >( ERRCODE_SFX_NOMOREDOCUMENTSALLOWED)) break; } } } } } delete pURLList; return; } // else // { // String aURL; // if ( pURLList->Count() == 1 ) // aURL = *(pURLList->GetObject(0)); // rReq.AppendItem( SfxStringItem( SID_FILE_NAME, aURL ) ); // delete pURLList; // } } if ( !rReq.IsSynchronCall() ) { // now check wether a stream is already there // if not: download it in a thread and restart the call // return; } BOOL bHyperlinkUsed = FALSE; if ( SID_OPENURL == nSID ) { // SID_OPENURL does the same as SID_OPENDOC! rReq.SetSlot( SID_OPENDOC ); nSID = SID_OPENDOC; } else if ( nSID == SID_OPENTEMPLATE ) { rReq.AppendItem( SfxBoolItem( SID_TEMPLATE, FALSE ) ); } // pass URL to OS by using ShellExecuter or open it internal // if it seams to be an own format. /* Attention! There exist two possibilities to open hyperlinks: a) using SID_OPENHYPERLINK (new) b) using SID_BROWSE (old) */ else if ( nSID == SID_OPENHYPERLINK ) { rReq.SetSlot( SID_OPENDOC ); nSID = SID_OPENDOC; bHyperlinkUsed = TRUE; } // no else here! It's optional ... if (!bHyperlinkUsed) { SFX_REQUEST_ARG(rReq, pHyperLinkUsedItem, SfxBoolItem, SID_BROWSE, FALSE); if ( pHyperLinkUsedItem ) bHyperlinkUsed = pHyperLinkUsedItem->GetValue(); // no "official" item, so remove it from ItemSet before using UNO-API rReq.RemoveItem( SID_BROWSE ); } SFX_REQUEST_ARG( rReq, pFileName, SfxStringItem, SID_FILE_NAME, FALSE ); String aFileName = pFileName->GetValue(); String aReferer; SFX_REQUEST_ARG( rReq, pRefererItem, SfxStringItem, SID_REFERER, FALSE ); if ( pRefererItem ) aReferer = pRefererItem->GetValue(); SFX_REQUEST_ARG( rReq, pFileFlagsItem, SfxStringItem, SID_OPTIONS, FALSE); if ( pFileFlagsItem ) { String aFileFlags = pFileFlagsItem->GetValue(); aFileFlags.ToUpperAscii(); if ( STRING_NOTFOUND != aFileFlags.Search( 0x0054 ) ) // T = 54h { rReq.RemoveItem( SID_TEMPLATE ); rReq.AppendItem( SfxBoolItem( SID_TEMPLATE, TRUE ) ); } if ( STRING_NOTFOUND != aFileFlags.Search( 0x0048 ) ) // H = 48h { rReq.RemoveItem( SID_HIDDEN ); rReq.AppendItem( SfxBoolItem( SID_HIDDEN, TRUE ) ); } if ( STRING_NOTFOUND != aFileFlags.Search( 0x0052 ) ) // R = 52h { rReq.RemoveItem( SID_DOC_READONLY ); rReq.AppendItem( SfxBoolItem( SID_DOC_READONLY, TRUE ) ); } if ( STRING_NOTFOUND != aFileFlags.Search( 0x0042 ) ) // B = 42h { rReq.RemoveItem( SID_PREVIEW ); rReq.AppendItem( SfxBoolItem( SID_PREVIEW, TRUE ) ); } if ( STRING_NOTFOUND != aFileFlags.Search( 0x0053 ) ) // S = 53h { // not supported anymore //rReq.RemoveItem( SID_SILENT ); //rReq.AppendItem( SfxBoolItem( SID_SILENT, TRUE ) ); } rReq.RemoveItem( SID_OPTIONS ); } // Mark without URL cannot be handled by hyperlink code if ( bHyperlinkUsed && aFileName.Len() && aFileName.GetChar(0) != '#' ) { Reference< ::com::sun::star::document::XTypeDetection > xTypeDetection( ::comphelper::getProcessServiceFactory()->createInstance( ::rtl::OUString::createFromAscii( "com.sun.star.document.TypeDetection" )), UNO_QUERY ); if ( xTypeDetection.is() ) { URL aURL; ::rtl::OUString aTypeName; aURL.Complete = aFileName; Reference < XURLTransformer > xTrans( ::comphelper::getProcessServiceFactory()->createInstance( ::rtl::OUString::createFromAscii("com.sun.star.util.URLTransformer" )), UNO_QUERY ); xTrans->parseStrict( aURL ); INetProtocol aINetProtocol = INetURLObject( aURL.Complete ).GetProtocol(); SvtExtendedSecurityOptions aExtendedSecurityOptions; SvtExtendedSecurityOptions::OpenHyperlinkMode eMode = aExtendedSecurityOptions.GetOpenHyperlinkMode(); if ( eMode == SvtExtendedSecurityOptions::OPEN_WITHSECURITYCHECK ) { if ( aINetProtocol == INET_PROT_FILE ) { /*!!! pb: #i49802# no security warning any longer // Check if file URL is a directory. This is not insecure! osl::Directory aDir( aURL.Main ); sal_Bool bIsDir = ( aDir.open() == osl::Directory::E_None ); if ( !bIsDir && !aExtendedSecurityOptions.IsSecureHyperlink( aURL.Complete ) ) { // Security check for local files depending on the extension vos::OGuard aGuard( Application::GetSolarMutex() ); Window *pWindow = SFX_APP()->GetTopWindow(); String aSecurityWarningBoxTitle( SfxResId( RID_SECURITY_WARNING_TITLE )); WarningBox aSecurityWarningBox( pWindow, SfxResId( RID_SECURITY_WARNING_HYPERLINK )); aSecurityWarningBox.SetText( aSecurityWarningBoxTitle ); // Replace %s with the real file name String aMsgText = aSecurityWarningBox.GetMessText(); String aMainURL( aURL.Main ); String aFileName; utl::LocalFileHelper::ConvertURLToPhysicalName( aMainURL, aFileName ); aMsgText.SearchAndReplaceAscii( "%s", aFileName ); aSecurityWarningBox.SetMessText( aMsgText ); if( aSecurityWarningBox.Execute() == RET_NO ) return; } */ } } else if ( eMode == SvtExtendedSecurityOptions::OPEN_NEVER && aINetProtocol != INET_PROT_VND_SUN_STAR_HELP ) { vos::OGuard aGuard( Application::GetSolarMutex() ); Window *pWindow = SFX_APP()->GetTopWindow(); String aSecurityWarningBoxTitle( SfxResId( RID_SECURITY_WARNING_TITLE )); WarningBox aSecurityWarningBox( pWindow, SfxResId( RID_SECURITY_WARNING_NO_HYPERLINKS )); aSecurityWarningBox.SetText( aSecurityWarningBoxTitle ); aSecurityWarningBox.Execute(); return; } aTypeName = xTypeDetection->queryTypeByURL( aURL.Main ); SfxFilterMatcher& rMatcher = SFX_APP()->GetFilterMatcher(); const SfxFilter* pFilter = rMatcher.GetFilter4EA( aTypeName ); if ( !pFilter || !( pFilter->IsOwnFormat() )) { // hyperlink does not link to known type => special handling (http, ftp) browser and (file) OS Reference< XSystemShellExecute > xSystemShellExecute( ::comphelper::getProcessServiceFactory()->createInstance( ::rtl::OUString::createFromAscii( "com.sun.star.system.SystemShellExecute" )), UNO_QUERY ); if ( xSystemShellExecute.is() ) { if ( aINetProtocol == INET_PROT_FTP || aINetProtocol == INET_PROT_HTTP || aINetProtocol == INET_PROT_HTTPS ) { try { // start browser ::rtl::OUString aURLString( aURL.Complete ); xSystemShellExecute->execute( aURLString, ::rtl::OUString(), SystemShellExecuteFlags::DEFAULTS ); } catch ( ::com::sun::star::lang::IllegalArgumentException& ) { vos::OGuard aGuard( Application::GetSolarMutex() ); Window *pWindow = SFX_APP()->GetTopWindow(); ErrorBox( pWindow, SfxResId( MSG_ERR_NO_WEBBROWSER_FOUND )).Execute(); } catch ( ::com::sun::star::system::SystemShellExecuteException& ) { vos::OGuard aGuard( Application::GetSolarMutex() ); Window *pWindow = SFX_APP()->GetTopWindow(); ErrorBox( pWindow, SfxResId( MSG_ERR_NO_WEBBROWSER_FOUND )).Execute(); } return; } else if ( aINetProtocol == INET_PROT_FILE ) { BOOL bLoadInternal = FALSE; // security reservation: => we have to check the referer before executing if (SFX_APP()->IsSecureURL(rtl::OUString(), &aReferer)) { ::rtl::OUString aURLString( aURL.Complete ); try { // give os this file xSystemShellExecute->execute( aURLString, ::rtl::OUString(), SystemShellExecuteFlags::DEFAULTS ); } catch ( ::com::sun::star::lang::IllegalArgumentException& ) { vos::OGuard aGuard( Application::GetSolarMutex() ); Window *pWindow = SFX_APP()->GetTopWindow(); ErrorBox( pWindow, SfxResId( MSG_ERR_NO_WEBBROWSER_FOUND )).Execute(); } catch ( ::com::sun::star::system::SystemShellExecuteException& ) { if ( !pFilter ) { vos::OGuard aGuard( Application::GetSolarMutex() ); Window *pWindow = SFX_APP()->GetTopWindow(); ErrorBox( pWindow, SfxResId( MSG_ERR_NO_WEBBROWSER_FOUND )).Execute(); } else { rReq.RemoveItem( SID_TARGETNAME ); rReq.AppendItem( SfxStringItem( SID_TARGETNAME, String::CreateFromAscii("_default") ) ); bLoadInternal = TRUE; } } } else { SfxErrorContext aCtx( ERRCTX_SFX_OPENDOC, aURL.Complete ); ErrorHandler::HandleError( ERRCODE_IO_ACCESSDENIED ); } if ( !bLoadInternal ) return; } else if ( aINetProtocol == INET_PROT_MAILTO ) { // don't dispatch mailto hyperlink to desktop dispatcher rReq.RemoveItem( SID_TARGETNAME ); rReq.AppendItem( SfxStringItem( SID_TARGETNAME, String::CreateFromAscii("_self") ) ); } } } else { // hyperlink document must be loaded into a new frame rReq.RemoveItem( SID_TARGETNAME ); rReq.AppendItem( SfxStringItem( SID_TARGETNAME, String::CreateFromAscii("_default") ) ); } } } if ( !SFX_APP()->IsSecureURL( INetURLObject(aFileName), &aReferer ) ) { SfxErrorContext aCtx( ERRCTX_SFX_OPENDOC, aFileName ); ErrorHandler::HandleError( ERRCODE_IO_ACCESSDENIED ); return; } SFX_REQUEST_ARG(rReq, pFrmItem, SfxFrameItem, SID_DOCFRAME, FALSE); SfxFrame *pFrame = NULL; if ( pFrmItem ) pFrame = pFrmItem->GetFrame(); else if ( SfxViewFrame::Current() ) pFrame = SfxViewFrame::Current()->GetFrame(); // check if caller has set a callback SFX_REQUEST_ARG(rReq, pLinkItem, SfxLinkItem, SID_DONELINK, FALSE ); // remove from Itemset, because it confuses the parameter transformation if ( pLinkItem ) pLinkItem = (SfxLinkItem*) pLinkItem->Clone(); rReq.RemoveItem( SID_DONELINK ); // check if caller wants to create a view BOOL bCreateView = TRUE; SFX_REQUEST_ARG( rReq, pCreateViewItem, SfxBoolItem, SID_VIEW, FALSE ); if ( pCreateViewItem ) { if ( !pCreateViewItem->GetValue() ) bCreateView = FALSE; // this is an "SFX only" parameter rReq.RemoveItem( SID_VIEW ); } // we can't load without a view - switch to hidden view if ( !bCreateView ) rReq.AppendItem( SfxBoolItem( SID_HIDDEN, TRUE ) ); // check if the view must be hidden BOOL bHidden = FALSE; SFX_REQUEST_ARG(rReq, pHidItem, SfxBoolItem, SID_HIDDEN, FALSE); if ( pHidItem ) bHidden = pHidItem->GetValue(); // This request is a UI call. We have to set the right values inside the MediaDescriptor // for: InteractionHandler, StatusIndicator, MacroExecutionMode and DocTemplate. // But we have to look for already existing values or for real hidden requests. SFX_REQUEST_ARG(rReq, pPreviewItem, SfxBoolItem, SID_PREVIEW, FALSE); if (!bHidden && ( !pPreviewItem || !pPreviewItem->GetValue() ) ) { SFX_REQUEST_ARG(rReq, pInteractionItem, SfxUnoAnyItem, SID_INTERACTIONHANDLER, FALSE); SFX_REQUEST_ARG(rReq, pMacroExecItem , SfxUInt16Item, SID_MACROEXECMODE , FALSE); SFX_REQUEST_ARG(rReq, pDocTemplateItem, SfxUInt16Item, SID_UPDATEDOCMODE , FALSE); if (!pInteractionItem) { Reference < ::com::sun::star::task::XInteractionHandler > xHdl( ::comphelper::getProcessServiceFactory()->createInstance(::rtl::OUString::createFromAscii("com.sun.star.comp.uui.UUIInteractionHandler")), UNO_QUERY ); if (xHdl.is()) rReq.AppendItem( SfxUnoAnyItem(SID_INTERACTIONHANDLER,::com::sun::star::uno::makeAny(xHdl)) ); } if (!pMacroExecItem) rReq.AppendItem( SfxUInt16Item(SID_MACROEXECMODE,::com::sun::star::document::MacroExecMode::USE_CONFIG) ); if (!pDocTemplateItem) rReq.AppendItem( SfxUInt16Item(SID_UPDATEDOCMODE,::com::sun::star::document::UpdateDocMode::ACCORDING_TO_CONFIG) ); } // extract target name ::rtl::OUString aTarget; SFX_REQUEST_ARG(rReq, pTargetItem, SfxStringItem, SID_TARGETNAME, FALSE); if ( pTargetItem ) aTarget = pTargetItem->GetValue(); else { SFX_REQUEST_ARG( rReq, pNewViewItem, SfxBoolItem, SID_OPEN_NEW_VIEW, FALSE ); if ( pNewViewItem && pNewViewItem->GetValue() ) aTarget = String::CreateFromAscii("_blank" ); } if ( bHidden ) { aTarget = String::CreateFromAscii("_blank"); DBG_ASSERT( rReq.IsSynchronCall() || pLinkItem, "Hidden load process must be done synchronously!" ); } Reference < XController > xController; // if ( ( !bIsBlankTarget && pFrame ) || pLinkItem || !rReq.IsSynchronCall() ) // { // if a frame is given, it must be used for the starting point of the targetting mechanism // this code is also used if asynchronous loading is possible, because loadComponent always is synchron Reference < XFrame > xFrame; if ( pFrame ) xFrame = pFrame->GetFrameInterface(); else xFrame = Reference < XFrame >( ::comphelper::getProcessServiceFactory()->createInstance(::rtl::OUString::createFromAscii("com.sun.star.frame.Desktop")), UNO_QUERY ); // make URL ready SFX_REQUEST_ARG( rReq, pURLItem, SfxStringItem, SID_FILE_NAME, FALSE ); aFileName = pURLItem->GetValue(); if( aFileName.Len() && aFileName.GetChar(0) == '#' ) // Mark without URL { SfxViewFrame *pView = pFrame ? pFrame->GetCurrentViewFrame() : 0; if ( !pView ) pView = SfxViewFrame::Current(); pView->GetViewShell()->JumpToMark( aFileName.Copy(1) ); rReq.SetReturnValue( SfxViewFrameItem( 0, pView ) ); return; } // convert items to properties for framework API calls Sequence < PropertyValue > aArgs; TransformItems( SID_OPENDOC, *rReq.GetArgs(), aArgs ); // TODO/LATER: either remove LinkItem or create an asynchronous process for it if( bHidden || pLinkItem || rReq.IsSynchronCall() ) { // if loading must be done synchron, we must wait for completion to get a return value // find frame by myself; I must konw the exact frame to get the controller for the return value from it //if( aTarget.getLength() ) // xFrame = xFrame->findFrame( aTarget, FrameSearchFlag::ALL ); Reference < XComponent > xComp; try { Reference < XComponentLoader > xLoader( xFrame, UNO_QUERY ); xComp = xLoader->loadComponentFromURL( aFileName, aTarget, 0, aArgs ); } catch(const RuntimeException&) { throw; } catch(const ::com::sun::star::uno::Exception&) { } Reference < XModel > xModel( xComp, UNO_QUERY ); if ( xModel.is() ) xController = xModel->getCurrentController(); else xController = Reference < XController >( xComp, UNO_QUERY ); } else { URL aURL; aURL.Complete = aFileName; Reference < XURLTransformer > xTrans( ::comphelper::getProcessServiceFactory()->createInstance( rtl::OUString::createFromAscii("com.sun.star.util.URLTransformer" )), UNO_QUERY ); xTrans->parseStrict( aURL ); Reference < XDispatchProvider > xProv( xFrame, UNO_QUERY ); Reference < XDispatch > xDisp = xProv.is() ? xProv->queryDispatch( aURL, aTarget, FrameSearchFlag::ALL ) : Reference < XDispatch >();; RTL_LOGFILE_PRODUCT_CONTEXT( aLog2, "PERFORMANCE - SfxApplication::OpenDocExec_Impl" ); if ( xDisp.is() ) xDisp->dispatch( aURL, aArgs ); } /* } else { // synchron loading without a given frame or as blank frame SFX_REQUEST_ARG( rReq, pFileNameItem, SfxStringItem, SID_FILE_NAME, FALSE ); // Desktop service must exists! dont catch() or check for problems here ... // But loading of documents can fail by other reasons. Handle it more gracefully. Reference < XComponentLoader > xDesktop( ::comphelper::getProcessServiceFactory()->createInstance(::rtl::OUString::createFromAscii("com.sun.star.frame.Desktop")), UNO_QUERY ); Reference < XComponent > xComp; try { xComp = xDesktop->loadComponentFromURL( pFileNameItem->GetValue(), aTarget, 0, aArgs ); } catch(const RuntimeException&) { throw; } catch(const ::com::sun::star::uno::Exception&) { xDesktop.clear(); xComp.clear(); } Reference < XModel > xModel( xComp, UNO_QUERY ); if ( xModel.is() ) xController = xModel->getCurrentController(); else xController = Reference < XController >( xComp, UNO_QUERY ); }*/ if ( xController.is() ) { // try to find the SfxFrame for the controller SfxFrame* pCntrFrame = NULL; for ( SfxViewShell* pShell = SfxViewShell::GetFirst( 0, FALSE ); pShell; pShell = SfxViewShell::GetNext( *pShell, 0, FALSE ) ) { if ( pShell->GetController() == xController ) { pCntrFrame = pShell->GetViewFrame()->GetFrame(); break; } } if ( pCntrFrame ) { SfxObjectShell* pSh = pCntrFrame->GetCurrentDocument(); DBG_ASSERT( pSh, "Controller without ObjectShell ?!" ); if ( bCreateView ) rReq.SetReturnValue( SfxViewFrameItem( 0, pCntrFrame->GetCurrentViewFrame() ) ); else rReq.SetReturnValue( SfxObjectItem( 0, pSh ) ); if( ( bHidden || !bCreateView ) ) pSh->RestoreNoDelete(); } } if ( pLinkItem ) { SfxPoolItem* pRet = rReq.GetReturnValue()->Clone(); pLinkItem->GetValue().Call(pRet); delete pLinkItem; } }