diff options
author | David Tardon <dtardon@redhat.com> | 2015-05-20 14:09:31 +0200 |
---|---|---|
committer | David Tardon <dtardon@redhat.com> | 2015-05-20 15:13:12 +0200 |
commit | a1202971e5b27ac4585cde73ed15f395c242cae3 (patch) | |
tree | 20c42fc62619d0d45292764ec5ccbfe3831900dc | |
parent | d5ffc8b0adacf31e88156588f57db3149f430ad3 (diff) |
enable Apple Numbers import
Change-Id: I9aaa4ae2e567b54f15097c265a3d1c3c12662b92
-rwxr-xr-x | bin/get-bugzilla-attachments-by-mimetype | 2 | ||||
-rw-r--r-- | filter/Configuration_filter.mk | 2 | ||||
-rw-r--r-- | filter/source/config/fragments/filters/AppleNumbers.xcu | 29 | ||||
-rw-r--r-- | filter/source/config/fragments/types/calc_AppleNumbers.xcu | 29 | ||||
-rw-r--r-- | writerperfect/Library_wpftcalc.mk | 2 | ||||
-rw-r--r-- | writerperfect/qa/unit/WpftCalcFilterTest.cxx | 1 | ||||
-rw-r--r-- | writerperfect/qa/unit/data/calc/libetonyek/fail/.gitignore | 0 | ||||
-rw-r--r-- | writerperfect/qa/unit/data/calc/libetonyek/indeterminate/.gitignore | 0 | ||||
-rw-r--r-- | writerperfect/qa/unit/data/calc/libetonyek/pass/Numbers_2.numbers | bin | 0 -> 113709 bytes | |||
-rw-r--r-- | writerperfect/source/calc/NumbersImportFilter.cxx | 91 | ||||
-rw-r--r-- | writerperfect/source/calc/NumbersImportFilter.hxx | 54 | ||||
-rw-r--r-- | writerperfect/source/calc/wpftcalc.component | 4 | ||||
-rw-r--r-- | writerperfect/source/calc/wpftcalc_genericfilter.cxx | 6 |
13 files changed, 220 insertions, 0 deletions
diff --git a/bin/get-bugzilla-attachments-by-mimetype b/bin/get-bugzilla-attachments-by-mimetype index 1c87589a5c93..ea92bb82258d 100755 --- a/bin/get-bugzilla-attachments-by-mimetype +++ b/bin/get-bugzilla-attachments-by-mimetype @@ -422,8 +422,10 @@ mimetypes = { 'application/clarisworks' : 'cwk', 'application/macwriteii' : 'mw', 'application/vnd.apple.keynote': 'key', + 'application/vnd.apple.numbers': 'numbers', 'application/vnd.apple.pages': 'pages', 'application/x-iwork-keynote-sffkey': 'key', + 'application/x-iwork-numbers-sffnumbers': 'numbers', 'application/x-iwork-pages-sffpages': 'pages', 'application/x-hwp': 'hwp', 'application/x-aportisdoc': 'pdb', diff --git a/filter/Configuration_filter.mk b/filter/Configuration_filter.mk index 91ef26fde92f..29e672bee4d2 100644 --- a/filter/Configuration_filter.mk +++ b/filter/Configuration_filter.mk @@ -518,6 +518,7 @@ $(eval $(call filter_Configuration_add_types,fcfg_langpack,fcfg_calc_types.xcu,f calc_Great_Works \ calc_Mac_Works \ calc_Mac_Wingz \ + calc_AppleNumbers \ )) $(eval $(call filter_Configuration_add_filters,fcfg_langpack,fcfg_calc_filters.xcu,filter/source/config/fragments/filters,\ @@ -558,6 +559,7 @@ $(eval $(call filter_Configuration_add_filters,fcfg_langpack,fcfg_calc_filters.x Great_Works_Calc \ Mac_Wingz_Calc \ Mac_Works_Calc \ + AppleNumbers \ )) # fcfg_draw diff --git a/filter/source/config/fragments/filters/AppleNumbers.xcu b/filter/source/config/fragments/filters/AppleNumbers.xcu new file mode 100644 index 000000000000..eced344241f6 --- /dev/null +++ b/filter/source/config/fragments/filters/AppleNumbers.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 Numbers" oor:op="replace"> + <prop oor:name="Flags"> + <value>IMPORT ALIEN USESOPTIONS 3RDPARTYFILTER PREFERRED</value> + </prop> + <prop oor:name="FilterService"> + <value>org.libreoffice.comp.Calc.NumbersImportFilter</value> + </prop> + <prop oor:name="UIName"> + <value xml:lang="en-US">Apple Numbers 2</value> + </prop> + <prop oor:name="FileFormatVersion"> + <value>0</value> + </prop> + <prop oor:name="Type"> + <value>calc_AppleNumbers</value> + </prop> + <prop oor:name="DocumentService"> + <value>com.sun.star.sheet.SpreadsheetDocument</value> + </prop> +</node> diff --git a/filter/source/config/fragments/types/calc_AppleNumbers.xcu b/filter/source/config/fragments/types/calc_AppleNumbers.xcu new file mode 100644 index 000000000000..d2030b82af85 --- /dev/null +++ b/filter/source/config/fragments/types/calc_AppleNumbers.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="calc_AppleNumbers" oor:op="replace"> + <prop oor:name="DetectService"> + <value>org.libreoffice.comp.Calc.NumbersImportFilter</value> + </prop> + <prop oor:name="Extensions"> + <value>numbers</value> + </prop> + <prop oor:name="MediaType"> + <value>application/x-iwork-numbers-sffnumbers</value> + </prop> + <prop oor:name="Preferred"> + <value>true</value> + </prop> + <prop oor:name="PreferredFilter"> + <value>Apple Numbers</value> + </prop> + <prop oor:name="UIName"> + <value>Apple Numbers</value> + </prop> +</node> diff --git a/writerperfect/Library_wpftcalc.mk b/writerperfect/Library_wpftcalc.mk index a68aa4846ffd..18cc378e8f91 100644 --- a/writerperfect/Library_wpftcalc.mk +++ b/writerperfect/Library_wpftcalc.mk @@ -45,6 +45,7 @@ $(eval $(call gb_Library_use_libraries,wpftcalc,\ $(eval $(call gb_Library_use_externals,wpftcalc,\ boost_headers \ + etonyek \ odfgen \ revenge \ mwaw \ @@ -59,6 +60,7 @@ $(eval $(call gb_Library_use_externals,wpftcalc,\ $(eval $(call gb_Library_add_exception_objects,wpftcalc,\ writerperfect/source/calc/MSWorksCalcImportFilter \ writerperfect/source/calc/MWAWCalcImportFilter \ + writerperfect/source/calc/NumbersImportFilter \ writerperfect/source/calc/wpftcalc_genericfilter \ )) diff --git a/writerperfect/qa/unit/WpftCalcFilterTest.cxx b/writerperfect/qa/unit/WpftCalcFilterTest.cxx index 6af5c048f53c..40d1ace53b48 100644 --- a/writerperfect/qa/unit/WpftCalcFilterTest.cxx +++ b/writerperfect/qa/unit/WpftCalcFilterTest.cxx @@ -33,6 +33,7 @@ void WpftCalcFilterTest::test() { doTest("com.sun.star.comp.Calc.MWAWCalcImportFilter", "/writerperfect/qa/unit/data/calc/libmwaw/"); doTest("com.sun.star.comp.Calc.MSWorksCalcImportFilter", "/writerperfect/qa/unit/data/calc/libwps/"); + doTest("org.libreoffice.comp.Calc.NumbersImportFilter", "/writerperfect/qa/unit/data/calc/libetonyek/"); } CPPUNIT_TEST_SUITE_REGISTRATION(WpftCalcFilterTest); diff --git a/writerperfect/qa/unit/data/calc/libetonyek/fail/.gitignore b/writerperfect/qa/unit/data/calc/libetonyek/fail/.gitignore new file mode 100644 index 000000000000..e69de29bb2d1 --- /dev/null +++ b/writerperfect/qa/unit/data/calc/libetonyek/fail/.gitignore diff --git a/writerperfect/qa/unit/data/calc/libetonyek/indeterminate/.gitignore b/writerperfect/qa/unit/data/calc/libetonyek/indeterminate/.gitignore new file mode 100644 index 000000000000..e69de29bb2d1 --- /dev/null +++ b/writerperfect/qa/unit/data/calc/libetonyek/indeterminate/.gitignore diff --git a/writerperfect/qa/unit/data/calc/libetonyek/pass/Numbers_2.numbers b/writerperfect/qa/unit/data/calc/libetonyek/pass/Numbers_2.numbers Binary files differnew file mode 100644 index 000000000000..307a49ccfc3a --- /dev/null +++ b/writerperfect/qa/unit/data/calc/libetonyek/pass/Numbers_2.numbers diff --git a/writerperfect/source/calc/NumbersImportFilter.cxx b/writerperfect/source/calc/NumbersImportFilter.cxx new file mode 100644 index 000000000000..ba8cf0e83fac --- /dev/null +++ b/writerperfect/source/calc/NumbersImportFilter.cxx @@ -0,0 +1,91 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* NumbersImportFilter: 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 "NumbersImportFilter.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 NumbersImportFilter::doImportDocument(librevenge::RVNGInputStream &rInput, OdsGenerator &rGenerator, utl::MediaDescriptor &) +{ + return EtonyekDocument::parse(&rInput, &rGenerator); +} + +bool NumbersImportFilter::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_NUMBERS)) + { + rTypeName = "calc_AppleNumbers"; + return true; + } + + return false; +} + +void NumbersImportFilter::doRegisterHandlers(OdsGenerator &) +{ +} + +OUString NumbersImportFilter_getImplementationName() +throw (RuntimeException) +{ + return OUString("org.libreoffice.comp.Calc.NumbersImportFilter"); +} + +Sequence< OUString > SAL_CALL NumbersImportFilter_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 NumbersImportFilter_createInstance(const Reference< XComponentContext > &rContext) +throw(Exception) +{ + return static_cast<cppu::OWeakObject *>(new NumbersImportFilter(rContext)); +} + +// XServiceInfo +OUString SAL_CALL NumbersImportFilter::getImplementationName() +throw (RuntimeException, std::exception) +{ + return NumbersImportFilter_getImplementationName(); +} +sal_Bool SAL_CALL NumbersImportFilter::supportsService(const OUString &rServiceName) +throw (RuntimeException, std::exception) +{ + return cppu::supportsService(this, rServiceName); +} +Sequence< OUString > SAL_CALL NumbersImportFilter::getSupportedServiceNames() +throw (RuntimeException, std::exception) +{ + return NumbersImportFilter_getSupportedServiceNames(); +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/writerperfect/source/calc/NumbersImportFilter.hxx b/writerperfect/source/calc/NumbersImportFilter.hxx new file mode 100644 index 000000000000..5b389649553b --- /dev/null +++ b/writerperfect/source/calc/NumbersImportFilter.hxx @@ -0,0 +1,54 @@ +/* -*- 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_NUMBERSIMPORTFILTER_HXX +#define INCLUDED_WRITERPERFECT_SOURCE_WRITER_NUMBERSIMPORTFILTER_HXX + +#include <com/sun/star/lang/XServiceInfo.hpp> +#include <com/sun/star/uno/XComponentContext.hpp> + +#include "DocumentHandlerForOds.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 NumbersImportFilter : public writerperfect::ImportFilter<OdsGenerator> +{ +public: + NumbersImportFilter(const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XComponentContext > &rxContext) + : writerperfect::ImportFilter<OdsGenerator>(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, OdsGenerator &rGenerator, utl::MediaDescriptor &) SAL_OVERRIDE; + virtual void doRegisterHandlers(OdsGenerator &rGenerator) SAL_OVERRIDE; +}; + +OUString NumbersImportFilter_getImplementationName() +throw (::com::sun::star::uno::RuntimeException); + +::com::sun::star::uno::Sequence< OUString > SAL_CALL NumbersImportFilter_getSupportedServiceNames() +throw (::com::sun::star::uno::RuntimeException); + +::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > +SAL_CALL NumbersImportFilter_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/calc/wpftcalc.component b/writerperfect/source/calc/wpftcalc.component index 68c5f85cef70..9216b33526f8 100644 --- a/writerperfect/source/calc/wpftcalc.component +++ b/writerperfect/source/calc/wpftcalc.component @@ -17,4 +17,8 @@ <service name="com.sun.star.document.ImportFilter"/> <service name="com.sun.star.document.ExtendedTypeDetection"/> </implementation> + <implementation name="org.libreoffice.comp.Calc.NumbersImportFilter"> + <service name="com.sun.star.document.ImportFilter"/> + <service name="com.sun.star.document.ExtendedTypeDetection"/> + </implementation> </component> diff --git a/writerperfect/source/calc/wpftcalc_genericfilter.cxx b/writerperfect/source/calc/wpftcalc_genericfilter.cxx index 9738c34b9e42..7ebe8f5dc554 100644 --- a/writerperfect/source/calc/wpftcalc_genericfilter.cxx +++ b/writerperfect/source/calc/wpftcalc_genericfilter.cxx @@ -31,6 +31,7 @@ #include "MSWorksCalcImportFilter.hxx" #include "MWAWCalcImportFilter.hxx" +#include "NumbersImportFilter.hxx" namespace { @@ -47,6 +48,11 @@ static cppu::ImplementationEntry const services[] = &MWAWCalcImportFilter_getSupportedServiceNames, &cppu::createSingleComponentFactory, 0, 0 }, + { + &NumbersImportFilter_createInstance, &NumbersImportFilter_getImplementationName, + &NumbersImportFilter_getSupportedServiceNames, + &cppu::createSingleComponentFactory, 0, 0 + }, { 0, 0, 0, 0, 0, 0 } }; |