diff options
author | Markus Mohrhard <markus.mohrhard@googlemail.com> | 2017-07-30 19:59:50 +0200 |
---|---|---|
committer | Markus Mohrhard <markus.mohrhard@googlemail.com> | 2017-07-31 04:30:23 +0200 |
commit | ce1b56ae4ad35fbb5e2f5cc6f4b7ce4839f4e285 (patch) | |
tree | 2ec14ff8cb6eb81ac9fbfa8f3f19e986e65fe8ac /sc/source/filter/xml/xmlmappingi.cxx | |
parent | 20ecb4b7b807b63d25195c44c02cb5bf0624ab7a (diff) |
add initial file format representation for data import feature
Change-Id: I51143ecfe4eb1584f13bd1590f927743de8fa91e
Reviewed-on: https://gerrit.libreoffice.org/40572
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Markus Mohrhard <markus.mohrhard@googlemail.com>
Diffstat (limited to 'sc/source/filter/xml/xmlmappingi.cxx')
-rw-r--r-- | sc/source/filter/xml/xmlmappingi.cxx | 143 |
1 files changed, 143 insertions, 0 deletions
diff --git a/sc/source/filter/xml/xmlmappingi.cxx b/sc/source/filter/xml/xmlmappingi.cxx new file mode 100644 index 000000000000..f65c929c070c --- /dev/null +++ b/sc/source/filter/xml/xmlmappingi.cxx @@ -0,0 +1,143 @@ +/* -*- 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/. + */ + +#include "xmlmappingi.hxx" + +#include <xmloff/xmltkmap.hxx> +#include <xmloff/nmspmap.hxx> +#include <xmloff/xmltoken.hxx> +#include <xmloff/xmlnmspe.hxx> +#include <xmloff/xmlerror.hxx> + +#include "datamapper.hxx" +#include "document.hxx" +#include "dbdata.hxx" + +#include <sax/tools/converter.hxx> + +using namespace com::sun::star; +using namespace xmloff::token; + +ScXMLMappingsContext::ScXMLMappingsContext( ScXMLImport& rImport, + sal_Int32 /*nElement*/, + const css::uno::Reference<css::xml::sax::XFastAttributeList>& /* xAttrList */ ) : + ScXMLImportContext( rImport ) +{ + // has no attributes + rImport.LockSolarMutex(); +} + +ScXMLMappingsContext::~ScXMLMappingsContext() +{ + GetScImport().UnlockSolarMutex(); +} + +uno::Reference< xml::sax::XFastContextHandler > SAL_CALL ScXMLMappingsContext::createFastChildContext( + sal_Int32 nElement, + const uno::Reference< xml::sax::XFastAttributeList >& xAttrList ) +{ + SvXMLImportContext *pContext = nullptr; + + switch( nElement ) + { + case XML_ELEMENT( CALC_EXT, XML_DATA_MAPPING ): + { + pContext = new ScXMLMappingContext( GetScImport(), nElement, xAttrList ); + } + break; + } + + if( !pContext ) + pContext = new SvXMLImportContext( GetImport() ); + + return pContext; +} + +ScXMLMappingContext::ScXMLMappingContext( ScXMLImport& rImport, + sal_Int32 /*nElement*/, + const css::uno::Reference<css::xml::sax::XFastAttributeList>& xAttrList) : + ScXMLImportContext( rImport ) +{ + OUString aProvider; + OUString aID; + OUString aURL; + // OUString aFrequency; + OUString aDBName; + if( xAttrList.is() ) + { + sax_fastparser::FastAttributeList *pAttribList = + sax_fastparser::FastAttributeList::castToFastAttributeList( xAttrList ); + + for( auto &aIter : *pAttribList ) + { + switch( aIter.getToken() ) + { + case XML_ELEMENT( XLINK, XML_HREF ): + { + aURL = aIter.toString(); + } + break; + case XML_ELEMENT( CALC_EXT, XML_PROVIDER ): + { + aProvider = aIter.toString(); + } + break; + case XML_ELEMENT( CALC_EXT, XML_ID ): + { + aID = aIter.toString(); + } + break; + case XML_ELEMENT( CALC_EXT, XML_DATABASE_NAME ): + { + aDBName = aIter.toString(); + } + break; + case XML_ELEMENT( CALC_EXT, XML_DATA_FREQUENCY ): + { + } + break; + } + } + } + + if (!aProvider.isEmpty()) + { + ScDocument* pDoc = GetScImport().GetDocument(); + ScDBData* pDBData = pDoc->GetDBCollection()->getNamedDBs().findByUpperName(ScGlobal::pCharClass->uppercase(aDBName)); + if (pDBData) + { + auto& rDataMapper = pDoc->GetExternalDataMapper(); + sc::ExternalDataSource aSource(aURL, aProvider); + aSource.setID(aID); + aSource.setDBData(pDBData); + rDataMapper.insertDataSource(aSource); + } + } +} + +ScXMLMappingContext::~ScXMLMappingContext() +{ +} + +uno::Reference< xml::sax::XFastContextHandler > SAL_CALL ScXMLMappingContext::createFastChildContext( + sal_Int32 /*nElement*/, const uno::Reference< xml::sax::XFastAttributeList >& /*xAttrList*/ ) +{ + SvXMLImportContext *pContext = nullptr; + + if( !pContext ) + pContext = new SvXMLImportContext( GetImport() ); + + return pContext; +} + +void SAL_CALL ScXMLMappingContext::endFastElement( sal_Int32 /*nElement*/ ) +{ +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |