/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: XMLTextListBlockContext.cxx,v $ * * $Revision: 1.10 $ * * last change: $Author: rt $ $Date: 2008-03-12 11:03:13 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library 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 for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_xmloff.hxx" #ifndef _TOOLS_DEBUG_HXX #include #endif #ifndef _COM_SUN_STAR_CONTAINER_XNAMECONTAINER_HPP_ #include #endif #ifndef _COM_SUN_STAR_CONTAINER_XINDEXREPLACE_HPP_ #include #endif #ifndef _COM_SUN_STAR_STYLE_XSTYLE_HPP_ #include #endif #ifndef _COM_SUN_STAR_BEANS_XPROPERTYSET_HPP_ #include #endif #ifndef _XMLOFF_XMLIMP_HXX #include #endif #ifndef _XMLOFF_XMLNUMI_HXX #include #endif #ifndef _XMLOFF_NMSPMAP_HXX #include #endif #ifndef _XMLOFF_XMLNMSPE_HXX #include "xmlnmspe.hxx" #endif #ifndef _XMLOFF_XMLTOKEN_HXX #include #endif #ifndef _XMLTEXTLISTITEMCONTEXT_HXX #include "XMLTextListItemContext.hxx" #endif #ifndef _XMLTEXTLISTBLOCKCONTEXT_HXX #include "XMLTextListBlockContext.hxx" #endif 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; }