diff options
-rwxr-xr-x | bin/get-bugzilla-attachments-by-mimetype | 2 | ||||
-rw-r--r-- | configure.ac | 2 | ||||
-rw-r--r-- | filter/Configuration_filter.mk | 2 | ||||
-rw-r--r-- | filter/source/config/fragments/filters/ApplePages.xcu | 29 | ||||
-rw-r--r-- | filter/source/config/fragments/types/writer_ApplePages.xcu | 29 | ||||
-rw-r--r-- | writerperfect/Library_wpftwriter.mk | 2 | ||||
-rw-r--r-- | writerperfect/qa/unit/WpftWriterFilterTest.cxx | 1 | ||||
-rw-r--r-- | writerperfect/qa/unit/data/writer/libetonyek/fail/.gitignore | 0 | ||||
-rw-r--r-- | writerperfect/qa/unit/data/writer/libetonyek/indeterminate/.gitignore | 0 | ||||
-rw-r--r-- | writerperfect/qa/unit/data/writer/libetonyek/pass/Pages_4.pages | bin | 0 -> 42277 bytes | |||
-rw-r--r-- | writerperfect/source/writer/PagesImportFilter.cxx | 87 | ||||
-rw-r--r-- | writerperfect/source/writer/PagesImportFilter.hxx | 53 | ||||
-rw-r--r-- | writerperfect/source/writer/wpftwriter.component | 4 | ||||
-rw-r--r-- | writerperfect/source/writer/wpftwriter_genericfilter.cxx | 6 |
14 files changed, 216 insertions, 1 deletions
diff --git a/bin/get-bugzilla-attachments-by-mimetype b/bin/get-bugzilla-attachments-by-mimetype index 8b0b4c5049e1..1c87589a5c93 100755 --- a/bin/get-bugzilla-attachments-by-mimetype +++ b/bin/get-bugzilla-attachments-by-mimetype @@ -422,7 +422,9 @@ mimetypes = { 'application/clarisworks' : 'cwk', 'application/macwriteii' : 'mw', 'application/vnd.apple.keynote': 'key', + 'application/vnd.apple.pages': 'pages', 'application/x-iwork-keynote-sffkey': 'key', + 'application/x-iwork-pages-sffpages': 'pages', 'application/x-hwp': 'hwp', 'application/x-aportisdoc': 'pdb', 'application/prs.plucker' : 'pdb_plucker', diff --git a/configure.ac b/configure.ac index b9e2658cc580..f6c541f805d2 100644 --- a/configure.ac +++ b/configure.ac @@ -7585,7 +7585,7 @@ libo_CHECK_SYSTEM_MODULE([libebook],[EBOOK],[libe-book-0.1 >= 0.1.1]) dnl =================================================================== dnl Check for system libetonyek dnl =================================================================== -libo_CHECK_SYSTEM_MODULE([libetonyek],[ETONYEK],[libetonyek-0.1 >= 0.1.1]) +libo_CHECK_SYSTEM_MODULE([libetonyek],[ETONYEK],[libetonyek-0.1 >= 0.1.2]) dnl =================================================================== dnl Check for system libfreehand diff --git a/filter/Configuration_filter.mk b/filter/Configuration_filter.mk index c2d207629295..91ef26fde92f 100644 --- a/filter/Configuration_filter.mk +++ b/filter/Configuration_filter.mk @@ -369,6 +369,7 @@ $(eval $(call filter_Configuration_add_types,fcfg_langpack,fcfg_writer_types.xcu writer_Plucker_eBook \ writer_TealDoc \ writer_zTXT \ + writer_ApplePages \ )) $(eval $(call filter_Configuration_add_filters,fcfg_langpack,fcfg_writer_filters.xcu,filter/source/config/fragments/filters,\ @@ -431,6 +432,7 @@ $(eval $(call filter_Configuration_add_filters,fcfg_langpack,fcfg_writer_filters Plucker_eBook \ TealDoc \ zTXT \ + ApplePages \ )) # fcfg_web diff --git a/filter/source/config/fragments/filters/ApplePages.xcu b/filter/source/config/fragments/filters/ApplePages.xcu new file mode 100644 index 000000000000..4b772774f6e3 --- /dev/null +++ b/filter/source/config/fragments/filters/ApplePages.xcu @@ -0,0 +1,29 @@ +<!-- + * 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/. + * +--> + +<node oor:name="Apple Pages" oor:op="replace"> + <prop oor:name="Flags"> + <value>IMPORT ALIEN USESOPTIONS 3RDPARTYFILTER PREFERRED</value> + </prop> + <prop oor:name="FilterService"> + <value>org.libreoffice.comp.Writer.PagesImportFilter</value> + </prop> + <prop oor:name="UIName"> + <value xml:lang="en-US">Apple Pages 4</value> + </prop> + <prop oor:name="FileFormatVersion"> + <value>0</value> + </prop> + <prop oor:name="Type"> + <value>writer_ApplePages</value> + </prop> + <prop oor:name="DocumentService"> + <value>com.sun.star.text.TextDocument</value> + </prop> +</node> diff --git a/filter/source/config/fragments/types/writer_ApplePages.xcu b/filter/source/config/fragments/types/writer_ApplePages.xcu new file mode 100644 index 000000000000..823a766b50a3 --- /dev/null +++ b/filter/source/config/fragments/types/writer_ApplePages.xcu @@ -0,0 +1,29 @@ +<!-- + * 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/. + * +--> + +<node oor:name="writer_ApplePages" oor:op="replace"> + <prop oor:name="DetectService"> + <value>org.libreoffice.comp.Writer.PagesImportFilter</value> + </prop> + <prop oor:name="Extensions"> + <value>pages</value> + </prop> + <prop oor:name="MediaType"> + <value>application/x-iwork-pages-sffpages</value> + </prop> + <prop oor:name="Preferred"> + <value>true</value> + </prop> + <prop oor:name="PreferredFilter"> + <value>Apple Pages</value> + </prop> + <prop oor:name="UIName"> + <value>Apple Pages</value> + </prop> +</node> diff --git a/writerperfect/Library_wpftwriter.mk b/writerperfect/Library_wpftwriter.mk index 8c32ea366f8f..8557991594b2 100644 --- a/writerperfect/Library_wpftwriter.mk +++ b/writerperfect/Library_wpftwriter.mk @@ -50,6 +50,7 @@ $(eval $(call gb_Library_use_externals,wpftwriter,\ abw \ boost_headers \ ebook \ + etonyek \ icui18n \ icuuc \ libxml2 \ @@ -67,6 +68,7 @@ $(eval $(call gb_Library_add_exception_objects,wpftwriter,\ writerperfect/source/writer/EBookImportFilter \ writerperfect/source/writer/MSWorksImportFilter \ writerperfect/source/writer/MWAWImportFilter \ + writerperfect/source/writer/PagesImportFilter \ writerperfect/source/writer/WordPerfectImportFilter \ writerperfect/source/writer/wpftwriter_genericfilter \ )) diff --git a/writerperfect/qa/unit/WpftWriterFilterTest.cxx b/writerperfect/qa/unit/WpftWriterFilterTest.cxx index 904daab2d4aa..f8f9f8504bdc 100644 --- a/writerperfect/qa/unit/WpftWriterFilterTest.cxx +++ b/writerperfect/qa/unit/WpftWriterFilterTest.cxx @@ -35,6 +35,7 @@ void WpftWriterFilterTest::test() doTest("org.libreoffice.comp.Writer.EBookImportFilter", "/writerperfect/qa/unit/data/writer/libe-book/"); doTest("com.sun.star.comp.Writer.MSWorksImportFilter", "/writerperfect/qa/unit/data/writer/libwps/"); doTest("com.sun.star.comp.Writer.MWAWImportFilter", "/writerperfect/qa/unit/data/writer/libmwaw/"); + doTest("org.libreoffice.comp.Writer.PagesImportFilter", "/writerperfect/qa/unit/data/writer/libetonyek/"); doTest("com.sun.star.comp.Writer.WordPerfectImportFilter", "/writerperfect/qa/unit/data/writer/libwpd/"); } diff --git a/writerperfect/qa/unit/data/writer/libetonyek/fail/.gitignore b/writerperfect/qa/unit/data/writer/libetonyek/fail/.gitignore new file mode 100644 index 000000000000..e69de29bb2d1 --- /dev/null +++ b/writerperfect/qa/unit/data/writer/libetonyek/fail/.gitignore diff --git a/writerperfect/qa/unit/data/writer/libetonyek/indeterminate/.gitignore b/writerperfect/qa/unit/data/writer/libetonyek/indeterminate/.gitignore new file mode 100644 index 000000000000..e69de29bb2d1 --- /dev/null +++ b/writerperfect/qa/unit/data/writer/libetonyek/indeterminate/.gitignore diff --git a/writerperfect/qa/unit/data/writer/libetonyek/pass/Pages_4.pages b/writerperfect/qa/unit/data/writer/libetonyek/pass/Pages_4.pages Binary files differnew file mode 100644 index 000000000000..43c9213922bd --- /dev/null +++ b/writerperfect/qa/unit/data/writer/libetonyek/pass/Pages_4.pages diff --git a/writerperfect/source/writer/PagesImportFilter.cxx b/writerperfect/source/writer/PagesImportFilter.cxx new file mode 100644 index 000000000000..3942aa0984b8 --- /dev/null +++ b/writerperfect/source/writer/PagesImportFilter.cxx @@ -0,0 +1,87 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* PagesImportFilter: Sets up the filter, and calls DocumentCollector + * to do the actual filtering + * + * 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/. + */ + +#include <libetonyek/libetonyek.h> + +#include <com/sun/star/uno/Reference.h> + +#include <cppuhelper/supportsservice.hxx> + +#include "PagesImportFilter.hxx" + +using com::sun::star::uno::Sequence; +using com::sun::star::uno::Reference; +using com::sun::star::uno::Any; +using com::sun::star::uno::XInterface; +using com::sun::star::uno::Exception; +using com::sun::star::uno::RuntimeException; +using com::sun::star::uno::XComponentContext; + +using libetonyek::EtonyekDocument; + +bool PagesImportFilter::doImportDocument(librevenge::RVNGInputStream &rInput, OdtGenerator &rGenerator, utl::MediaDescriptor &) +{ + return EtonyekDocument::parse(&rInput, &rGenerator); +} + +bool PagesImportFilter::doDetectFormat(librevenge::RVNGInputStream &rInput, OUString &rTypeName) +{ + EtonyekDocument::Type type = EtonyekDocument::TYPE_UNKNOWN; + const EtonyekDocument::Confidence confidence = EtonyekDocument::isSupported(&rInput, &type); + if ((confidence == EtonyekDocument::CONFIDENCE_EXCELLENT) && (type == EtonyekDocument::TYPE_PAGES)) + { + rTypeName = "writer_ApplePages"; + return true; + } + + return false; +} + +OUString PagesImportFilter_getImplementationName() +throw (RuntimeException) +{ + return OUString("org.libreoffice.comp.Writer.PagesImportFilter"); +} + +Sequence< OUString > SAL_CALL PagesImportFilter_getSupportedServiceNames() +throw (RuntimeException) +{ + Sequence < OUString > aRet(2); + OUString *pArray = aRet.getArray(); + pArray[0] = "com.sun.star.document.ImportFilter"; + pArray[1] = "com.sun.star.document.ExtendedTypeDetection"; + return aRet; +} + +Reference< XInterface > SAL_CALL PagesImportFilter_createInstance(const Reference< XComponentContext > &rContext) +throw(Exception) +{ + return static_cast<cppu::OWeakObject *>(new PagesImportFilter(rContext)); +} + +// XServiceInfo +OUString SAL_CALL PagesImportFilter::getImplementationName() +throw (RuntimeException, std::exception) +{ + return PagesImportFilter_getImplementationName(); +} +sal_Bool SAL_CALL PagesImportFilter::supportsService(const OUString &rServiceName) +throw (RuntimeException, std::exception) +{ + return cppu::supportsService(this, rServiceName); +} +Sequence< OUString > SAL_CALL PagesImportFilter::getSupportedServiceNames() +throw (RuntimeException, std::exception) +{ + return PagesImportFilter_getSupportedServiceNames(); +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/writerperfect/source/writer/PagesImportFilter.hxx b/writerperfect/source/writer/PagesImportFilter.hxx new file mode 100644 index 000000000000..e527b0747169 --- /dev/null +++ b/writerperfect/source/writer/PagesImportFilter.hxx @@ -0,0 +1,53 @@ +/* -*- 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/. + */ + +#ifndef INCLUDED_WRITERPERFECT_SOURCE_WRITER_PAGESIMPORTFILTER_HXX +#define INCLUDED_WRITERPERFECT_SOURCE_WRITER_PAGESIMPORTFILTER_HXX + +#include <com/sun/star/lang/XServiceInfo.hpp> +#include <com/sun/star/uno/XComponentContext.hpp> + +#include "DocumentHandlerForOdt.hxx" +#include "ImportFilter.hxx" + +/* This component will be instantiated for both import or export. Whether it calls + * setSourceDocument or setTargetDocument determines which Impl function the filter + * member calls */ +class PagesImportFilter : public writerperfect::ImportFilter<OdtGenerator> +{ +public: + PagesImportFilter(const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XComponentContext > &rxContext) + : writerperfect::ImportFilter<OdtGenerator>(rxContext) {} + + // XServiceInfo + virtual OUString SAL_CALL getImplementationName() + throw (::com::sun::star::uno::RuntimeException, std::exception) SAL_OVERRIDE; + virtual sal_Bool SAL_CALL supportsService(const OUString &ServiceName) + throw (::com::sun::star::uno::RuntimeException, std::exception) SAL_OVERRIDE; + virtual ::com::sun::star::uno::Sequence< OUString > SAL_CALL getSupportedServiceNames() + throw (::com::sun::star::uno::RuntimeException, std::exception) SAL_OVERRIDE; + +private: + virtual bool doDetectFormat(librevenge::RVNGInputStream &rInput, OUString &rTypeName) SAL_OVERRIDE; + virtual bool doImportDocument(librevenge::RVNGInputStream &rInput, OdtGenerator &rGenerator, utl::MediaDescriptor &rDescriptor) SAL_OVERRIDE; +}; + +OUString PagesImportFilter_getImplementationName() +throw (::com::sun::star::uno::RuntimeException); + +::com::sun::star::uno::Sequence< OUString > SAL_CALL PagesImportFilter_getSupportedServiceNames() +throw (::com::sun::star::uno::RuntimeException); + +::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > +SAL_CALL PagesImportFilter_createInstance(const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XComponentContext > &rContext) +throw (::com::sun::star::uno::Exception); + +#endif + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/writerperfect/source/writer/wpftwriter.component b/writerperfect/source/writer/wpftwriter.component index 8a204ec24746..eaf751a1003d 100644 --- a/writerperfect/source/writer/wpftwriter.component +++ b/writerperfect/source/writer/wpftwriter.component @@ -38,4 +38,8 @@ <service name="com.sun.star.document.ExtendedTypeDetection"/> <service name="com.sun.star.document.ImportFilter"/> </implementation> + <implementation name="org.libreoffice.comp.Writer.PagesImportFilter"> + <service name="com.sun.star.document.ExtendedTypeDetection"/> + <service name="com.sun.star.document.ImportFilter"/> + </implementation> </component> diff --git a/writerperfect/source/writer/wpftwriter_genericfilter.cxx b/writerperfect/source/writer/wpftwriter_genericfilter.cxx index cd60fe21a1d4..3f508c49f40d 100644 --- a/writerperfect/source/writer/wpftwriter_genericfilter.cxx +++ b/writerperfect/source/writer/wpftwriter_genericfilter.cxx @@ -36,6 +36,7 @@ #include "WordPerfectImportFilter.hxx" #include "MSWorksImportFilter.hxx" #include "MWAWImportFilter.hxx" +#include "PagesImportFilter.hxx" namespace { @@ -67,6 +68,11 @@ static cppu::ImplementationEntry const services[] = &EBookImportFilter_getSupportedServiceNames, &cppu::createSingleComponentFactory, 0, 0 }, + { + &PagesImportFilter_createInstance, &PagesImportFilter_getImplementationName, + &PagesImportFilter_getSupportedServiceNames, + &cppu::createSingleComponentFactory, 0, 0 + }, { 0, 0, 0, 0, 0, 0 } }; |