/* -*- 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 "xmlReport.hxx" #include "xmlfilter.hxx" #include #include #include #include #include "xmlHelper.hxx" #include "xmlGroup.hxx" #include "xmlSection.hxx" #include "xmlEnums.hxx" #include "xmlFunction.hxx" #include #include #include "xmlMasterFields.hxx" namespace rptxml { using namespace ::com::sun::star; using namespace uno; using namespace xml::sax; OXMLReport::OXMLReport( ORptFilter& rImport, sal_uInt16 nPrfx, const OUString& rLName, const Reference< XAttributeList > & _xAttrList ,const uno::Reference< report::XReportDefinition >& _xComponent) : OXMLReportElementBase( rImport, nPrfx, rLName,_xComponent.get(),nullptr) ,m_xReportDefinition(_xComponent) { OSL_ENSURE(m_xReportDefinition.is(),"No Report definition!"); impl_initRuntimeDefaults(); const SvXMLNamespaceMap& rMap = m_rImport.GetNamespaceMap(); const SvXMLTokenMap& rTokenMap = m_rImport.GetReportElemTokenMap(); const sal_Int16 nLength = (_xAttrList.is()) ? _xAttrList->getLength() : 0; static const OUString s_sTRUE = ::xmloff::token::GetXMLToken(XML_TRUE); try { for(sal_Int16 i = 0; i < nLength; ++i) { OUString sLocalName; const OUString sAttrName = _xAttrList->getNameByIndex( i ); const sal_uInt16 nPrefix = rMap.GetKeyByAttrName( sAttrName,&sLocalName ); const OUString sValue = _xAttrList->getValueByIndex( i ); switch( rTokenMap.Get( nPrefix, sLocalName ) ) { case XML_TOK_COMMAND_TYPE: { sal_Int32 nRet = sdb::CommandType::COMMAND; const SvXMLEnumMapEntry* aXML_EnumMap = OXMLHelper::GetCommandTypeOptions(); bool bConvertOk = SvXMLUnitConverter::convertEnum( nRet, sValue, aXML_EnumMap ); SAL_WARN_IF(!bConvertOk, "reportdesign", "convertEnum failed"); m_xReportDefinition->setCommandType(nRet); } break; case XML_TOK_COMMAND: m_xReportDefinition->setCommand(sValue); break; case XML_TOK_FILTER: m_xReportDefinition->setFilter(sValue); break; case XML_TOK_CAPTION: m_xReportDefinition->setCaption(sValue); break; case XML_TOK_ESCAPE_PROCESSING: m_xReportDefinition->setEscapeProcessing(sValue == s_sTRUE); break; case XML_TOK_REPORT_MIMETYPE: m_xReportDefinition->setMimeType(sValue); break; case XML_TOK_REPORT_NAME: m_xReportDefinition->setName(sValue); break; default: break; } } } catch(Exception&) { OSL_FAIL("Exception catched while filling the report definition props"); } } OXMLReport::~OXMLReport() { } void OXMLReport::impl_initRuntimeDefaults() const { OSL_PRECOND( m_xReportDefinition.is(), "OXMLReport::impl_initRuntimeDefaults: no component!" ); if ( !m_xReportDefinition.is() ) return; try { m_xReportDefinition->setCommandType( sdb::CommandType::COMMAND ); } catch( const Exception& ) { DBG_UNHANDLED_EXCEPTION(); } } SvXMLImportContext* OXMLReport::CreateChildContext( sal_uInt16 nPrefix, const OUString& rLocalName, const Reference< XAttributeList > & xAttrList ) { SvXMLImportContext *pContext = CreateChildContext_(nPrefix,rLocalName,xAttrList); if ( pContext ) return pContext; const SvXMLTokenMap& rTokenMap = m_rImport.GetReportElemTokenMap(); switch( rTokenMap.Get( nPrefix, rLocalName ) ) { case XML_TOK_REPORT_FUNCTION: { m_rImport.GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLFunction( m_rImport, nPrefix, rLocalName,xAttrList,m_xReportDefinition.get(),true); } break; case XML_TOK_MASTER_DETAIL_FIELDS: m_rImport.GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLMasterFields(m_rImport, nPrefix, rLocalName,xAttrList ,this); break; case XML_TOK_REPORT_HEADER: { m_rImport.GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); m_xReportDefinition->setReportHeaderOn(true); pContext = new OXMLSection( m_rImport, nPrefix, rLocalName,xAttrList, m_xReportDefinition->getReportHeader()); } break; case XML_TOK_PAGE_HEADER: { m_rImport.GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); m_xReportDefinition->setPageHeaderOn(true); pContext = new OXMLSection( m_rImport, nPrefix, rLocalName,xAttrList, m_xReportDefinition->getPageHeader()); } break; case XML_TOK_GROUP: m_rImport.GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLGroup( m_rImport, nPrefix, rLocalName,xAttrList); break; case XML_TOK_DETAIL: { m_rImport.GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); pContext = new OXMLSection( m_rImport, nPrefix, rLocalName,xAttrList, m_xReportDefinition->getDetail()); } break; case XML_TOK_PAGE_FOOTER: { m_rImport.GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); m_xReportDefinition->setPageFooterOn(true); pContext = new OXMLSection( m_rImport, nPrefix, rLocalName,xAttrList, m_xReportDefinition->getPageFooter(),false); } break; case XML_TOK_REPORT_FOOTER: { m_rImport.GetProgressBarHelper()->Increment( PROGRESS_BAR_STEP ); m_xReportDefinition->setReportFooterOn(true); pContext = new OXMLSection( m_rImport, nPrefix, rLocalName,xAttrList, m_xReportDefinition->getReportFooter()); } break; default: break; } if( !pContext ) pContext = new SvXMLImportContext( GetImport(), nPrefix, rLocalName ); return pContext; } void OXMLReport::EndElement() { Reference< XFunctions > xFunctions = m_xReportDefinition->getFunctions(); const ORptFilter::TGroupFunctionMap& aFunctions = m_rImport.getFunctions(); ORptFilter::TGroupFunctionMap::const_iterator aIter = aFunctions.begin(); const ORptFilter::TGroupFunctionMap::const_iterator aEnd = aFunctions.end(); for (; aIter != aEnd; ++aIter) xFunctions->insertByIndex(xFunctions->getCount(),uno::makeAny(aIter->second)); if ( !m_aMasterFields.empty() ) m_xReportDefinition->setMasterFields(Sequence< OUString>(&*m_aMasterFields.begin(),m_aMasterFields.size())); if ( !m_aDetailFields.empty() ) m_xReportDefinition->setDetailFields(Sequence< OUString>(&*m_aDetailFields.begin(),m_aDetailFields.size())); } void OXMLReport::addMasterDetailPair(const ::std::pair< OUString,OUString >& _aPair) { m_aMasterFields.push_back(_aPair.first); m_aDetailFields.push_back(_aPair.second); } } // namespace rptxml /* vim:set shiftwidth=4 softtabstop=4 expandtab: */