summaryrefslogtreecommitdiff
path: root/svtools/source/dialogs/insdlg.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'svtools/source/dialogs/insdlg.cxx')
-rw-r--r--svtools/source/dialogs/insdlg.cxx389
1 files changed, 389 insertions, 0 deletions
diff --git a/svtools/source/dialogs/insdlg.cxx b/svtools/source/dialogs/insdlg.cxx
new file mode 100644
index 000000000000..3f7700805995
--- /dev/null
+++ b/svtools/source/dialogs/insdlg.cxx
@@ -0,0 +1,389 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2000, 2010 Oracle and/or its affiliates.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org 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 version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+// MARKER(update_precomp.py): autogen include statement, do not remove
+#include "precompiled_svtools.hxx"
+
+#define _INSDLG_CXX
+
+// include ---------------------------------------------------------------
+
+#include <svtools/insdlg.hxx>
+#include "sores.hxx"
+#include <svtools/svtdata.hxx>
+
+#include <tools/rc.hxx>
+#include <unotools/configmgr.hxx>
+#include <sot/clsids.hxx>
+#include <sot/stg.hxx>
+
+#include <com/sun/star/lang/XMultiServiceFactory.hpp>
+#include <com/sun/star/beans/PropertyValue.hpp>
+#include <comphelper/processfactory.hxx>
+#include <com/sun/star/container/XNameAccess.hpp>
+
+using namespace ::com::sun::star;
+
+//---------------------------------------------
+// this struct conforms to the Microsoft
+// OBJECTDESCRIPTOR -> see oleidl.h
+// (MS platform sdk)
+//---------------------------------------------
+
+struct OleObjectDescriptor
+{
+ sal_uInt32 cbSize;
+ ClsId clsid;
+ sal_uInt32 dwDrawAspect;
+ Size sizel;
+ Point pointl;
+ sal_uInt32 dwStatus;
+ sal_uInt32 dwFullUserTypeName;
+ sal_uInt32 dwSrcOfCopy;
+};
+
+/********************** SvObjectServerList ********************************
+**************************************************************************/
+PRV_SV_IMPL_OWNER_LIST( SvObjectServerList, SvObjectServer )
+
+/*************************************************************************
+|* SvObjectServerList::SvObjectServerList()
+|*
+|* Beschreibung
+*************************************************************************/
+const SvObjectServer * SvObjectServerList::Get( const String & rHumanName ) const
+{
+ for( ULONG i = 0; i < Count(); i++ )
+ {
+ if( rHumanName == GetObject( i ).GetHumanName() )
+ return &GetObject( i );
+ }
+ return NULL;
+}
+
+/*************************************************************************
+|* SvObjectServerList::SvObjectServerList()
+|*
+|* Beschreibung
+*************************************************************************/
+const SvObjectServer * SvObjectServerList::Get( const SvGlobalName & rName ) const
+{
+ for( ULONG i = 0; i < Count(); i++ )
+ {
+ if( rName == GetObject( i ).GetClassName() )
+ return &GetObject( i );
+ }
+ return NULL;
+}
+
+void SvObjectServerList::Remove( const SvGlobalName & rName )
+{
+ SvObjectServer * pS = (SvObjectServer *)aTypes.First();
+ while( pS )
+ {
+ if( rName == pS->GetClassName() )
+ {
+ Remove();
+ pS = (SvObjectServer *)aTypes.GetCurObject();
+ }
+ else
+ pS = (SvObjectServer *)aTypes.Next();
+ }
+}
+
+//---------------------------------------------------------------------
+void SvObjectServerList::FillInsertObjects()
+/* [Beschreibung]
+
+ Die Liste wird mit allen Typen gef"ullt, die im Insert-Dialog
+ ausgew"ahlt werden k"onnen.
+*/
+{
+ try{
+ uno::Reference< lang::XMultiServiceFactory > _globalMSFactory= comphelper::getProcessServiceFactory();
+ if( _globalMSFactory.is())
+ {
+ ::rtl::OUString sProviderService =
+ ::rtl::OUString::createFromAscii( "com.sun.star.configuration.ConfigurationProvider" );
+ uno::Reference< lang::XMultiServiceFactory > sProviderMSFactory(
+ _globalMSFactory->createInstance( sProviderService ), uno::UNO_QUERY );
+
+ if( sProviderMSFactory.is())
+ {
+ ::rtl::OUString sReaderService =
+ ::rtl::OUString::createFromAscii( "com.sun.star.configuration.ConfigurationAccess" );
+ uno::Sequence< uno::Any > aArguments( 1 );
+ beans::PropertyValue aPathProp;
+ aPathProp.Name = ::rtl::OUString::createFromAscii( "nodepath" );
+ aPathProp.Value <<= ::rtl::OUString::createFromAscii( "/org.openoffice.Office.Embedding/ObjectNames");
+ aArguments[0] <<= aPathProp;
+
+ uno::Reference< container::XNameAccess > xNameAccess(
+ sProviderMSFactory->createInstanceWithArguments( sReaderService,aArguments ),
+ uno::UNO_QUERY );
+
+ if( xNameAccess.is())
+ {
+ uno::Sequence< ::rtl::OUString > seqNames= xNameAccess->getElementNames();
+ sal_Int32 nInd;
+
+ ::rtl::OUString aStringProductName( RTL_CONSTASCII_USTRINGPARAM( "%PRODUCTNAME" ) );
+ sal_Int32 nStringProductNameLength = aStringProductName.getLength();
+
+ ::rtl::OUString aStringProductVersion( RTL_CONSTASCII_USTRINGPARAM( "%PRODUCTVERSION" ) );
+ sal_Int32 nStringProductVersionLength = aStringProductVersion.getLength();
+
+ // TODO/LATER: Do the request only once ( needs incompatible change )
+ ::rtl::OUString aProductName;
+ ::rtl::OUString aProductVersion;
+ uno::Any aProperty =
+ ::utl::ConfigManager::GetDirectConfigProperty( ::utl::ConfigManager::PRODUCTNAME );
+ if ( !( aProperty >>= aProductName ) )
+ {
+ OSL_ENSURE( sal_False, "Coudn't get PRODUCTNAME variable!\n" );
+ aProductName = ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "StarOffice" ) );
+ }
+ aProperty = ::utl::ConfigManager::GetDirectConfigProperty( ::utl::ConfigManager::PRODUCTVERSION );
+ if ( !( aProperty >>= aProductVersion ) )
+ {
+ OSL_ENSURE( sal_False, "Coudn't get PRODUCTVERSION variable!\n" );
+ }
+
+ for( nInd = 0; nInd < seqNames.getLength(); nInd++ )
+ {
+ uno::Reference< container::XNameAccess > xEntry ;
+ xNameAccess->getByName( seqNames[nInd] ) >>= xEntry;
+ if ( xEntry.is() )
+ {
+ ::rtl::OUString aUIName;
+ ::rtl::OUString aClassID;
+ xEntry->getByName( ::rtl::OUString::createFromAscii("ObjectUIName") ) >>= aUIName;
+ xEntry->getByName( ::rtl::OUString::createFromAscii("ClassID") ) >>= aClassID;
+
+ if ( aUIName.getLength() )
+ {
+ // replace %PRODUCTNAME
+ sal_Int32 nIndex = aUIName.indexOf( aStringProductName );
+ while( nIndex != -1 )
+ {
+ aUIName = aUIName.replaceAt( nIndex, nStringProductNameLength, aProductName );
+ nIndex = aUIName.indexOf( aStringProductName );
+ }
+
+ // replace %PRODUCTVERSION
+ nIndex = aUIName.indexOf( aStringProductVersion );
+ while( nIndex != -1 )
+ {
+ aUIName = aUIName.replaceAt( nIndex, nStringProductVersionLength, aProductVersion );
+ nIndex = aUIName.indexOf( aStringProductVersion );
+ }
+ }
+
+ SvGlobalName aClassName;
+ if( aClassName.MakeId( String( aClassID )))
+ {
+ if( !Get( aClassName ) )
+ // noch nicht eingetragen
+ Append( SvObjectServer( aClassName, String( aUIName.getStr() ) ) );
+ }
+ }
+ }
+ }
+ }
+ }
+
+
+#ifdef WNT
+ SvGlobalName aOleFact( SO3_OUT_CLASSID );
+ String aOleObj( SvtResId( STR_FURTHER_OBJECT ) );
+ Append( SvObjectServer( aOleFact, aOleObj ) );
+#endif
+
+ }catch( container::NoSuchElementException)
+ {
+ }catch( uno::Exception)
+ {
+ }
+ catch(...)
+ {
+ }
+}
+
+String SvPasteObjectHelper::GetSotFormatUIName( SotFormatStringId nId )
+{
+ struct SotResourcePair
+ {
+ SotFormatStringId mnSotId;
+ USHORT mnResId;
+ };
+
+ static const SotResourcePair aSotResourcePairs[] =
+ {
+ { SOT_FORMAT_STRING, STR_FORMAT_STRING },
+ { SOT_FORMAT_BITMAP, STR_FORMAT_BITMAP },
+ { SOT_FORMAT_GDIMETAFILE, STR_FORMAT_GDIMETAFILE },
+ { SOT_FORMAT_RTF, STR_FORMAT_RTF },
+ { SOT_FORMATSTR_ID_DRAWING, STR_FORMAT_ID_DRAWING },
+ { SOT_FORMATSTR_ID_SVXB, STR_FORMAT_ID_SVXB },
+ { SOT_FORMATSTR_ID_INTERNALLINK_STATE, STR_FORMAT_ID_INTERNALLINK_STATE },
+ { SOT_FORMATSTR_ID_SOLK, STR_FORMAT_ID_SOLK },
+ { SOT_FORMATSTR_ID_NETSCAPE_BOOKMARK, STR_FORMAT_ID_NETSCAPE_BOOKMARK },
+ { SOT_FORMATSTR_ID_STARSERVER, STR_FORMAT_ID_STARSERVER },
+ { SOT_FORMATSTR_ID_STAROBJECT, STR_FORMAT_ID_STAROBJECT },
+ { SOT_FORMATSTR_ID_APPLETOBJECT, STR_FORMAT_ID_APPLETOBJECT },
+ { SOT_FORMATSTR_ID_PLUGIN_OBJECT, STR_FORMAT_ID_PLUGIN_OBJECT },
+ { SOT_FORMATSTR_ID_STARWRITER_30, STR_FORMAT_ID_STARWRITER_30 },
+ { SOT_FORMATSTR_ID_STARWRITER_40, STR_FORMAT_ID_STARWRITER_40 },
+ { SOT_FORMATSTR_ID_STARWRITER_50, STR_FORMAT_ID_STARWRITER_50 },
+ { SOT_FORMATSTR_ID_STARWRITERWEB_40, STR_FORMAT_ID_STARWRITERWEB_40 },
+ { SOT_FORMATSTR_ID_STARWRITERWEB_50, STR_FORMAT_ID_STARWRITERWEB_50 },
+ { SOT_FORMATSTR_ID_STARWRITERGLOB_40, STR_FORMAT_ID_STARWRITERGLOB_40 },
+ { SOT_FORMATSTR_ID_STARWRITERGLOB_50, STR_FORMAT_ID_STARWRITERGLOB_50 },
+ { SOT_FORMATSTR_ID_STARDRAW, STR_FORMAT_ID_STARDRAW },
+ { SOT_FORMATSTR_ID_STARDRAW_40, STR_FORMAT_ID_STARDRAW_40 },
+ { SOT_FORMATSTR_ID_STARIMPRESS_50, STR_FORMAT_ID_STARIMPRESS_50 },
+ { SOT_FORMATSTR_ID_STARDRAW_50, STR_FORMAT_ID_STARDRAW_50 },
+ { SOT_FORMATSTR_ID_STARCALC, STR_FORMAT_ID_STARCALC },
+ { SOT_FORMATSTR_ID_STARCALC_40, STR_FORMAT_ID_STARCALC_40 },
+ { SOT_FORMATSTR_ID_STARCALC_50, STR_FORMAT_ID_STARCALC_50 },
+ { SOT_FORMATSTR_ID_STARCHART, STR_FORMAT_ID_STARCHART },
+ { SOT_FORMATSTR_ID_STARCHART_40, STR_FORMAT_ID_STARCHART_40 },
+ { SOT_FORMATSTR_ID_STARCHART_50, STR_FORMAT_ID_STARCHART_50 },
+ { SOT_FORMATSTR_ID_STARIMAGE, STR_FORMAT_ID_STARIMAGE },
+ { SOT_FORMATSTR_ID_STARIMAGE_40, STR_FORMAT_ID_STARIMAGE_40 },
+ { SOT_FORMATSTR_ID_STARIMAGE_50, STR_FORMAT_ID_STARIMAGE_50 },
+ { SOT_FORMATSTR_ID_STARMATH, STR_FORMAT_ID_STARMATH },
+ { SOT_FORMATSTR_ID_STARMATH_40, STR_FORMAT_ID_STARMATH_40 },
+ { SOT_FORMATSTR_ID_STARMATH_50, STR_FORMAT_ID_STARMATH_50 },
+ { SOT_FORMATSTR_ID_STAROBJECT_PAINTDOC, STR_FORMAT_ID_STAROBJECT_PAINTDOC },
+ { SOT_FORMATSTR_ID_HTML, STR_FORMAT_ID_HTML },
+ { SOT_FORMATSTR_ID_HTML_SIMPLE, STR_FORMAT_ID_HTML_SIMPLE },
+ { SOT_FORMATSTR_ID_BIFF_5, STR_FORMAT_ID_BIFF_5 },
+ { SOT_FORMATSTR_ID_BIFF_8, STR_FORMAT_ID_BIFF_8 },
+ { SOT_FORMATSTR_ID_SYLK, STR_FORMAT_ID_SYLK },
+ { SOT_FORMATSTR_ID_LINK, STR_FORMAT_ID_LINK },
+ { SOT_FORMATSTR_ID_DIF, STR_FORMAT_ID_DIF },
+ { SOT_FORMATSTR_ID_MSWORD_DOC, STR_FORMAT_ID_MSWORD_DOC },
+ { SOT_FORMATSTR_ID_STAR_FRAMESET_DOC, STR_FORMAT_ID_STAR_FRAMESET_DOC },
+ { SOT_FORMATSTR_ID_OFFICE_DOC, STR_FORMAT_ID_OFFICE_DOC },
+ { SOT_FORMATSTR_ID_NOTES_DOCINFO, STR_FORMAT_ID_NOTES_DOCINFO },
+ { SOT_FORMATSTR_ID_SFX_DOC, STR_FORMAT_ID_SFX_DOC },
+ { SOT_FORMATSTR_ID_STARCHARTDOCUMENT_50,STR_FORMAT_ID_STARCHARTDOCUMENT_50 },
+ { SOT_FORMATSTR_ID_GRAPHOBJ, STR_FORMAT_ID_GRAPHOBJ },
+ { SOT_FORMATSTR_ID_STARWRITER_60, STR_FORMAT_ID_STARWRITER_60 },
+ { SOT_FORMATSTR_ID_STARWRITERWEB_60, STR_FORMAT_ID_STARWRITERWEB_60 },
+ { SOT_FORMATSTR_ID_STARWRITERGLOB_60, STR_FORMAT_ID_STARWRITERGLOB_60 },
+ { SOT_FORMATSTR_ID_STARDRAW_60, STR_FORMAT_ID_STARDRAW_60 },
+ { SOT_FORMATSTR_ID_STARIMPRESS_60, STR_FORMAT_ID_STARIMPRESS_60 },
+ { SOT_FORMATSTR_ID_STARCALC_60, STR_FORMAT_ID_STARCALC_60 },
+ { SOT_FORMATSTR_ID_STARCHART_60, STR_FORMAT_ID_STARCHART_60 },
+ { SOT_FORMATSTR_ID_STARMATH_60, STR_FORMAT_ID_STARMATH_60 },
+ { SOT_FORMATSTR_ID_WMF, STR_FORMAT_ID_WMF },
+ { SOT_FORMATSTR_ID_DBACCESS_QUERY, STR_FORMAT_ID_DBACCESS_QUERY },
+ { SOT_FORMATSTR_ID_DBACCESS_TABLE, STR_FORMAT_ID_DBACCESS_TABLE },
+ { SOT_FORMATSTR_ID_DBACCESS_COMMAND, STR_FORMAT_ID_DBACCESS_COMMAND },
+ { SOT_FORMATSTR_ID_DIALOG_60, STR_FORMAT_ID_DIALOG_60 },
+ { SOT_FORMATSTR_ID_FILEGRPDESCRIPTOR, STR_FORMAT_ID_FILEGRPDESCRIPTOR },
+ { SOT_FORMATSTR_ID_HTML_NO_COMMENT, STR_FORMAT_ID_HTML_NO_COMMENT }
+ };
+
+ String aUIName;
+ USHORT nResId = 0;
+
+ for( sal_uInt32 i = 0, nCount = sizeof( aSotResourcePairs ) / sizeof( aSotResourcePairs[ 0 ] ); ( i < nCount ) && !nResId; i++ )
+ {
+ if( aSotResourcePairs[ i ].mnSotId == nId )
+ nResId = aSotResourcePairs[ i ].mnResId;
+ }
+
+ if( nResId )
+ aUIName = String( SvtResId( nResId ) );
+ else
+ aUIName = SotExchange::GetFormatName( nId );
+
+ return aUIName;
+}
+// -----------------------------------------------------------------------------
+sal_Bool SvPasteObjectHelper::GetEmbeddedName(const TransferableDataHelper& rData,String& _rName,String& _rSource,SotFormatStringId& _nFormat)
+{
+ sal_Bool bRet = sal_False;
+ if( _nFormat == SOT_FORMATSTR_ID_EMBED_SOURCE_OLE || _nFormat == SOT_FORMATSTR_ID_EMBEDDED_OBJ_OLE )
+ {
+ datatransfer::DataFlavor aFlavor;
+ SotExchange::GetFormatDataFlavor( SOT_FORMATSTR_ID_OBJECTDESCRIPTOR_OLE, aFlavor );
+
+ uno::Any aAny;
+ if( rData.HasFormat( aFlavor ) &&
+ ( aAny = rData.GetAny( aFlavor ) ).hasValue() )
+ {
+ uno::Sequence< sal_Int8 > anySequence;
+ aAny >>= anySequence;
+
+ OleObjectDescriptor* pOleObjDescr =
+ reinterpret_cast< OleObjectDescriptor* >( anySequence.getArray( ) );
+
+ // determine the user friendly description of the embedded object
+ if ( pOleObjDescr->dwFullUserTypeName )
+ {
+ // we set the pointer to the start of user friendly description
+ // string. it starts at &OleObjectDescriptor + dwFullUserTypeName.
+ // dwFullUserTypeName is the offset in bytes.
+ // the user friendly description string is '\0' terminated.
+ const sal_Unicode* pUserTypeName =
+ reinterpret_cast< sal_Unicode* >(
+ reinterpret_cast< sal_Char* >( pOleObjDescr ) +
+ pOleObjDescr->dwFullUserTypeName );
+
+ _rName.Append( pUserTypeName );
+ // the following statement was here for historical reasons, it is commented out since it causes bug i49460
+ // _nFormat = SOT_FORMATSTR_ID_EMBED_SOURCE_OLE;
+ }
+
+ // determine the source of the embedded object
+ if ( pOleObjDescr->dwSrcOfCopy )
+ {
+ // we set the pointer to the start of source string
+ // it starts at &OleObjectDescriptor + dwSrcOfCopy.
+ // dwSrcOfCopy is the offset in bytes.
+ // the source string is '\0' terminated.
+ const sal_Unicode* pSrcOfCopy =
+ reinterpret_cast< sal_Unicode* >(
+ reinterpret_cast< sal_Char* >( pOleObjDescr ) +
+ pOleObjDescr->dwSrcOfCopy );
+
+ _rSource.Append( pSrcOfCopy );
+ }
+ else
+ _rSource =
+ String( SvtResId( STR_UNKNOWN_SOURCE ) );
+ }
+ bRet = sal_True;
+ }
+ return bRet;
+}
+// -----------------------------------------------------------------------------
+