Files
libreoffice/include/xmloff/xmlprmap.hxx

182 lines
7.4 KiB
C++
Raw Normal View History

2010-10-27 13:11:31 +01:00
/* -*- 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 .
*/
#ifndef _XMLOFF_PROPERTYSETMAPPER_HXX
#define _XMLOFF_PROPERTYSETMAPPER_HXX
#include "sal/config.h"
#include "xmloff/dllapi.h"
#include <com/sun/star/uno/Sequence.hxx>
#include <com/sun/star/uno/Any.hxx>
#include <com/sun/star/beans/XPropertySet.hpp>
#include <vector>
#include <xmloff/uniref.hxx>
#include <xmloff/maptype.hxx>
#include <xmloff/xmltypes.hxx>
#include <xmloff/prhdlfac.hxx>
#include <tools/debug.hxx>
class SvXMLUnitConverter;
class XMLPropertyHandler;
///////////////////////////////////////////////////////////////////////////
//
/** Helper-class for XML-im/export:
- Holds a pointer to a given array of XMLPropertyMapEntry
- Provides several methods to access data from this array
- Holds a Sequence of XML-names (for properties)
- The filter takes all properties of the XPropertySet which are also
in the XMLPropertyMapEntry and which are have not a default value
and put them into a vector of XMLPropertyStae
- this class knows how to compare, im/export properties
Attention: At all methods, which get an index as parameter, there is no
range validation to save runtime !!
*/
struct XMLPropertySetMapperEntry_Impl
{
OUString sXMLAttributeName;
OUString sAPIPropertyName;
sal_uInt16 nXMLNameSpace;
sal_Int32 nType;
sal_Int16 nContextId;
SvtSaveOptions::ODFDefaultVersion nEarliestODFVersionForExport;
const XMLPropertyHandler *pHdl;
XMLPropertySetMapperEntry_Impl(
const XMLPropertyMapEntry& rMapEntry,
const UniReference< XMLPropertyHandlerFactory >& rFactory );
XMLPropertySetMapperEntry_Impl(
const XMLPropertySetMapperEntry_Impl& rEntry );
sal_uInt32 GetPropType() const { return nType & XML_TYPE_PROP_MASK; }
};
class XMLOFF_DLLPUBLIC XMLPropertySetMapper : public UniRefBase
{
::std::vector< XMLPropertySetMapperEntry_Impl > aMapEntries;
::std::vector< UniReference < XMLPropertyHandlerFactory > > aHdlFactories;
public:
/** The last element of the XMLPropertyMapEntry-array must contain NULL-values */
XMLPropertySetMapper(
const XMLPropertyMapEntry* pEntries,
const UniReference< XMLPropertyHandlerFactory >& rFactory );
virtual ~XMLPropertySetMapper();
void AddMapperEntry( const UniReference < XMLPropertySetMapper >& rMapper );
/** Return number of entries in input-array */
2008-10-10 13:02:43 +00:00
sal_Int32 GetEntryCount() const { return aMapEntries.size(); }
/** Returns the flags of an entry */
2008-10-10 13:02:43 +00:00
sal_uInt32 GetEntryFlags( sal_Int32 nIndex ) const
{
DBG_ASSERT( (nIndex >= 0) && (nIndex < (sal_Int32)aMapEntries.size() ), "illegal access to invalid entry!" );
return aMapEntries[nIndex].nType & ~MID_FLAG_MASK;
}
/** Returns the type of an entry */
2008-10-10 13:02:43 +00:00
sal_uInt32 GetEntryType( sal_Int32 nIndex,
sal_Bool bWithFlags = sal_True ) const
{
DBG_ASSERT( (nIndex >= 0) && (nIndex < (sal_Int32)aMapEntries.size() ), "illegal access to invalid entry!" );
sal_uInt32 nType = aMapEntries[nIndex].nType;
if( !bWithFlags )
nType = nType & MID_FLAG_MASK;
return nType;
}
/** Returns the namespace-key of an entry */
2008-10-10 13:02:43 +00:00
sal_uInt16 GetEntryNameSpace( sal_Int32 nIndex ) const
{
DBG_ASSERT( (nIndex >= 0) && (nIndex < (sal_Int32)aMapEntries.size() ), "illegal access to invalid entry!" );
return aMapEntries[nIndex].nXMLNameSpace;
}
/** Returns the 'local' XML-name of the entry */
const OUString& GetEntryXMLName( sal_Int32 nIndex ) const
{
DBG_ASSERT( (nIndex >= 0) && (nIndex < (sal_Int32)aMapEntries.size() ), "illegal access to invalid entry!" );
return aMapEntries[nIndex].sXMLAttributeName;
}
/** Returns the entry API name */
const OUString& GetEntryAPIName( sal_Int32 nIndex ) const
{
DBG_ASSERT( (nIndex >= 0) && (nIndex < (sal_Int32)aMapEntries.size() ), "illegal access to invalid entry!" );
return aMapEntries[nIndex].sAPIPropertyName;
}
/** returns the entry context id. -1 is a valid index here. */
2008-10-10 13:02:43 +00:00
sal_Int16 GetEntryContextId( sal_Int32 nIndex ) const
{
DBG_ASSERT( (nIndex >= -1) && (nIndex < (sal_Int32)aMapEntries.size() ), "illegal access to invalid entry!" );
return nIndex == -1 ? 0 : aMapEntries[nIndex].nContextId;
}
/** returns the earliest odf version for which this property should be exported. */
2008-10-10 13:02:43 +00:00
SvtSaveOptions::ODFDefaultVersion GetEarliestODFVersionForExport( sal_Int32 nIndex ) const
{
DBG_ASSERT( (nIndex >= -1) && (nIndex < (sal_Int32)aMapEntries.size() ), "illegal access to invalid entry!" );
return nIndex == -1 ? SvtSaveOptions::ODFVER_UNKNOWN : aMapEntries[nIndex].nEarliestODFVersionForExport;
}
/** Returns the index of an entry with the given XML-name and namespace
If there is no matching entry the method returns -1 */
2008-10-10 13:02:43 +00:00
sal_Int32 GetEntryIndex( sal_uInt16 nNamespace,
const OUString& rStrName,
sal_uInt32 nPropType,
sal_Int32 nStartAt = -1 ) const;
2013-05-06 20:07:23 +02:00
/** Retrieves a PropertyHandler for that property which placed at nIndex in the XMLPropertyMapEntry-array */
const XMLPropertyHandler* GetPropertyHandler( sal_Int32 nIndex ) const
{
DBG_ASSERT( (nIndex >= 0) && (nIndex < (sal_Int32)aMapEntries.size() ), "illegal access to invalid entry!" );
return aMapEntries[nIndex].pHdl;
}
/** import/export
This methods calls the respective im/export-method of the respective PropertyHandler. */
virtual sal_Bool exportXML( OUString& rStrExpValue,
const XMLPropertyState& rProperty,
const SvXMLUnitConverter& rUnitConverter ) const;
virtual sal_Bool importXML( const OUString& rStrImpValue,
XMLPropertyState& rProperty,
const SvXMLUnitConverter& rUnitConverter ) const;
/** searches for an entry that matches the given api name, namespace and local name or -1 if nothing found */
sal_Int32 FindEntryIndex( const sal_Char* sApiName,
sal_uInt16 nNameSpace,
const OUString& sXMLName ) const;
/** searches for an entry that matches the given ContextId or gives -1 if nothing found */
sal_Int32 FindEntryIndex( const sal_Int16 nContextId ) const;
2008-11-26 15:19:48 +00:00
/** Remove an entry */
void RemoveEntry( sal_Int32 nIndex );
};
#endif // _XMLOFF_PROPERTYSETMAPPER_HXX
2010-10-27 13:11:31 +01:00
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */