summaryrefslogtreecommitdiff
path: root/xmloff/source
diff options
context:
space:
mode:
authorMohammed Abdul Azeem <azeemmysore@gmail.com>2016-08-26 23:32:23 +0530
committerNoel Grandin <noelgrandin@gmail.com>2016-08-29 06:22:46 +0000
commit41b3fd8ca54eff7e71c69bb0b60e63016f1ac8c2 (patch)
treee5a3af9a2f0c0a7c40333c59869fff9ee1b953e7 /xmloff/source
parent301279ea15f0310367598300f884062333628767 (diff)
Make SvXMLTokenMap compatible with FastTokens:
Added seperate map for fastToken and Token, to get token using only fastToken. Default values are derived for fastTokens from prefixKey and localName. Duplicate/ dummy tokens need to be overidden with different values. Change-Id: I17268754d8fd1bac29dd7bae05706ff20b8314ae Reviewed-on: https://gerrit.libreoffice.org/28415 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Noel Grandin <noelgrandin@gmail.com>
Diffstat (limited to 'xmloff/source')
-rw-r--r--xmloff/source/core/xmltkmap.cxx95
-rw-r--r--xmloff/source/style/GradientStyle.cxx4
-rw-r--r--xmloff/source/style/HatchStyle.cxx4
-rw-r--r--xmloff/source/style/TransGradientStyle.cxx4
-rw-r--r--xmloff/source/token/tokens.txt2
5 files changed, 54 insertions, 55 deletions
diff --git a/xmloff/source/core/xmltkmap.cxx b/xmloff/source/core/xmltkmap.cxx
index 6888b62aae60..1aca38975d9b 100644
--- a/xmloff/source/core/xmltkmap.cxx
+++ b/xmloff/source/core/xmltkmap.cxx
@@ -21,52 +21,63 @@
#include <xmloff/xmltkmap.hxx>
#include <xmloff/xmltoken.hxx>
-#include <set>
+#include <unordered_map>
+#include <utility>
using namespace ::xmloff::token;
-class SvXMLTokenMapEntry_Impl
+class SvXMLTokenMap_Impl
{
- sal_uInt16 nPrefixKey;
- OUString sLocalName;
- sal_uInt16 nToken;
- sal_Int32 nFastToken;
+private:
+ struct PairHash
+ {
+ std::size_t operator()(const std::pair<sal_uInt16,OUString> &pair) const
+ {
+ return static_cast<std::size_t>( pair.first | pair.second.hashCode() );
+ }
+ };
+ std::unordered_map< std::pair<sal_uInt16, OUString>,
+ sal_uInt16, PairHash> m_aPrefixAndNameToTokenMap;
+ std::unordered_map< sal_Int32, sal_uInt16> m_aFastTokenToTokenMap;
public:
+ void insert( const SvXMLTokenMapEntry& rEntry );
+ sal_uInt16 get( sal_uInt16 nKeyPrefix, const OUString& rLName ) const;
+ sal_uInt16 get( sal_Int32 nFastTok ) const;
+};
- sal_uInt16 GetToken() const { return nToken; }
-
- SvXMLTokenMapEntry_Impl( sal_uInt16 nPrefix, const OUString& rLName,
- sal_uInt16 nTok = XML_TOK_UNKNOWN, sal_Int32 nFastTok = 0 ) :
- nPrefixKey( nPrefix ),
- sLocalName( rLName ),
- nToken( nTok ),
- nFastToken( nFastTok )
- {}
-
- explicit SvXMLTokenMapEntry_Impl( const SvXMLTokenMapEntry& rEntry ) :
- nPrefixKey( rEntry.nPrefixKey ),
- sLocalName( GetXMLToken( rEntry.eLocalName ) ),
- nToken( rEntry.nToken ),
- nFastToken( rEntry.nFastToken )
- {}
+void SvXMLTokenMap_Impl::insert( const SvXMLTokenMapEntry& rEntry )
+{
+ m_aPrefixAndNameToTokenMap.insert( std::make_pair( std::make_pair( rEntry.nPrefixKey,
+ GetXMLToken( rEntry.eLocalName ) ), rEntry.nToken ) );
+ if( rEntry.nFastToken )
+ m_aFastTokenToTokenMap.insert( std::make_pair( rEntry.nFastToken, rEntry.nToken ) );
+}
- bool operator<( const SvXMLTokenMapEntry_Impl& r ) const
- {
- return nPrefixKey < r.nPrefixKey ||
- ( nPrefixKey == r.nPrefixKey &&
- sLocalName < r.sLocalName);
- }
-};
+sal_uInt16 SvXMLTokenMap_Impl::get( sal_uInt16 nKeyPrefix, const OUString& rLName ) const
+{
+ auto aIter( m_aPrefixAndNameToTokenMap.find( std::make_pair( nKeyPrefix, rLName ) ) );
+ if ( aIter != m_aPrefixAndNameToTokenMap.end() )
+ return (*aIter).second;
+ else
+ return XML_TOK_UNKNOWN;
+}
-class SvXMLTokenMap_Impl : public std::set<SvXMLTokenMapEntry_Impl> {};
+sal_uInt16 SvXMLTokenMap_Impl::get( sal_Int32 nFastTok ) const
+{
+ auto aIter( m_aFastTokenToTokenMap.find( nFastTok ) );
+ if ( aIter != m_aFastTokenToTokenMap.end() )
+ return (*aIter).second;
+ else
+ return XML_TOK_UNKNOWN;
+}
SvXMLTokenMap::SvXMLTokenMap( const SvXMLTokenMapEntry *pMap )
: m_pImpl( new SvXMLTokenMap_Impl )
{
while( pMap->eLocalName != XML_TOKEN_INVALID )
{
- m_pImpl->insert(SvXMLTokenMapEntry_Impl( *pMap ));
+ m_pImpl->insert( *pMap );
pMap++;
}
}
@@ -75,33 +86,15 @@ SvXMLTokenMap::~SvXMLTokenMap()
{
}
-sal_uInt16 SvXMLTokenMap::Get( const SvXMLTokenMapEntry_Impl& rEntry ) const
-{
- SvXMLTokenMapEntry_Impl const* pEntry = nullptr;
- SvXMLTokenMap_Impl::iterator it = m_pImpl->find( rEntry );
- if (it != m_pImpl->end())
- {
- pEntry = &*it;
- }
-
- if( pEntry )
- return pEntry->GetToken();
- else
- return XML_TOK_UNKNOWN;
-}
-
sal_uInt16 SvXMLTokenMap::Get( sal_uInt16 nKeyPrefix,
const OUString& rLName ) const
{
- SvXMLTokenMapEntry_Impl aTst( nKeyPrefix, rLName );
- return( Get( aTst ) );
+ return m_pImpl->get( nKeyPrefix, rLName );
}
sal_uInt16 SvXMLTokenMap::Get( sal_Int32 nFastTok ) const
{
- static const OUString sEmptyString("");
- SvXMLTokenMapEntry_Impl aTst( 0, sEmptyString, XML_TOK_UNKNOWN, nFastTok );
- return( Get( aTst ) );
+ return m_pImpl->get( nFastTok );
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/xmloff/source/style/GradientStyle.cxx b/xmloff/source/style/GradientStyle.cxx
index fd72968f93a3..ac05a0dbacee 100644
--- a/xmloff/source/style/GradientStyle.cxx
+++ b/xmloff/source/style/GradientStyle.cxx
@@ -94,7 +94,9 @@ void XMLGradientStyleImport::importXML(
{ XML_NAMESPACE_DRAW, XML_START_INTENSITY, XML_TOK_GRADIENT_STARTINT },
{ XML_NAMESPACE_DRAW, XML_END_INTENSITY, XML_TOK_GRADIENT_ENDINT },
{ XML_NAMESPACE_DRAW, XML_GRADIENT_ANGLE, XML_TOK_GRADIENT_ANGLE },
- { XML_NAMESPACE_DRAW, XML_GRADIENT_BORDER, XML_TOK_GRADIENT_BORDER },
+ { XML_NAMESPACE_DRAW, XML_GRADIENT_BORDER, XML_TOK_GRADIENT_BORDER,
+ NAMESPACE_TOKEN( XML_NAMESPACE_DRAW ) | XML_BORDER },
+ // XML_GRADIENT_BORDER is a duplicate of XML_BORDER
XML_TOKEN_MAP_END
};
diff --git a/xmloff/source/style/HatchStyle.cxx b/xmloff/source/style/HatchStyle.cxx
index 43c1e029e953..ea7999f0ac27 100644
--- a/xmloff/source/style/HatchStyle.cxx
+++ b/xmloff/source/style/HatchStyle.cxx
@@ -79,7 +79,9 @@ void XMLHatchStyleImport::importXML(
{ XML_NAMESPACE_DRAW, XML_DISPLAY_NAME, XML_TOK_HATCH_DISPLAY_NAME },
{ XML_NAMESPACE_DRAW, XML_STYLE, XML_TOK_HATCH_STYLE },
{ XML_NAMESPACE_DRAW, XML_COLOR, XML_TOK_HATCH_COLOR },
- { XML_NAMESPACE_DRAW, XML_HATCH_DISTANCE, XML_TOK_HATCH_DISTANCE },
+ { XML_NAMESPACE_DRAW, XML_HATCH_DISTANCE, XML_TOK_HATCH_DISTANCE,
+ NAMESPACE_TOKEN( XML_NAMESPACE_DRAW ) | XML_DISTANCE },
+ // XML_HATCH_DISTANCE is a duplicate of XML_DISTANCE
{ XML_NAMESPACE_DRAW, XML_ROTATION, XML_TOK_HATCH_ROTATION },
XML_TOKEN_MAP_END
};
diff --git a/xmloff/source/style/TransGradientStyle.cxx b/xmloff/source/style/TransGradientStyle.cxx
index ab193f1a4895..5a9d93d0f94a 100644
--- a/xmloff/source/style/TransGradientStyle.cxx
+++ b/xmloff/source/style/TransGradientStyle.cxx
@@ -100,7 +100,9 @@ void XMLTransGradientStyleImport::importXML(
{ XML_NAMESPACE_DRAW, XML_START, XML_TOK_GRADIENT_START },
{ XML_NAMESPACE_DRAW, XML_END, XML_TOK_GRADIENT_END },
{ XML_NAMESPACE_DRAW, XML_GRADIENT_ANGLE, XML_TOK_GRADIENT_ANGLE },
- { XML_NAMESPACE_DRAW, XML_GRADIENT_BORDER, XML_TOK_GRADIENT_BORDER },
+ { XML_NAMESPACE_DRAW, XML_GRADIENT_BORDER, XML_TOK_GRADIENT_BORDER,
+ NAMESPACE_TOKEN( XML_NAMESPACE_DRAW ) | XML_BORDER },
+ // XML_GRADIENT_BORDER is a duplicate of XML_BORDER
XML_TOKEN_MAP_END
};
diff --git a/xmloff/source/token/tokens.txt b/xmloff/source/token/tokens.txt
index d93d50a8053f..1a1db7bcdaeb 100644
--- a/xmloff/source/token/tokens.txt
+++ b/xmloff/source/token/tokens.txt
@@ -62,7 +62,7 @@ NP_BLOCK_LIST_DUMMY
N_BLOCK_LIST_DUMMY
NP_MATH_DUMMY
N_MATH_DUMMY
-VL_DUMMY
+VL
N_VERSIONS_LIST_DUMMY
of
N_OF_DUMMY