summaryrefslogtreecommitdiff
path: root/sdext
diff options
context:
space:
mode:
authorAshod Nakashian <ashod.nakashian@collabora.co.uk>2017-11-27 19:56:35 -0500
committerAshod Nakashian <ashnakash@gmail.com>2017-12-24 17:09:08 +0100
commit653736fb23346e07e8c0e6e0125689ae1f49f0f7 (patch)
tree5624b585e09b185783c8c47b99836404aaa91233 /sdext
parent5a529d1743c0d0fe2a5317173dcf159da4ae8784 (diff)
pdf: use bimap for GraphicsContext-id map
In some large PDFs the two maps for mapping GraphicsContext to ID and finding GraphicsContext given and ID are huge (over 160 MB in one case). By using a bimap the footprint went down to 110 MB. Reviewed-on: https://gerrit.libreoffice.org/45380 Reviewed-by: Ashod Nakashian <ashnakash@gmail.com> Tested-by: Ashod Nakashian <ashnakash@gmail.com> (cherry picked from commit 551543bf359f644f727fd1aa86e2c5ae499f88ce) (cherry picked from commit ac328157460e9e6a9ca6834e8233a28e845c2806) Change-Id: I59a444b5efa09fcabc26fa492de723ca063e14a4 Reviewed-on: https://gerrit.libreoffice.org/46988 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Ashod Nakashian <ashnakash@gmail.com>
Diffstat (limited to 'sdext')
-rw-r--r--sdext/source/pdfimport/inc/pdfiprocessor.hxx10
-rw-r--r--sdext/source/pdfimport/tree/pdfiprocessor.cxx18
2 files changed, 15 insertions, 13 deletions
diff --git a/sdext/source/pdfimport/inc/pdfiprocessor.hxx b/sdext/source/pdfimport/inc/pdfiprocessor.hxx
index fae6c0fc5382..f0662b8b1ad9 100644
--- a/sdext/source/pdfimport/inc/pdfiprocessor.hxx
+++ b/sdext/source/pdfimport/inc/pdfiprocessor.hxx
@@ -46,6 +46,9 @@
#include "treevisitorfactory.hxx"
#include "genericelements.hxx"
+#include <boost/bimap/bimap.hpp>
+#include <boost/bimap/unordered_set_of.hpp>
+
namespace pdfi
{
@@ -169,6 +172,10 @@ namespace pdfi
typedef std::unordered_map<sal_Int32,GraphicsContext> IdToGCMap;
typedef std::unordered_map<GraphicsContext,sal_Int32,GraphicsContextHash> GCToIdMap;
+ typedef boost::bimaps::bimap<
+ boost::bimaps::unordered_set_of<GraphicsContext, GraphicsContextHash>,
+ boost::bimaps::unordered_set_of<sal_Int32>
+ > GCToIdBiMap;
typedef std::vector<GraphicsContext> GraphicsContextStack;
@@ -183,8 +190,7 @@ namespace pdfi
GraphicsContextStack m_aGCStack;
sal_Int32 m_nNextGCId;
- IdToGCMap m_aIdToGC;
- GCToIdMap m_aGCToId;
+ GCToIdBiMap m_aGCToId;
ImageContainer m_aImages;
diff --git a/sdext/source/pdfimport/tree/pdfiprocessor.cxx b/sdext/source/pdfimport/tree/pdfiprocessor.cxx
index fac0e6873638..4937e332d6f6 100644
--- a/sdext/source/pdfimport/tree/pdfiprocessor.cxx
+++ b/sdext/source/pdfimport/tree/pdfiprocessor.cxx
@@ -45,7 +45,6 @@
#include <com/sun/star/geometry/RealPoint2D.hpp>
#include <com/sun/star/geometry/RealRectangle2D.hpp>
-
using namespace com::sun::star;
@@ -65,7 +64,6 @@ namespace pdfi
m_aFontToId(),
m_aGCStack(),
m_nNextGCId( 1 ),
- m_aIdToGC(),
m_aGCToId(),
m_aImages(),
m_nPages(0),
@@ -82,8 +80,7 @@ namespace pdfi
GraphicsContext aDefGC;
m_aGCStack.push_back( aDefGC );
- m_aIdToGC[ 0 ] = aDefGC;
- m_aGCToId[ aDefGC ] = 0;
+ m_aGCToId.insert(GCToIdBiMap::relation(aDefGC, 0));
}
void PDFIProcessor::setPageNum( sal_Int32 nPages )
@@ -481,13 +478,12 @@ const FontAttributes& PDFIProcessor::getFont( sal_Int32 nFontId ) const
sal_Int32 PDFIProcessor::getGCId( const GraphicsContext& rGC )
{
sal_Int32 nGCId = 0;
- GCToIdMap::const_iterator it = m_aGCToId.find( rGC );
- if( it != m_aGCToId.end() )
+ auto it = m_aGCToId.left.find( rGC );
+ if( it != m_aGCToId.left.end() )
nGCId = it->second;
else
{
- m_aGCToId[ rGC ] = m_nNextGCId;
- m_aIdToGC[ m_nNextGCId ] = rGC;
+ m_aGCToId.insert(GCToIdBiMap::relation(rGC, m_nNextGCId));
nGCId = m_nNextGCId;
m_nNextGCId++;
}
@@ -497,9 +493,9 @@ sal_Int32 PDFIProcessor::getGCId( const GraphicsContext& rGC )
const GraphicsContext& PDFIProcessor::getGraphicsContext( sal_Int32 nGCId ) const
{
- IdToGCMap::const_iterator it = m_aIdToGC.find( nGCId );
- if( it == m_aIdToGC.end() )
- it = m_aIdToGC.find( 0 );
+ auto it = m_aGCToId.right.find( nGCId );
+ if( it == m_aGCToId.right.end() )
+ it = m_aGCToId.right.find( 0 );
return it->second;
}