Make SvXMLTokenMap compatible with FastTokens:
Added new methods for the fasttokens and a lot of entries must be updated in later commits. Change-Id: I37de9c8d4bdeb75f678902a422a5961670480562 Reviewed-on: https://gerrit.libreoffice.org/28355 Reviewed-by: Noel Grandin <noelgrandin@gmail.com> Tested-by: Noel Grandin <noelgrandin@gmail.com>
This commit is contained in:
committed by
Noel Grandin
parent
674e0f0b43
commit
e3b3c3fe41
@@ -28,20 +28,32 @@
|
|||||||
|
|
||||||
|
|
||||||
class SvXMLTokenMap_Impl;
|
class SvXMLTokenMap_Impl;
|
||||||
|
class SvXMLTokenMapEntry_Impl;
|
||||||
|
|
||||||
#define XML_TOK_UNKNOWN 0xffffU
|
#define XML_TOK_UNKNOWN 0xffffU
|
||||||
#define XML_TOKEN_MAP_END { 0xffffU, ::xmloff::token::XML_TOKEN_INVALID, 0U }
|
#define XML_TOKEN_MAP_END { 0xffffU, xmloff::token::XML_TOKEN_INVALID, 0U, 0 }
|
||||||
|
|
||||||
struct SvXMLTokenMapEntry
|
struct SvXMLTokenMapEntry
|
||||||
{
|
{
|
||||||
sal_uInt16 nPrefixKey;
|
sal_uInt16 nPrefixKey;
|
||||||
enum ::xmloff::token::XMLTokenEnum eLocalName;
|
enum xmloff::token::XMLTokenEnum eLocalName;
|
||||||
sal_uInt16 nToken;
|
sal_uInt16 nToken;
|
||||||
|
sal_Int32 nFastToken;
|
||||||
|
|
||||||
|
SvXMLTokenMapEntry( sal_uInt16 nPrefix, xmloff::token::XMLTokenEnum eName,
|
||||||
|
sal_uInt16 nTok = XML_TOK_UNKNOWN, sal_Int32 nFastTok = 0 ) :
|
||||||
|
nPrefixKey( nPrefix ),
|
||||||
|
eLocalName( eName ),
|
||||||
|
nToken( nTok ),
|
||||||
|
nFastToken( nFastTok )
|
||||||
|
{}
|
||||||
};
|
};
|
||||||
|
|
||||||
class XMLOFF_DLLPUBLIC SvXMLTokenMap
|
class XMLOFF_DLLPUBLIC SvXMLTokenMap
|
||||||
{
|
{
|
||||||
|
private:
|
||||||
std::unique_ptr<SvXMLTokenMap_Impl> m_pImpl;
|
std::unique_ptr<SvXMLTokenMap_Impl> m_pImpl;
|
||||||
|
sal_uInt16 Get( const SvXMLTokenMapEntry_Impl& rEntry ) const;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@@ -49,6 +61,7 @@ public:
|
|||||||
~SvXMLTokenMap();
|
~SvXMLTokenMap();
|
||||||
|
|
||||||
sal_uInt16 Get( sal_uInt16 nPrefix, const OUString& rLName ) const;
|
sal_uInt16 Get( sal_uInt16 nPrefix, const OUString& rLName ) const;
|
||||||
|
sal_uInt16 Get( sal_Int32 nFastTok ) const;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // INCLUDED_XMLOFF_XMLTKMAP_HXX
|
#endif // INCLUDED_XMLOFF_XMLTKMAP_HXX
|
||||||
|
@@ -30,22 +30,25 @@ class SvXMLTokenMapEntry_Impl
|
|||||||
sal_uInt16 nPrefixKey;
|
sal_uInt16 nPrefixKey;
|
||||||
OUString sLocalName;
|
OUString sLocalName;
|
||||||
sal_uInt16 nToken;
|
sal_uInt16 nToken;
|
||||||
|
sal_Int32 nFastToken;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
sal_uInt16 GetToken() const { return nToken; }
|
sal_uInt16 GetToken() const { return nToken; }
|
||||||
|
|
||||||
SvXMLTokenMapEntry_Impl( sal_uInt16 nPrefix, const OUString& rLName,
|
SvXMLTokenMapEntry_Impl( sal_uInt16 nPrefix, const OUString& rLName,
|
||||||
sal_uInt16 nTok=XML_TOK_UNKNOWN ) :
|
sal_uInt16 nTok = XML_TOK_UNKNOWN, sal_Int32 nFastTok = 0 ) :
|
||||||
nPrefixKey( nPrefix ),
|
nPrefixKey( nPrefix ),
|
||||||
sLocalName( rLName ),
|
sLocalName( rLName ),
|
||||||
nToken( nTok )
|
nToken( nTok ),
|
||||||
|
nFastToken( nFastTok )
|
||||||
{}
|
{}
|
||||||
|
|
||||||
explicit SvXMLTokenMapEntry_Impl( const SvXMLTokenMapEntry& rEntry ) :
|
explicit SvXMLTokenMapEntry_Impl( const SvXMLTokenMapEntry& rEntry ) :
|
||||||
nPrefixKey( rEntry.nPrefixKey ),
|
nPrefixKey( rEntry.nPrefixKey ),
|
||||||
sLocalName( GetXMLToken( rEntry.eLocalName ) ),
|
sLocalName( GetXMLToken( rEntry.eLocalName ) ),
|
||||||
nToken( rEntry.nToken )
|
nToken( rEntry.nToken ),
|
||||||
|
nFastToken( rEntry.nFastToken )
|
||||||
{}
|
{}
|
||||||
|
|
||||||
bool operator<( const SvXMLTokenMapEntry_Impl& r ) const
|
bool operator<( const SvXMLTokenMapEntry_Impl& r ) const
|
||||||
@@ -72,13 +75,10 @@ SvXMLTokenMap::~SvXMLTokenMap()
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
sal_uInt16 SvXMLTokenMap::Get( sal_uInt16 nKeyPrefix,
|
sal_uInt16 SvXMLTokenMap::Get( const SvXMLTokenMapEntry_Impl& rEntry ) const
|
||||||
const OUString& rLName ) const
|
|
||||||
{
|
{
|
||||||
SvXMLTokenMapEntry_Impl const* pEntry = nullptr;
|
SvXMLTokenMapEntry_Impl const* pEntry = nullptr;
|
||||||
SvXMLTokenMapEntry_Impl aTst( nKeyPrefix, rLName );
|
SvXMLTokenMap_Impl::iterator it = m_pImpl->find( rEntry );
|
||||||
|
|
||||||
SvXMLTokenMap_Impl::iterator it = m_pImpl->find( aTst );
|
|
||||||
if (it != m_pImpl->end())
|
if (it != m_pImpl->end())
|
||||||
{
|
{
|
||||||
pEntry = &*it;
|
pEntry = &*it;
|
||||||
@@ -90,4 +90,18 @@ sal_uInt16 SvXMLTokenMap::Get( sal_uInt16 nKeyPrefix,
|
|||||||
return XML_TOK_UNKNOWN;
|
return XML_TOK_UNKNOWN;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sal_uInt16 SvXMLTokenMap::Get( sal_uInt16 nKeyPrefix,
|
||||||
|
const OUString& rLName ) const
|
||||||
|
{
|
||||||
|
SvXMLTokenMapEntry_Impl aTst( nKeyPrefix, rLName );
|
||||||
|
return( Get( aTst ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
sal_uInt16 SvXMLTokenMap::Get( sal_Int32 nFastTok ) const
|
||||||
|
{
|
||||||
|
static const OUString sEmptyString("");
|
||||||
|
SvXMLTokenMapEntry_Impl aTst( 0, sEmptyString, XML_TOK_UNKNOWN, nFastTok );
|
||||||
|
return( Get( aTst ) );
|
||||||
|
}
|
||||||
|
|
||||||
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|
||||||
|
Reference in New Issue
Block a user