...which only happens ot work in environments where sizeof (bool) == 1. The simpler alternative is to use the operator <<= template without passing explicit UNO type information, anyway. The std::nullptr_t overloads are needed to disambiguate calls with a nullptr argument. (Which can at least be meaningful for VOID, but for other types what it happens to do is store a default value of the given type.) As std::nullptr_t is only C++11, this all needs to be LIBO_INTERNAL_ONLY. Change-Id: Iff06a6ba94250bd4ae4afc937c2a2bfa75f0888f
162 lines
5.3 KiB
C++
162 lines
5.3 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 "XMLIndexTabStopEntryContext.hxx"
|
|
|
|
#include <sax/tools/converter.hxx>
|
|
|
|
#include "XMLIndexTemplateContext.hxx"
|
|
#include <xmloff/xmlictxt.hxx>
|
|
#include <xmloff/xmlimp.hxx>
|
|
#include <xmloff/txtimp.hxx>
|
|
#include <xmloff/nmspmap.hxx>
|
|
#include <xmloff/xmlnmspe.hxx>
|
|
#include <xmloff/xmltoken.hxx>
|
|
#include <xmloff/xmluconv.hxx>
|
|
#include <rtl/ustring.hxx>
|
|
#include <tools/debug.hxx>
|
|
|
|
using namespace ::xmloff::token;
|
|
|
|
using ::com::sun::star::uno::Sequence;
|
|
using ::com::sun::star::uno::Reference;
|
|
using ::com::sun::star::beans::PropertyValue;
|
|
using ::com::sun::star::xml::sax::XAttributeList;
|
|
|
|
|
|
XMLIndexTabStopEntryContext::XMLIndexTabStopEntryContext(
|
|
SvXMLImport& rImport,
|
|
XMLIndexTemplateContext& rTemplate,
|
|
sal_uInt16 nPrfx,
|
|
const OUString& rLocalName ) :
|
|
XMLIndexSimpleEntryContext(rImport, rTemplate.sTokenTabStop,
|
|
rTemplate, nPrfx, rLocalName),
|
|
sLeaderChar(),
|
|
nTabPosition(0),
|
|
bTabPositionOK(false),
|
|
bTabRightAligned(false),
|
|
bLeaderCharOK(false),
|
|
bWithTab(true) // #i21237#
|
|
{
|
|
}
|
|
|
|
XMLIndexTabStopEntryContext::~XMLIndexTabStopEntryContext()
|
|
{
|
|
}
|
|
|
|
void XMLIndexTabStopEntryContext::StartElement(
|
|
const Reference<XAttributeList> & xAttrList)
|
|
{
|
|
// process three attributes: type, position, leader char
|
|
sal_Int16 nLength = xAttrList->getLength();
|
|
for(sal_Int16 nAttr = 0; nAttr < nLength; nAttr++)
|
|
{
|
|
OUString sLocalName;
|
|
sal_uInt16 nPrefix = GetImport().GetNamespaceMap().
|
|
GetKeyByAttrName( xAttrList->getNameByIndex(nAttr),
|
|
&sLocalName );
|
|
OUString sAttr = xAttrList->getValueByIndex(nAttr);
|
|
if (XML_NAMESPACE_STYLE == nPrefix)
|
|
{
|
|
if ( IsXMLToken( sLocalName, XML_TYPE ) )
|
|
{
|
|
// if it's neither left nor right, value is
|
|
// ignored. Since left is default, we only need to
|
|
// check for right
|
|
bTabRightAligned = IsXMLToken( sAttr, XML_RIGHT );
|
|
}
|
|
else if ( IsXMLToken( sLocalName, XML_POSITION ) )
|
|
{
|
|
sal_Int32 nTmp;
|
|
if (GetImport().GetMM100UnitConverter().
|
|
convertMeasureToCore(nTmp, sAttr))
|
|
{
|
|
nTabPosition = nTmp;
|
|
bTabPositionOK = true;
|
|
}
|
|
}
|
|
else if ( IsXMLToken( sLocalName, XML_LEADER_CHAR ) )
|
|
{
|
|
sLeaderChar = sAttr;
|
|
// valid only, if we have a char!
|
|
bLeaderCharOK = !sAttr.isEmpty();
|
|
}
|
|
// #i21237#
|
|
else if ( IsXMLToken( sLocalName, XML_WITH_TAB ) )
|
|
{
|
|
bool bTmp(false);
|
|
if (::sax::Converter::convertBool(bTmp, sAttr))
|
|
bWithTab = bTmp;
|
|
}
|
|
// else: unknown style: attribute -> ignore
|
|
}
|
|
// else: no style attribute -> ignore
|
|
}
|
|
|
|
// how many entries? #i21237#
|
|
nValues += 2 + (bTabPositionOK ? 1 : 0) + (bLeaderCharOK ? 1 : 0);
|
|
|
|
// now try parent class (for character style)
|
|
XMLIndexSimpleEntryContext::StartElement( xAttrList );
|
|
}
|
|
|
|
void XMLIndexTabStopEntryContext::FillPropertyValues(
|
|
Sequence<PropertyValue> & rValues)
|
|
{
|
|
// fill values from parent class (type + style name)
|
|
XMLIndexSimpleEntryContext::FillPropertyValues(rValues);
|
|
|
|
// get values array and next entry to be written;
|
|
sal_Int32 nNextEntry = bCharStyleNameOK ? 2 : 1;
|
|
PropertyValue* pValues = rValues.getArray();
|
|
|
|
// right aligned?
|
|
pValues[nNextEntry].Name = rTemplateContext.sTabStopRightAligned;
|
|
pValues[nNextEntry].Value <<= bTabRightAligned;
|
|
nNextEntry++;
|
|
|
|
// position
|
|
if (bTabPositionOK)
|
|
{
|
|
pValues[nNextEntry].Name = rTemplateContext.sTabStopPosition;
|
|
pValues[nNextEntry].Value <<= nTabPosition;
|
|
nNextEntry++;
|
|
}
|
|
|
|
// leader char
|
|
if (bLeaderCharOK)
|
|
{
|
|
pValues[nNextEntry].Name = rTemplateContext.sTabStopFillCharacter;
|
|
pValues[nNextEntry].Value <<= sLeaderChar;
|
|
nNextEntry++;
|
|
}
|
|
|
|
// tab character #i21237#
|
|
pValues[nNextEntry].Name = "WithTab";
|
|
pValues[nNextEntry].Value <<= bWithTab;
|
|
nNextEntry++;
|
|
|
|
// check whether we really filled all elements of the sequence
|
|
DBG_ASSERT( nNextEntry == rValues.getLength(),
|
|
"length incorrectly precumputed!" );
|
|
}
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|