diff options
author | Kurt Zenker <kz@openoffice.org> | 2008-05-20 18:00:04 +0000 |
---|---|---|
committer | Kurt Zenker <kz@openoffice.org> | 2008-05-20 18:00:04 +0000 |
commit | e4641d1678b32a770beaf72a134d5da5d787cef0 (patch) | |
tree | a18d53b386569d3c310e1533ca5e9b05a068adad /sfx2 | |
parent | 99fdb76022ddd9d431df2e9f5f1896f0b1e239ec (diff) |
INTEGRATION: CWS mba30patches01 (1.205.8); FILE MERGED
2008/04/23 09:46:33 mba 1.205.8.2: RESYNC: (1.205-1.209); FILE MERGED
2008/03/20 17:36:31 mba 1.205.8.1: #i84621#: don't use subfilter approach for file insertion
Diffstat (limited to 'sfx2')
-rw-r--r-- | sfx2/source/doc/objstor.cxx | 97 |
1 files changed, 96 insertions, 1 deletions
diff --git a/sfx2/source/doc/objstor.cxx b/sfx2/source/doc/objstor.cxx index 943e89a091..c5f93657d9 100644 --- a/sfx2/source/doc/objstor.cxx +++ b/sfx2/source/doc/objstor.cxx @@ -7,7 +7,7 @@ * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: objstor.cxx,v $ - * $Revision: 1.210 $ + * $Revision: 1.211 $ * * This file is part of OpenOffice.org. * @@ -2100,6 +2100,101 @@ sal_Bool SfxObjectShell::ConvertFrom return sal_False; } +sal_Bool SfxObjectShell::InsertFrom( SfxMedium& rMedium ) +{ + ::rtl::OUString aTypeName( rMedium.GetFilter()->GetTypeName() ); + ::rtl::OUString aFilterName( rMedium.GetFilter()->GetFilterName() ); + + uno::Reference< lang::XMultiServiceFactory > xMan = ::comphelper::getProcessServiceFactory(); + uno::Reference < lang::XMultiServiceFactory > xFilterFact ( + xMan->createInstance( DEFINE_CONST_UNICODE( "com.sun.star.document.FilterFactory" ) ), uno::UNO_QUERY ); + + uno::Sequence < beans::PropertyValue > aProps; + uno::Reference < container::XNameAccess > xFilters ( xFilterFact, uno::UNO_QUERY ); + if ( xFilters->hasByName( aFilterName ) ) + { + xFilters->getByName( aFilterName ) >>= aProps; + rMedium.GetItemSet()->Put( SfxStringItem( SID_FILTER_NAME, aFilterName ) ); + } + + ::rtl::OUString aFilterImplName; + sal_Int32 nFilterProps = aProps.getLength(); + for ( sal_Int32 nFilterProp = 0; nFilterProp<nFilterProps; nFilterProp++ ) + { + const beans::PropertyValue& rFilterProp = aProps[nFilterProp]; + if ( rFilterProp.Name.compareToAscii("FilterService") == COMPARE_EQUAL ) + { + rFilterProp.Value >>= aFilterImplName; + break; + } + } + + uno::Reference< document::XFilter > xLoader; + if ( aFilterImplName.getLength() ) + { + try{ + xLoader = uno::Reference< document::XFilter > + ( xFilterFact->createInstanceWithArguments( aFilterName, uno::Sequence < uno::Any >() ), uno::UNO_QUERY ); + }catch(const uno::Exception&) + { xLoader.clear(); } + } + if ( xLoader.is() ) + { + // #131744#: it happens that xLoader does not support xImporter! + try{ + uno::Reference< lang::XComponent > xComp( GetModel(), uno::UNO_QUERY_THROW ); + uno::Reference< document::XImporter > xImporter( xLoader, uno::UNO_QUERY_THROW ); + xImporter->setTargetDocument( xComp ); + + uno::Sequence < beans::PropertyValue > lDescriptor; + rMedium.GetItemSet()->Put( SfxStringItem( SID_FILE_NAME, rMedium.GetName() ) ); + TransformItems( SID_OPENDOC, *rMedium.GetItemSet(), lDescriptor ); + + com::sun::star::uno::Sequence < com::sun::star::beans::PropertyValue > aArgs ( lDescriptor.getLength() ); + com::sun::star::beans::PropertyValue * pNewValue = aArgs.getArray(); + const com::sun::star::beans::PropertyValue * pOldValue = lDescriptor.getConstArray(); + const OUString sInputStream ( RTL_CONSTASCII_USTRINGPARAM ( "InputStream" ) ); + + sal_Bool bHasInputStream = sal_False; + BOOL bHasBaseURL = FALSE; + sal_Int32 i; + sal_Int32 nEnd = lDescriptor.getLength(); + + for ( i = 0; i < nEnd; i++ ) + { + pNewValue[i] = pOldValue[i]; + if ( pOldValue [i].Name == sInputStream ) + bHasInputStream = sal_True; + else if ( pOldValue[i].Name.equalsAsciiL ( RTL_CONSTASCII_STRINGPARAM ( "DocumentBaseURL" ) ) ) + bHasBaseURL = sal_True; + } + + if ( !bHasInputStream ) + { + aArgs.realloc ( ++nEnd ); + aArgs[nEnd-1].Name = sInputStream; + aArgs[nEnd-1].Value <<= com::sun::star::uno::Reference < com::sun::star::io::XInputStream > ( new utl::OSeekableInputStreamWrapper ( *rMedium.GetInStream() ) ); + } + + if ( !bHasBaseURL ) + { + aArgs.realloc ( ++nEnd ); + aArgs[nEnd-1].Name = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "DocumentBaseURL" ) ); + aArgs[nEnd-1].Value <<= rMedium.GetBaseURL(); + } + + aArgs.realloc( ++nEnd ); + aArgs[nEnd-1].Name = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM ( "InsertMode" ) ); + aArgs[nEnd-1].Value <<= (sal_Bool) sal_True; + + return xLoader->filter( aArgs ); + }catch(const uno::Exception&) + {} + } + + return sal_False; +} + sal_Bool SfxObjectShell::ImportFrom( SfxMedium& rMedium ) { ::rtl::OUString aTypeName( rMedium.GetFilter()->GetTypeName() ); |