summaryrefslogtreecommitdiff
path: root/sfx2
diff options
context:
space:
mode:
authorKurt Zenker <kz@openoffice.org>2008-05-20 18:00:04 +0000
committerKurt Zenker <kz@openoffice.org>2008-05-20 18:00:04 +0000
commite4641d1678b32a770beaf72a134d5da5d787cef0 (patch)
treea18d53b386569d3c310e1533ca5e9b05a068adad /sfx2
parent99fdb76022ddd9d431df2e9f5f1896f0b1e239ec (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.cxx97
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() );