/* -*- 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 INCLUDED_XMLOFF_XMLPRMAP_HXX #define INCLUDED_XMLOFF_XMLPRMAP_HXX #include #include #include #include #include #include #include #include #include #include #include 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_Int32 nType; sal_uInt16 nXMLNameSpace; sal_Int16 nContextId; SvtSaveOptions::ODFDefaultVersion nEarliestODFVersionForExport; bool bImportOnly; 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; bool mbOnlyExportMappings; public: /** The last element of the XMLPropertyMapEntry-array must contain NULL-values. @param bForExport If TRUE, only entries that have the mbImportOnly flag not set will be in the mappings. */ XMLPropertySetMapper( const XMLPropertyMapEntry* pEntries, const UniReference< XMLPropertyHandlerFactory >& rFactory, bool bForExport ); virtual ~XMLPropertySetMapper(); void AddMapperEntry( const UniReference < XMLPropertySetMapper >& rMapper ); /** Return number of entries in input-array */ sal_Int32 GetEntryCount() const { return aMapEntries.size(); } /** Returns the flags of an entry */ 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 */ sal_uInt32 GetEntryType( sal_Int32 nIndex, bool bWithFlags = 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 */ 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. */ 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. */ 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 */ sal_Int32 GetEntryIndex( sal_uInt16 nNamespace, const OUString& rStrName, sal_uInt32 nPropType, sal_Int32 nStartAt = -1 ) const; /** 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 bool exportXML( OUString& rStrExpValue, const XMLPropertyState& rProperty, const SvXMLUnitConverter& rUnitConverter ) const; virtual 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; /** Remove an entry */ void RemoveEntry( sal_Int32 nIndex ); }; #endif // INCLUDED_XMLOFF_XMLPRMAP_HXX /* vim:set shiftwidth=4 softtabstop=4 expandtab: */