summaryrefslogtreecommitdiff
path: root/sdext
diff options
context:
space:
mode:
authorNoel Grandin <noel.grandin@collabora.co.uk>2020-07-16 12:01:46 +0200
committerNoel Grandin <noel.grandin@collabora.co.uk>2020-07-16 21:19:20 +0200
commit3c446a4ded14ded98d88294ecf5f659718aee6ad (patch)
tree7d8e083d2fc085d51a5f99127f1a19826dc26165 /sdext
parentbaed93c8022bf64226fcbc6dbcb0132b35eb2328 (diff)
sdext/pdfimport: create instances with uno constructors
See tdf#74608 for motivation. Change-Id: I0c43eac5e325a22146c19f52a8226544c60b3aa9 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/98919 Tested-by: Jenkins Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
Diffstat (limited to 'sdext')
-rw-r--r--sdext/Library_pdfimport.mk1
-rw-r--r--sdext/source/pdfimport/filterdet.cxx8
-rw-r--r--sdext/source/pdfimport/pdfiadaptor.cxx39
-rw-r--r--sdext/source/pdfimport/pdfimport.component17
-rw-r--r--sdext/source/pdfimport/services.cxx145
5 files changed, 58 insertions, 152 deletions
diff --git a/sdext/Library_pdfimport.mk b/sdext/Library_pdfimport.mk
index 11a1a3e9aebf..3359ef5e6a46 100644
--- a/sdext/Library_pdfimport.mk
+++ b/sdext/Library_pdfimport.mk
@@ -57,7 +57,6 @@ $(eval $(call gb_Library_add_exception_objects,pdfimport,\
sdext/source/pdfimport/pdfparse/pdfparse \
sdext/source/pdfimport/sax/emitcontext \
sdext/source/pdfimport/sax/saxattrlist \
- sdext/source/pdfimport/services \
sdext/source/pdfimport/tree/drawtreevisiting \
sdext/source/pdfimport/tree/genericelements \
sdext/source/pdfimport/tree/imagecontainer \
diff --git a/sdext/source/pdfimport/filterdet.cxx b/sdext/source/pdfimport/filterdet.cxx
index b3fe676315fa..7619f4518b89 100644
--- a/sdext/source/pdfimport/filterdet.cxx
+++ b/sdext/source/pdfimport/filterdet.cxx
@@ -595,6 +595,14 @@ uno::Reference< io::XStream > getAdditionalStream( const OUString&
return xEmbed;
}
+
+extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface*
+sdext_PDFDetector_get_implementation(
+ css::uno::XComponentContext* context , css::uno::Sequence<css::uno::Any> const&)
+{
+ return cppu::acquire(new PDFDetector(context));
+}
+
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sdext/source/pdfimport/pdfiadaptor.cxx b/sdext/source/pdfimport/pdfiadaptor.cxx
index a496736dca78..45f35320fe30 100644
--- a/sdext/source/pdfimport/pdfiadaptor.cxx
+++ b/sdext/source/pdfimport/pdfiadaptor.cxx
@@ -326,6 +326,45 @@ css::uno::Sequence<OUString> PDFIRawAdaptor::getSupportedServiceNames()
return css::uno::Sequence<OUString>{"com.sun.star.document.ImportFilter"};
}
+
+
+extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface*
+sdext_PDFIRawAdaptor_Writer_get_implementation(
+ css::uno::XComponentContext* context , css::uno::Sequence<css::uno::Any> const&)
+{
+ pdfi::PDFIRawAdaptor* pAdaptor = new pdfi::PDFIRawAdaptor( "org.libreoffice.comp.documents.WriterPDFImport", context );
+ pAdaptor->setTreeVisitorFactory(pdfi::createWriterTreeVisitorFactory());
+ pAdaptor->acquire();
+ return static_cast<cppu::OWeakObject*>(pAdaptor);
+}
+
+extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface*
+sdext_PDFIRawAdaptor_Draw_get_implementation(
+ css::uno::XComponentContext* context , css::uno::Sequence<css::uno::Any> const&)
+{
+ pdfi::PDFIRawAdaptor* pAdaptor = new pdfi::PDFIRawAdaptor( "org.libreoffice.comp.documents.DrawPDFImport", context );
+ pAdaptor->setTreeVisitorFactory(pdfi::createDrawTreeVisitorFactory());
+ pAdaptor->acquire();
+ return static_cast<cppu::OWeakObject*>(pAdaptor);
+}
+
+extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface*
+sdext_PDFIRawAdaptor_Impress_get_implementation(
+ css::uno::XComponentContext* context , css::uno::Sequence<css::uno::Any> const&)
+{
+ pdfi::PDFIRawAdaptor* pAdaptor = new pdfi::PDFIRawAdaptor( "org.libreoffice.comp.documents.ImpressPDFImport", context );
+ pAdaptor->setTreeVisitorFactory(pdfi::createImpressTreeVisitorFactory());
+ pAdaptor->acquire();
+ return static_cast<cppu::OWeakObject*>(pAdaptor);
+}
+
+extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface*
+sdext_PDFIHybridAdaptor_get_implementation(
+ css::uno::XComponentContext* context , css::uno::Sequence<css::uno::Any> const&)
+{
+ return cppu::acquire(new pdfi::PDFIHybridAdaptor( context ));
+}
+
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sdext/source/pdfimport/pdfimport.component b/sdext/source/pdfimport/pdfimport.component
index 396b37ead8cb..125e90589656 100644
--- a/sdext/source/pdfimport/pdfimport.component
+++ b/sdext/source/pdfimport/pdfimport.component
@@ -8,20 +8,25 @@
*
-->
<component loader="com.sun.star.loader.SharedLibrary" environment="@CPPU_ENV@"
- prefix="pdfimport" xmlns="http://openoffice.org/2010/uno-components">
- <implementation name="org.libreoffice.comp.documents.HybridPDFImport">
+ xmlns="http://openoffice.org/2010/uno-components">
+ <implementation name="org.libreoffice.comp.documents.HybridPDFImport"
+ constructor="sdext_PDFIHybridAdaptor_get_implementation">
<service name="com.sun.star.document.ImportFilter"/>
</implementation>
- <implementation name="org.libreoffice.comp.documents.WriterPDFImport">
+ <implementation name="org.libreoffice.comp.documents.WriterPDFImport"
+ constructor="sdext_PDFIRawAdaptor_Writer_get_implementation">
<service name="com.sun.star.document.ImportFilter"/>
</implementation>
- <implementation name="org.libreoffice.comp.documents.DrawPDFImport">
+ <implementation name="org.libreoffice.comp.documents.DrawPDFImport"
+ constructor="sdext_PDFIRawAdaptor_Draw_get_implementation">
<service name="com.sun.star.document.ImportFilter"/>
</implementation>
- <implementation name="org.libreoffice.comp.documents.ImpressPDFImport">
+ <implementation name="org.libreoffice.comp.documents.ImpressPDFImport"
+ constructor="sdext_PDFIRawAdaptor_Impress_get_implementation">
<service name="com.sun.star.document.ImportFilter"/>
</implementation>
- <implementation name="org.libreoffice.comp.documents.PDFDetector">
+ <implementation name="org.libreoffice.comp.documents.PDFDetector"
+ constructor="sdext_PDFDetector_get_implementation">
<service name="com.sun.star.document.ImportFilter"/>
</implementation>
</component>
diff --git a/sdext/source/pdfimport/services.cxx b/sdext/source/pdfimport/services.cxx
deleted file mode 100644
index b15f497dc481..000000000000
--- a/sdext/source/pdfimport/services.cxx
+++ /dev/null
@@ -1,145 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This file is part of the LibreOffice project.
- *
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/.
- *
- * This file incorporates work covered by the following license notice:
- *
- * 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 .
- */
-
-
-#include "pdfiadaptor.hxx"
-#include "filterdet.hxx"
-#include <treevisitorfactory.hxx>
-
-#include <cppuhelper/factory.hxx>
-#include <com/sun/star/lang/XSingleComponentFactory.hpp>
-
-using namespace ::com::sun::star;
-using namespace ::com::sun::star::uno;
-using namespace ::com::sun::star::lang;
-using namespace ::com::sun::star::registry;
-
-
-namespace
-{
- Reference< XInterface > Create_PDFIHybridAdaptor( const Reference< XComponentContext >& _rxContext )
- {
- return *(new pdfi::PDFIHybridAdaptor( _rxContext ));
- }
-
- Reference< XInterface > Create_PDFIRawAdaptor_Writer( const Reference< XComponentContext >& _rxContext )
- {
- pdfi::PDFIRawAdaptor* pAdaptor = new pdfi::PDFIRawAdaptor( "org.libreoffice.comp.documents.WriterPDFImport", _rxContext );
-
- pAdaptor->setTreeVisitorFactory(pdfi::createWriterTreeVisitorFactory());
-
- return uno::Reference<uno::XInterface>(static_cast<xml::XImportFilter*>(pAdaptor));
- }
-
- Reference< XInterface > Create_PDFIRawAdaptor_Draw( const Reference< XComponentContext >& _rxContext )
- {
- pdfi::PDFIRawAdaptor* pAdaptor = new pdfi::PDFIRawAdaptor( "org.libreoffice.comp.documents.DrawPDFImport", _rxContext );
-
- pAdaptor->setTreeVisitorFactory(pdfi::createDrawTreeVisitorFactory());
-
- return uno::Reference<uno::XInterface>(static_cast<xml::XImportFilter*>(pAdaptor));
- }
-
- Reference< XInterface > Create_PDFIRawAdaptor_Impress( const Reference< XComponentContext >& _rxContext )
- {
- pdfi::PDFIRawAdaptor* pAdaptor = new pdfi::PDFIRawAdaptor( "org.libreoffice.comp.documents.ImpressPDFImport", _rxContext );
-
- pAdaptor->setTreeVisitorFactory(pdfi::createImpressTreeVisitorFactory());
-
- return uno::Reference<uno::XInterface>(static_cast<xml::XImportFilter*>(pAdaptor));
- }
-
- Reference< XInterface > Create_PDFDetector( const Reference< XComponentContext >& _rxContext )
- {
- return *(new pdfi::PDFDetector( _rxContext ) );
- }
-}
-
-namespace
-{
- typedef Reference< XInterface > (* ComponentFactory)( const Reference< XComponentContext >& );
-
- struct ComponentDescription
- {
- const char* pAsciiServiceName;
- const char* pAsciiImplementationName;
- ComponentFactory pFactory;
-
- ComponentDescription()
- :pAsciiServiceName( nullptr )
- ,pAsciiImplementationName( nullptr )
- ,pFactory( nullptr )
- {
- }
- ComponentDescription( const char* _pAsciiServiceName, const char* _pAsciiImplementationName, ComponentFactory _pFactory )
- :pAsciiServiceName( _pAsciiServiceName )
- ,pAsciiImplementationName( _pAsciiImplementationName )
- ,pFactory( _pFactory )
- {
- }
- };
-
- const ComponentDescription* lcl_getComponents()
- {
- static const ComponentDescription aDescriptions[] = {
- ComponentDescription( "com.sun.star.document.ImportFilter", "org.libreoffice.comp.documents.HybridPDFImport", Create_PDFIHybridAdaptor ),
- ComponentDescription( "com.sun.star.document.ImportFilter", "org.libreoffice.comp.documents.WriterPDFImport", Create_PDFIRawAdaptor_Writer ),
- ComponentDescription( "com.sun.star.document.ImportFilter", "org.libreoffice.comp.documents.DrawPDFImport", Create_PDFIRawAdaptor_Draw ),
- ComponentDescription( "com.sun.star.document.ImportFilter", "org.libreoffice.comp.documents.ImpressPDFImport", Create_PDFIRawAdaptor_Impress ),
- ComponentDescription( "com.sun.star.document.ImportFilter", "org.libreoffice.comp.documents.PDFDetector", Create_PDFDetector ),
- ComponentDescription()
- };
- return aDescriptions;
- }
-}
-
-extern "C" SAL_DLLPUBLIC_EXPORT void* pdfimport_component_getFactory(
- const char* pImplementationName,
- SAL_UNUSED_PARAMETER void* /*pServiceManager*/,
- SAL_UNUSED_PARAMETER void* /*pRegistryKey*/ )
-{
- OUString sImplementationName( OUString::createFromAscii( pImplementationName ) );
-
- Reference< XSingleComponentFactory > xFactory;
-
- const ComponentDescription* pComponents = lcl_getComponents();
- while ( pComponents->pAsciiServiceName != nullptr )
- {
- if ( sImplementationName.equalsAscii( pComponents->pAsciiImplementationName ) )
- {
- Sequence< OUString > sServices(1);
- sServices[0] = OUString::createFromAscii( pComponents->pAsciiServiceName );
-
- xFactory = ::cppu::createSingleComponentFactory(
- pComponents->pFactory,
- sImplementationName,
- sServices
- );
- break;
- }
-
- ++pComponents;
- }
-
- // by definition, objects returned via this C API need to ber acquired once
- xFactory->acquire();
- return xFactory.get();
-}
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */