diff options
Diffstat (limited to 'xmloff/source/text/XMLLineNumberingImportContext.cxx')
-rw-r--r-- | xmloff/source/text/XMLLineNumberingImportContext.cxx | 322 |
1 files changed, 322 insertions, 0 deletions
diff --git a/xmloff/source/text/XMLLineNumberingImportContext.cxx b/xmloff/source/text/XMLLineNumberingImportContext.cxx new file mode 100644 index 000000000000..55dc9db9b254 --- /dev/null +++ b/xmloff/source/text/XMLLineNumberingImportContext.cxx @@ -0,0 +1,322 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +// MARKER(update_precomp.py): autogen include statement, do not remove +#include "precompiled_xmloff.hxx" +#include "XMLLineNumberingImportContext.hxx" +#include "XMLLineNumberingSeparatorImportContext.hxx" +#include "com/sun/star/beans/XPropertySet.hpp" +#include "com/sun/star/text/XLineNumberingProperties.hpp" +#include <com/sun/star/style/LineNumberPosition.hpp> +#include <com/sun/star/style/NumberingType.hpp> +#include <xmloff/xmlimp.hxx> +#include <xmloff/xmluconv.hxx> +#include "xmlnmspe.hxx" +#include <xmloff/nmspmap.hxx> +#include <xmloff/xmltoken.hxx> +#include <xmloff/xmlnumi.hxx> + + +using namespace ::com::sun::star; +using namespace ::com::sun::star::uno; +using namespace ::com::sun::star::style; +using namespace ::xmloff::token; + +using ::com::sun::star::beans::XPropertySet; +using ::com::sun::star::xml::sax::XAttributeList; +using ::com::sun::star::text::XLineNumberingProperties; +using ::rtl::OUString; + +TYPEINIT1( XMLLineNumberingImportContext, SvXMLStyleContext ); + + +XMLLineNumberingImportContext::XMLLineNumberingImportContext( + SvXMLImport& rImport, + sal_uInt16 nPrfx, + const OUString& rLocalName, + const Reference<XAttributeList> & xAttrList) +: SvXMLStyleContext(rImport, nPrfx, rLocalName, xAttrList, XML_STYLE_FAMILY_TEXT_LINENUMBERINGCONFIG) +, sCharStyleName(RTL_CONSTASCII_USTRINGPARAM("CharStyleName")) +, sCountEmptyLines(RTL_CONSTASCII_USTRINGPARAM("CountEmptyLines")) +, sCountLinesInFrames(RTL_CONSTASCII_USTRINGPARAM("CountLinesInFrames")) +, sDistance(RTL_CONSTASCII_USTRINGPARAM("Distance")) +, sInterval(RTL_CONSTASCII_USTRINGPARAM("Interval")) +, sSeparatorText(RTL_CONSTASCII_USTRINGPARAM("SeparatorText")) +, sNumberPosition(RTL_CONSTASCII_USTRINGPARAM("NumberPosition")) +, sNumberingType(RTL_CONSTASCII_USTRINGPARAM("NumberingType")) +, sIsOn(RTL_CONSTASCII_USTRINGPARAM("IsOn")) +, sRestartAtEachPage(RTL_CONSTASCII_USTRINGPARAM("RestartAtEachPage")) +, sSeparatorInterval(RTL_CONSTASCII_USTRINGPARAM("SeparatorInterval")) +, sNumFormat(GetXMLToken(XML_1)) +, sNumLetterSync(GetXMLToken(XML_FALSE)) +, nOffset(-1) +, nNumberPosition(style::LineNumberPosition::LEFT) +, nIncrement(-1) +, nSeparatorIncrement(-1) +, bNumberLines(sal_True) +, bCountEmptyLines(sal_True) +, bCountInFloatingFrames(sal_False) +, bRestartNumbering(sal_False) +{ +} + +XMLLineNumberingImportContext::~XMLLineNumberingImportContext() +{ +} + +void XMLLineNumberingImportContext::StartElement( + const Reference<XAttributeList> & xAttrList) +{ + static SvXMLTokenMapEntry aLineNumberingTokenMap[] = + { + { XML_NAMESPACE_TEXT, XML_STYLE_NAME, XML_TOK_LINENUMBERING_STYLE_NAME }, + { XML_NAMESPACE_TEXT, XML_NUMBER_LINES, + XML_TOK_LINENUMBERING_NUMBER_LINES }, + { XML_NAMESPACE_TEXT, XML_COUNT_EMPTY_LINES, + XML_TOK_LINENUMBERING_COUNT_EMPTY_LINES }, + { XML_NAMESPACE_TEXT, XML_COUNT_IN_TEXT_BOXES, + XML_TOK_LINENUMBERING_COUNT_IN_TEXT_BOXES }, + { XML_NAMESPACE_TEXT, XML_RESTART_ON_PAGE, + XML_TOK_LINENUMBERING_RESTART_NUMBERING }, + { XML_NAMESPACE_TEXT, XML_OFFSET, XML_TOK_LINENUMBERING_OFFSET }, + { XML_NAMESPACE_STYLE, XML_NUM_FORMAT, XML_TOK_LINENUMBERING_NUM_FORMAT }, + { XML_NAMESPACE_STYLE, XML_NUM_LETTER_SYNC, + XML_TOK_LINENUMBERING_NUM_LETTER_SYNC }, + { XML_NAMESPACE_TEXT, XML_NUMBER_POSITION, + XML_TOK_LINENUMBERING_NUMBER_POSITION }, + { XML_NAMESPACE_TEXT, XML_INCREMENT, XML_TOK_LINENUMBERING_INCREMENT }, + // { XML_NAMESPACE_TEXT, XML_LINENUMBERING_CONFIGURATION, + // XML_TOK_LINENUMBERING_LINENUMBERING_CONFIGURATION }, + // { XML_NAMESPACE_TEXT, XML_INCREMENT, XML_TOK_LINENUMBERING_INCREMENT }, + // { XML_NAMESPACE_TEXT, XML_LINENUMBERING_SEPARATOR, + // XML_TOK_LINENUMBERING_LINENUMBERING_SEPARATOR }, + + XML_TOKEN_MAP_END + }; + + SvXMLTokenMap aTokenMap(aLineNumberingTokenMap); + + // process attributes + sal_Int16 nLength = xAttrList->getLength(); + for(sal_Int16 i=0; i<nLength; i++) + { + OUString sLocalName; + sal_uInt16 nPrefix = GetImport().GetNamespaceMap(). + GetKeyByAttrName( xAttrList->getNameByIndex(i), &sLocalName ); + + ProcessAttribute( + (enum LineNumberingToken)aTokenMap.Get(nPrefix, sLocalName), + xAttrList->getValueByIndex(i)); + } +} + +void XMLLineNumberingImportContext::ProcessAttribute( + enum LineNumberingToken eToken, + OUString sValue) +{ + sal_Bool bTmp; + sal_Int32 nTmp; + + switch (eToken) + { + case XML_TOK_LINENUMBERING_STYLE_NAME: + sStyleName = sValue; + break; + + case XML_TOK_LINENUMBERING_NUMBER_LINES: + if (SvXMLUnitConverter::convertBool(bTmp, sValue)) + { + bNumberLines = bTmp; + } + break; + + case XML_TOK_LINENUMBERING_COUNT_EMPTY_LINES: + if (SvXMLUnitConverter::convertBool(bTmp, sValue)) + { + bCountEmptyLines = bTmp; + } + break; + + case XML_TOK_LINENUMBERING_COUNT_IN_TEXT_BOXES: + if (SvXMLUnitConverter::convertBool(bTmp, sValue)) + { + bCountInFloatingFrames = bTmp; + } + break; + + case XML_TOK_LINENUMBERING_RESTART_NUMBERING: + if (SvXMLUnitConverter::convertBool(bTmp, sValue)) + { + bRestartNumbering = bTmp; + } + break; + + case XML_TOK_LINENUMBERING_OFFSET: + if (GetImport().GetMM100UnitConverter(). + convertMeasure(nTmp, sValue)) + { + nOffset = nTmp; + } + break; + + case XML_TOK_LINENUMBERING_NUM_FORMAT: + sNumFormat = sValue; + break; + + case XML_TOK_LINENUMBERING_NUM_LETTER_SYNC: + sNumLetterSync = sValue; + break; + + case XML_TOK_LINENUMBERING_NUMBER_POSITION: + { + static const SvXMLEnumMapEntry aLineNumberPositionMap[] = + { + { XML_LEFT, style::LineNumberPosition::LEFT }, + { XML_RIGHT, style::LineNumberPosition::RIGHT }, + { XML_INSIDE, style::LineNumberPosition::INSIDE }, + { XML_OUTSIDE, style::LineNumberPosition::OUTSIDE }, + { XML_TOKEN_INVALID, 0 } + }; + + sal_uInt16 nTmp16; + if (SvXMLUnitConverter::convertEnum(nTmp16, sValue, + aLineNumberPositionMap)) + { + nNumberPosition = nTmp16; + } + break; + } + + case XML_TOK_LINENUMBERING_INCREMENT: + if (SvXMLUnitConverter::convertNumber(nTmp, sValue, 0)) + { + nIncrement = (sal_Int16)nTmp; + } + break; + } +} + +void XMLLineNumberingImportContext::CreateAndInsert(sal_Bool) +{ + // insert and block mode is handled in insertStyleFamily + + // we'll try to get the LineNumberingProperties + Reference<XLineNumberingProperties> xSupplier(GetImport().GetModel(), + UNO_QUERY); + if (xSupplier.is()) + { + Reference<XPropertySet> xLineNumbering = + xSupplier->getLineNumberingProperties(); + + if (xLineNumbering.is()) + { + Any aAny; + + // set style name (if it exists) + if ( GetImport().GetStyles()->FindStyleChildContext( + XML_STYLE_FAMILY_TEXT_TEXT, sStyleName ) != NULL ) + { + aAny <<= GetImport().GetStyleDisplayName( + XML_STYLE_FAMILY_TEXT_TEXT, sStyleName ); + xLineNumbering->setPropertyValue(sCharStyleName, aAny); + } + + aAny <<= sSeparator; + xLineNumbering->setPropertyValue(sSeparatorText, aAny); + + aAny <<= nOffset; + xLineNumbering->setPropertyValue(sDistance, aAny); + + aAny <<= nNumberPosition; + xLineNumbering->setPropertyValue(sNumberPosition, aAny); + + if (nIncrement >= 0) + { + aAny <<= nIncrement; + xLineNumbering->setPropertyValue(sInterval, aAny); + } + + if (nSeparatorIncrement >= 0) + { + aAny <<= nSeparatorIncrement; + xLineNumbering->setPropertyValue(sSeparatorInterval, aAny); + } + + aAny.setValue(&bNumberLines, ::getBooleanCppuType()); + xLineNumbering->setPropertyValue(sIsOn, aAny); + + aAny.setValue(&bCountEmptyLines, ::getBooleanCppuType()); + xLineNumbering->setPropertyValue(sCountEmptyLines, aAny); + + aAny.setValue(&bCountInFloatingFrames, ::getBooleanCppuType()); + xLineNumbering->setPropertyValue(sCountLinesInFrames, aAny); + + aAny.setValue(&bRestartNumbering, ::getBooleanCppuType()); + xLineNumbering->setPropertyValue(sRestartAtEachPage, aAny); + + sal_Int16 nNumType = NumberingType::ARABIC; + GetImport().GetMM100UnitConverter().convertNumFormat( nNumType, + sNumFormat, + sNumLetterSync ); + aAny <<= nNumType; + xLineNumbering->setPropertyValue(sNumberingType, aAny); + } + } +} + +SvXMLImportContext* XMLLineNumberingImportContext::CreateChildContext( + sal_uInt16 nPrefix, + const OUString& rLocalName, + const Reference<XAttributeList> & xAttrList ) +{ + if ( (nPrefix == XML_NAMESPACE_TEXT) && + IsXMLToken(rLocalName, XML_LINENUMBERING_SEPARATOR) ) + { + return new XMLLineNumberingSeparatorImportContext(GetImport(), + nPrefix, rLocalName, + *this); + } + else + { + // unknown element: default context + return SvXMLImportContext::CreateChildContext(nPrefix, rLocalName, + xAttrList); + } +} + +void XMLLineNumberingImportContext::SetSeparatorText( + const OUString& sText) +{ + sSeparator = sText; +} + +void XMLLineNumberingImportContext::SetSeparatorIncrement( + sal_Int16 nIncr) +{ + nSeparatorIncrement = nIncr; +} + |