177 lines
6 KiB
C++
177 lines
6 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*************************************************************************
|
|
*
|
|
* 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.
|
|
*
|
|
************************************************************************/
|
|
|
|
|
|
#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 ::rtl::OUString;
|
|
using ::com::sun::star::uno::Sequence;
|
|
using ::com::sun::star::uno::Reference;
|
|
using ::com::sun::star::uno::Any;
|
|
using ::com::sun::star::beans::PropertyValue;
|
|
using ::com::sun::star::xml::sax::XAttributeList;
|
|
|
|
|
|
TYPEINIT1( XMLIndexTabStopEntryContext, XMLIndexSimpleEntryContext );
|
|
|
|
XMLIndexTabStopEntryContext::XMLIndexTabStopEntryContext(
|
|
SvXMLImport& rImport,
|
|
XMLIndexTemplateContext& rTemplate,
|
|
sal_uInt16 nPrfx,
|
|
const OUString& rLocalName ) :
|
|
XMLIndexSimpleEntryContext(rImport, rTemplate.sTokenTabStop,
|
|
rTemplate, nPrfx, rLocalName),
|
|
sLeaderChar(),
|
|
nTabPosition(0),
|
|
bTabPositionOK(sal_False),
|
|
bTabRightAligned(sal_False),
|
|
bLeaderCharOK(sal_False),
|
|
bWithTab(sal_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 = sal_True;
|
|
}
|
|
}
|
|
else if ( IsXMLToken( sLocalName, XML_LEADER_CHAR ) )
|
|
{
|
|
sLeaderChar = sAttr;
|
|
// valid only, if we have a char!
|
|
bLeaderCharOK = (sAttr.getLength() > 0);
|
|
}
|
|
// #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 vlues 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.setValue( &bTabRightAligned,
|
|
::getBooleanCppuType());
|
|
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 =
|
|
OUString( RTL_CONSTASCII_USTRINGPARAM("WithTab") );
|
|
pValues[nNextEntry].Value.setValue( &bWithTab,
|
|
::getBooleanCppuType());
|
|
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: */
|