Files
libreoffice/xmloff/source/text/XMLIndexAlphabeticalSourceContext.cxx
Noel Grandin 58a32075ca use Any constructor instead of temporaries
Change-Id: Iffb82a2cee1a28d89eeea2b905aaa14086ee475a
2016-05-04 12:39:40 +02:00

250 lines
8.5 KiB
C++

/* -*- 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 "XMLIndexAlphabeticalSourceContext.hxx"
#include <com/sun/star/beans/XPropertySet.hpp>
#include <com/sun/star/container/XIndexReplace.hpp>
#include <sax/tools/converter.hxx>
#include "XMLIndexTemplateContext.hxx"
#include "XMLIndexTitleTemplateContext.hxx"
#include "XMLIndexTOCStylesContext.hxx"
#include <xmloff/xmlictxt.hxx>
#include <xmloff/xmlimp.hxx>
#include <xmloff/txtimp.hxx>
#include <xmloff/xmlnmspe.hxx>
#include <xmloff/nmspmap.hxx>
#include <xmloff/xmltoken.hxx>
#include <xmloff/xmluconv.hxx>
#include <rtl/ustring.hxx>
using ::com::sun::star::beans::XPropertySet;
using ::com::sun::star::uno::Reference;
using ::com::sun::star::uno::Any;
using ::com::sun::star::xml::sax::XAttributeList;
using ::xmloff::token::IsXMLToken;
using ::xmloff::token::XML_ALPHABETICAL_INDEX_ENTRY_TEMPLATE;
using ::xmloff::token::XML_OUTLINE_LEVEL;
const sal_Char sAPI_MainEntryCharacterStyleName[] = "MainEntryCharacterStyleName";
const sal_Char sAPI_UseAlphabeticalSeparators[] = "UseAlphabeticalSeparators";
const sal_Char sAPI_UseCombinedEntries[] = "UseCombinedEntries";
const sal_Char sAPI_IsCaseSensitive[] = "IsCaseSensitive";
const sal_Char sAPI_UseKeyAsEntry[] = "UseKeyAsEntry";
const sal_Char sAPI_UseUpperCase[] = "UseUpperCase";
const sal_Char sAPI_UseDash[] = "UseDash";
const sal_Char sAPI_UsePP[] = "UsePP";
const sal_Char sAPI_SortAlgorithm[] = "SortAlgorithm";
const sal_Char sAPI_Locale[] = "Locale";
XMLIndexAlphabeticalSourceContext::XMLIndexAlphabeticalSourceContext(
SvXMLImport& rImport,
sal_uInt16 nPrfx,
const OUString& rLocalName,
Reference<XPropertySet> & rPropSet)
: XMLIndexSourceBaseContext(rImport, nPrfx, rLocalName, rPropSet, false)
, sMainEntryCharacterStyleName(sAPI_MainEntryCharacterStyleName)
, sUseAlphabeticalSeparators(sAPI_UseAlphabeticalSeparators)
, sUseCombinedEntries(sAPI_UseCombinedEntries)
, sIsCaseSensitive(sAPI_IsCaseSensitive)
, sUseKeyAsEntry(sAPI_UseKeyAsEntry)
, sUseUpperCase(sAPI_UseUpperCase)
, sUseDash(sAPI_UseDash)
, sUsePP(sAPI_UsePP)
, sIsCommaSeparated("IsCommaSeparated")
, sSortAlgorithm(sAPI_SortAlgorithm)
, sLocale(sAPI_Locale)
, bMainEntryStyleNameOK(false)
, bSeparators(false)
, bCombineEntries(true)
, bCaseSensitive(true)
, bEntry(false)
, bUpperCase(false)
, bCombineDash(false)
, bCombinePP(true)
, bCommaSeparated(false)
{
}
XMLIndexAlphabeticalSourceContext::~XMLIndexAlphabeticalSourceContext()
{
}
void XMLIndexAlphabeticalSourceContext::ProcessAttribute(
enum IndexSourceParamEnum eParam,
const OUString& rValue)
{
bool bTmp(false);
switch (eParam)
{
case XML_TOK_INDEXSOURCE_MAIN_ENTRY_STYLE:
{
sMainEntryStyleName = rValue;
OUString sDisplayStyleName = GetImport().GetStyleDisplayName(
XML_STYLE_FAMILY_TEXT_TEXT, sMainEntryStyleName );
const Reference < css::container::XNameContainer >&
rStyles = GetImport().GetTextImport()->GetTextStyles();
bMainEntryStyleNameOK = rStyles.is() && rStyles->hasByName( sDisplayStyleName );
}
break;
case XML_TOK_INDEXSOURCE_IGNORE_CASE:
if (::sax::Converter::convertBool(bTmp, rValue))
{
bCaseSensitive = !bTmp;
}
break;
case XML_TOK_INDEXSOURCE_SEPARATORS:
if (::sax::Converter::convertBool(bTmp, rValue))
{
bSeparators = bTmp;
}
break;
case XML_TOK_INDEXSOURCE_COMBINE_ENTRIES:
if (::sax::Converter::convertBool(bTmp, rValue))
{
bCombineEntries = bTmp;
}
break;
case XML_TOK_INDEXSOURCE_COMBINE_WITH_DASH:
if (::sax::Converter::convertBool(bTmp, rValue))
{
bCombineDash = bTmp;
}
break;
case XML_TOK_INDEXSOURCE_KEYS_AS_ENTRIES:
if (::sax::Converter::convertBool(bTmp, rValue))
{
bEntry = bTmp;
}
break;
case XML_TOK_INDEXSOURCE_COMBINE_WITH_PP:
if (::sax::Converter::convertBool(bTmp, rValue))
{
bCombinePP = bTmp;
}
break;
case XML_TOK_INDEXSOURCE_CAPITALIZE:
if (::sax::Converter::convertBool(bTmp, rValue))
{
bUpperCase = bTmp;
}
break;
case XML_TOK_INDEXSOURCE_COMMA_SEPARATED:
if (::sax::Converter::convertBool(bTmp, rValue))
{
bCommaSeparated = bTmp;
}
break;
case XML_TOK_INDEXSOURCE_SORT_ALGORITHM:
sAlgorithm = rValue;
break;
case XML_TOK_INDEXSOURCE_RFC_LANGUAGE_TAG:
maLanguageTagODF.maRfcLanguageTag = rValue;
break;
case XML_TOK_INDEXSOURCE_LANGUAGE:
maLanguageTagODF.maLanguage = rValue;
break;
case XML_TOK_INDEXSOURCE_SCRIPT:
maLanguageTagODF.maScript = rValue;
break;
case XML_TOK_INDEXSOURCE_COUNTRY:
maLanguageTagODF.maCountry = rValue;
break;
default:
XMLIndexSourceBaseContext::ProcessAttribute(eParam, rValue);
break;
}
}
void XMLIndexAlphabeticalSourceContext::EndElement()
{
Any aAny;
if (bMainEntryStyleNameOK)
{
aAny <<= GetImport().GetStyleDisplayName(
XML_STYLE_FAMILY_TEXT_TEXT, sMainEntryStyleName );
rIndexPropertySet->setPropertyValue(sMainEntryCharacterStyleName,aAny);
}
rIndexPropertySet->setPropertyValue(sUseAlphabeticalSeparators, css::uno::Any(bSeparators));
rIndexPropertySet->setPropertyValue(sUseCombinedEntries, css::uno::Any(bCombineEntries));
rIndexPropertySet->setPropertyValue(sIsCaseSensitive, css::uno::Any(bCaseSensitive));
rIndexPropertySet->setPropertyValue(sUseKeyAsEntry, css::uno::Any(bEntry));
rIndexPropertySet->setPropertyValue(sUseUpperCase, css::uno::Any(bUpperCase));
rIndexPropertySet->setPropertyValue(sUseDash, css::uno::Any(bCombineDash));
rIndexPropertySet->setPropertyValue(sUsePP, css::uno::Any(bCombinePP));
rIndexPropertySet->setPropertyValue(sIsCommaSeparated, css::uno::Any(bCommaSeparated));
if (!sAlgorithm.isEmpty())
{
rIndexPropertySet->setPropertyValue(sSortAlgorithm, css::uno::Any(sAlgorithm));
}
if ( !maLanguageTagODF.isEmpty() )
{
aAny <<= maLanguageTagODF.getLanguageTag().getLocale( false);
rIndexPropertySet->setPropertyValue(sLocale, aAny);
}
XMLIndexSourceBaseContext::EndElement();
}
SvXMLImportContext* XMLIndexAlphabeticalSourceContext::CreateChildContext(
sal_uInt16 nPrefix,
const OUString& rLocalName,
const Reference<XAttributeList> & xAttrList )
{
if ( (XML_NAMESPACE_TEXT == nPrefix) &&
IsXMLToken( rLocalName, XML_ALPHABETICAL_INDEX_ENTRY_TEMPLATE ) )
{
return new XMLIndexTemplateContext(GetImport(), rIndexPropertySet,
nPrefix, rLocalName,
aLevelNameAlphaMap,
XML_OUTLINE_LEVEL,
aLevelStylePropNameAlphaMap,
aAllowedTokenTypesAlpha);
}
else
{
return XMLIndexSourceBaseContext::CreateChildContext(nPrefix,
rLocalName,
xAttrList);
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */