office-gobmx/xmloff/source/text/XMLTextListBlockContext.cxx
Rüdiger Timm fe4723ee88 INTEGRATION: CWS changefileheader (1.10.18); FILE MERGED
2008/04/01 16:10:11 thb 1.10.18.3: #i85898# Stripping all external header guards
2008/04/01 13:05:31 thb 1.10.18.2: #i85898# Stripping all external header guards
2008/03/31 16:28:37 rt 1.10.18.1: #i87441# Change license header to LPGL v3.
2008-04-10 22:22:15 +00:00

243 lines
8.2 KiB
C++

/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2008 by Sun Microsystems, Inc.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: XMLTextListBlockContext.cxx,v $
* $Revision: 1.11 $
*
* 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 <tools/debug.hxx>
#include <com/sun/star/container/XNameContainer.hpp>
#include <com/sun/star/container/XIndexReplace.hpp>
#include <com/sun/star/style/XStyle.hpp>
#include <com/sun/star/beans/XPropertySet.hpp>
#include <xmloff/xmlimp.hxx>
#include <xmloff/xmlnumi.hxx>
#include <xmloff/nmspmap.hxx>
#include "xmlnmspe.hxx"
#include <xmloff/xmltoken.hxx>
#include "XMLTextListItemContext.hxx"
#include "XMLTextListBlockContext.hxx"
using ::rtl::OUString;
using ::rtl::OUStringBuffer;
using namespace ::com::sun::star;
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::container;
using namespace ::com::sun::star::style;
using namespace ::com::sun::star::beans;
using namespace ::xmloff::token;
TYPEINIT1( XMLTextListBlockContext, SvXMLImportContext );
XMLTextListBlockContext::XMLTextListBlockContext(
SvXMLImport& rImport,
XMLTextImportHelper& rTxtImp,
sal_uInt16 nPrfx, const OUString& rLName,
const Reference< xml::sax::XAttributeList > & xAttrList )
: SvXMLImportContext( rImport, nPrfx, rLName )
, rTxtImport( rTxtImp )
, sNumberingRules( RTL_CONSTASCII_USTRINGPARAM( "NumberingRules" ) )
, xParentListBlock( rTxtImp.GetListBlock() )
, nLevel( 0 )
, nLevels( 0 )
, bRestartNumbering( sal_True )
, bSetDefaults( sal_False )
{
// Inherit style name from parent list, as well as the flags whether
// numbering must be restarted and formats have to be created.
OUString sParentStyleName;
if( xParentListBlock.Is() )
{
XMLTextListBlockContext *pParent =
(XMLTextListBlockContext *)&xParentListBlock;
sStyleName = pParent->GetStyleName();
xNumRules = pParent->GetNumRules();
sParentStyleName = sStyleName;
nLevels = pParent->nLevels;
nLevel = pParent->GetLevel() + 1;
bRestartNumbering = pParent->IsRestartNumbering();
bSetDefaults = pParent->bSetDefaults;
}
const SvXMLTokenMap& rTokenMap =
rTxtImport.GetTextListBlockAttrTokenMap();
sal_Int16 nAttrCount = xAttrList.is() ? xAttrList->getLength() : 0;
for( sal_Int16 i=0; i < nAttrCount; i++ )
{
const OUString& rAttrName = xAttrList->getNameByIndex( i );
const OUString& rValue = xAttrList->getValueByIndex( i );
OUString aLocalName;
sal_uInt16 nPrefix =
GetImport().GetNamespaceMap().GetKeyByAttrName( rAttrName,
&aLocalName );
switch( rTokenMap.Get( nPrefix, aLocalName ) )
{
case XML_TOK_TEXT_LIST_BLOCK_CONTINUE_NUMBERING:
bRestartNumbering = !IsXMLToken(rValue, XML_TRUE);
break;
case XML_TOK_TEXT_LIST_BLOCK_STYLE_NAME:
sStyleName = rValue;
break;
}
}
if( sStyleName.getLength() && sStyleName != sParentStyleName )
{
OUString sDisplayStyleName(
GetImport().GetStyleDisplayName( XML_STYLE_FAMILY_TEXT_LIST,
sStyleName ) );
const Reference < XNameContainer >& rNumStyles =
rTxtImport.GetNumberingStyles();
if( rNumStyles.is() && rNumStyles->hasByName( sDisplayStyleName ) )
{
Reference < XStyle > xStyle;
Any aAny = rNumStyles->getByName( sDisplayStyleName );
aAny >>= xStyle;
// If the style has not been used, the restart numbering has
// to be set never.
if( bRestartNumbering && !xStyle->isInUse() )
bRestartNumbering = sal_False;
Reference< XPropertySet > xPropSet( xStyle, UNO_QUERY );
aAny = xPropSet->getPropertyValue( sNumberingRules );
aAny >>= xNumRules;
nLevels = xNumRules->getCount();
}
else
{
const SvxXMLListStyleContext *pListStyle =
rTxtImport.FindAutoListStyle( sStyleName );
if( pListStyle )
{
xNumRules = pListStyle->GetNumRules();
sal_Bool bUsed = xNumRules.is();
if( !xNumRules.is() )
{
pListStyle->CreateAndInsertAuto();
xNumRules = pListStyle->GetNumRules();
}
if( bRestartNumbering && !bUsed )
bRestartNumbering = sal_False;
nLevels = pListStyle->GetLevels();
}
}
}
if( !xNumRules.is() )
{
// If no style name has been specified for this style and for any
// parent or if no num rule this the specified name is existing,
// create a new one.
xNumRules =
SvxXMLListStyleContext::CreateNumRule( GetImport().GetModel() );
DBG_ASSERT( xNumRules.is(), "go no numbering rule" );
if( !xNumRules.is() )
return;
nLevels = xNumRules->getCount();
// Because its a new num rule, numbering mist be restarted never.
bRestartNumbering = sal_False;
bSetDefaults = sal_True;
}
if( nLevel >= nLevels )
nLevel = sal::static_int_cast< sal_Int16 >(nLevels-1);
if( bSetDefaults )
{
// Because there is no list style sheet for this style, a default
// format must be set for any level of this num rule.
SvxXMLListStyleContext::SetDefaultStyle( xNumRules, nLevel,
sal_False );
}
// Remember this list block.
rTxtImport.SetListBlock( this );
// There is no list item by now.
rTxtImport.SetListItem( 0 );
}
XMLTextListBlockContext::~XMLTextListBlockContext()
{
}
void XMLTextListBlockContext::EndElement()
{
// Numbering has not to be restarted if it has been restarted within
// a child list.
XMLTextListBlockContext *pParent =
(XMLTextListBlockContext *)&xParentListBlock;
if( pParent )
{
pParent->bRestartNumbering = bRestartNumbering;
}
// Restore current list block.
rTxtImport.SetListBlock( pParent );
// Any paragraph following the list within the same list item mist not
// be numbered.
rTxtImport.SetListItem( 0 );
}
SvXMLImportContext *XMLTextListBlockContext::CreateChildContext(
sal_uInt16 nPrefix,
const OUString& rLocalName,
const Reference< xml::sax::XAttributeList > & xAttrList )
{
SvXMLImportContext *pContext = 0;
const SvXMLTokenMap& rTokenMap =
rTxtImport.GetTextListBlockElemTokenMap();
sal_Bool bHeader = sal_False;
switch( rTokenMap.Get( nPrefix, rLocalName ) )
{
case XML_TOK_TEXT_LIST_HEADER:
bHeader = sal_True;
case XML_TOK_TEXT_LIST_ITEM:
pContext = new XMLTextListItemContext( GetImport(), rTxtImport,
nPrefix, rLocalName,
xAttrList, bHeader );
break;
}
if( !pContext )
pContext = new SvXMLImportContext( GetImport(), nPrefix, rLocalName );
return pContext;
}