Files
libreoffice/xmloff/source/transform/ChartPlotAreaOASISTContext.cxx
Oliver Bolte 9335ed4faf INTEGRATION: CWS pchfix02 (1.4.158); FILE MERGED
2006/09/01 18:00:13 kaib 1.4.158.1: #i68856# Added header markers and pch files
2006-09-17 10:21:04 +00:00

280 lines
9.2 KiB
C++

/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: ChartPlotAreaOASISTContext.cxx,v $
*
* $Revision: 1.5 $
*
* last change: $Author: obo $ $Date: 2006-09-17 11:21:04 $
*
* 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"
#include "ChartPlotAreaOASISTContext.hxx"
#ifndef _XMLOFF_TRANSFORMER_BASE_HXX
#include "TransformerBase.hxx"
#endif
#ifndef _XMLOFF_NMSPMAP_HXX
#include "nmspmap.hxx"
#endif
#ifndef _XMLOFF_XMLNMSPE_HXX
#include "xmlnmspe.hxx"
#endif
#ifndef _XMLOFF_XMLTOKEN_HXX
#include "xmltoken.hxx"
#endif
#ifndef _XMLOFF_DEEPTCONTEXT_HXX
#include "DeepTContext.hxx"
#endif
#ifndef _XMLOFF_ACTIONMAPTYPESOASIS_HXX
#include "ActionMapTypesOASIS.hxx"
#endif
#ifndef _XMLOFF_MUTABLEATTRLIST_HXX
#include "MutableAttrList.hxx"
#endif
using namespace ::com::sun::star;
using namespace ::xmloff::token;
using ::com::sun::star::uno::Reference;
using ::rtl::OUString;
class XMLAxisOASISContext : public XMLPersElemContentTContext
{
public:
TYPEINFO();
XMLAxisOASISContext( XMLTransformerBase& rTransformer,
const ::rtl::OUString& rQName,
::rtl::Reference< XMLPersAttrListTContext > & rOutCategoriesContext );
~XMLAxisOASISContext();
virtual XMLTransformerContext *CreateChildContext(
sal_uInt16 nPrefix,
const ::rtl::OUString& rLocalName,
const ::rtl::OUString& rQName,
const Reference< xml::sax::XAttributeList >& xAttrList );
virtual void StartElement( const Reference< xml::sax::XAttributeList >& rAttrList );
virtual void EndElement();
bool IsCategoryAxis() const;
private:
::rtl::Reference< XMLPersAttrListTContext > & m_rCategoriesContext;
bool m_bHasCategories;
};
TYPEINIT1( XMLAxisOASISContext, XMLPersElemContentTContext );
XMLAxisOASISContext::XMLAxisOASISContext(
XMLTransformerBase& rTransformer,
const ::rtl::OUString& rQName,
::rtl::Reference< XMLPersAttrListTContext > & rOutCategoriesContext ) :
XMLPersElemContentTContext( rTransformer, rQName ),
m_rCategoriesContext( rOutCategoriesContext ),
m_bHasCategories( false )
{}
XMLAxisOASISContext::~XMLAxisOASISContext()
{}
XMLTransformerContext * XMLAxisOASISContext::CreateChildContext(
sal_uInt16 nPrefix,
const ::rtl::OUString& rLocalName,
const ::rtl::OUString& rQName,
const Reference< xml::sax::XAttributeList >& xAttrList )
{
XMLTransformerContext * pContext = 0;
if( XML_NAMESPACE_CHART == nPrefix &&
IsXMLToken( rLocalName, XML_CATEGORIES ) )
{
// store categories element at parent
m_rCategoriesContext.set( new XMLPersAttrListTContext( GetTransformer(), rQName ));
m_bHasCategories = true;
pContext = m_rCategoriesContext.get();
}
else
{
pContext = XMLPersElemContentTContext::CreateChildContext(
nPrefix, rLocalName, rQName, xAttrList );
}
return pContext;
}
void XMLAxisOASISContext::StartElement(
const Reference< xml::sax::XAttributeList >& rAttrList )
{
OUString aLocation, aMacroName;
Reference< xml::sax::XAttributeList > xAttrList( rAttrList );
XMLMutableAttributeList *pMutableAttrList = 0;
sal_Int16 nAttrCount = xAttrList.is() ? xAttrList->getLength() : 0;
for( sal_Int16 i=0; i < nAttrCount; i++ )
{
const OUString& rAttrName = xAttrList->getNameByIndex( i );
OUString aLocalName;
sal_uInt16 nPrefix =
GetTransformer().GetNamespaceMap().GetKeyByAttrName( rAttrName, &aLocalName );
if( nPrefix == XML_NAMESPACE_CHART &&
IsXMLToken( aLocalName, XML_DIMENSION ) )
{
if( !pMutableAttrList )
{
pMutableAttrList = new XMLMutableAttributeList( xAttrList );
xAttrList = pMutableAttrList;
}
const OUString& rAttrValue = xAttrList->getValueByIndex( i );
XMLTokenEnum eToken = XML_TOKEN_INVALID;
if( IsXMLToken( rAttrValue, XML_X ))
{
eToken = XML_DOMAIN;
// has to be XML_CATEGORY for axes with a categories
// sub-element. The attribute is changed later (when it is
// known that there is a categories sub-element) in this case.
}
else if( IsXMLToken( rAttrValue, XML_Y ))
{
eToken = XML_VALUE;
}
else if( IsXMLToken( rAttrValue, XML_Z ))
{
eToken = XML_SERIES;
}
else
{
OSL_ENSURE( false, "ChartAxis: Invalid attribute value" );
}
if( eToken != XML_TOKEN_INVALID )
{
OUString aNewAttrQName(
GetTransformer().GetNamespaceMap().GetQNameByKey(
XML_NAMESPACE_CHART, GetXMLToken( XML_CLASS )));
pMutableAttrList->RenameAttributeByIndex( i, aNewAttrQName );
pMutableAttrList->SetValueByIndex( i, GetXMLToken( eToken ));
}
}
}
XMLPersElemContentTContext::StartElement( xAttrList );
}
void XMLAxisOASISContext::EndElement()
{
// if we have categories, change the "class" attribute
if( IsCategoryAxis() &&
m_rCategoriesContext.is() )
{
OSL_ENSURE( GetAttrList().is(), "Invalid attribute list" );
XMLMutableAttributeList * pMutableAttrList =
new XMLMutableAttributeList( GetAttrList());
OUString aAttrQName( GetTransformer().GetNamespaceMap().GetQNameByKey(
XML_NAMESPACE_CHART, GetXMLToken( XML_CLASS )));
sal_Int16 nIndex = pMutableAttrList->GetIndexByName( aAttrQName );
if( nIndex != -1 )
{
OSL_ENSURE( IsXMLToken( pMutableAttrList->getValueByIndex( nIndex ),
XML_DOMAIN ), "Axis Dimension: invalid former value" );
pMutableAttrList->SetValueByIndex( nIndex, GetXMLToken( XML_CATEGORY ));
OSL_ENSURE( IsXMLToken( pMutableAttrList->getValueByIndex( nIndex ),
XML_CATEGORY ), "Axis Dimension: invalid new value" );
}
GetTransformer().GetDocHandler()->startElement(
GetExportQName(),
Reference< xml::sax::XAttributeList >( pMutableAttrList ));
ExportContent();
GetTransformer().GetDocHandler()->endElement( GetExportQName());
}
else
Export();
}
bool XMLAxisOASISContext::IsCategoryAxis() const
{
return m_bHasCategories;
}
TYPEINIT1( XMLChartPlotAreaOASISTContext, XMLProcAttrTransformerContext );
XMLChartPlotAreaOASISTContext::XMLChartPlotAreaOASISTContext(
XMLTransformerBase & rTransformer, const ::rtl::OUString & rQName ) :
XMLProcAttrTransformerContext( rTransformer, rQName, OASIS_SHAPE_ACTIONS )
{
}
XMLChartPlotAreaOASISTContext::~XMLChartPlotAreaOASISTContext()
{}
XMLTransformerContext * XMLChartPlotAreaOASISTContext::CreateChildContext(
sal_uInt16 nPrefix,
const ::rtl::OUString& rLocalName,
const ::rtl::OUString& rQName,
const uno::Reference< xml::sax::XAttributeList >& xAttrList )
{
XMLTransformerContext *pContext = 0;
if( XML_NAMESPACE_CHART == nPrefix &&
IsXMLToken( rLocalName, XML_AXIS ) )
{
pContext = new XMLAxisOASISContext( GetTransformer(), rQName, m_rCategoriesContext );
}
else
{
// export (and forget) categories if found in an axis-element
// otherwise export regularly
ExportCategories();
pContext = XMLProcAttrTransformerContext::CreateChildContext(
nPrefix, rLocalName, rQName, xAttrList );
}
return pContext;
}
void XMLChartPlotAreaOASISTContext::EndElement()
{
ExportCategories();
XMLProcAttrTransformerContext::EndElement();
}
void XMLChartPlotAreaOASISTContext::ExportCategories()
{
if( m_rCategoriesContext.is())
{
m_rCategoriesContext->Export();
m_rCategoriesContext.clear();
}
}