[Libreoffice-commits] core.git: vcl/source

Marco Cecchetti marco.cecchetti at collabora.com
Tue May 30 16:08:41 UTC 2017


 vcl/source/gdi/bitmap.cxx |   15 +++++++++++++++
 1 file changed, 15 insertions(+)

New commits:
commit 6a01c2d4cab8c3f1a4ba61e7c4e049771612127e
Author: Marco Cecchetti <marco.cecchetti at collabora.com>
Date:   Mon May 29 21:07:10 2017 +0200

    tdf#107682 - Repeated images replace correct ones in exported PDF
    
    The problem was due to the buffer acquire methods: in Bitmap::Checksum
    (old implementation) Bitmap::AcquireReadAccess is used to get the bitmap
    buffer: indeed this method relies on SalBitmap::AcquireBuffer (which is
    used in the new implementation) but in case the buffer acquisition
    fails, instead of giving up, it tries to update the imp bitmap instance
    embedded in the bitmap (see BitmapInfoAccess::ImplCreate).
    
    The solution is to perform this further attemp in Bitmap::Checksum when
    the value returned by ImpBitmap::GetChecksum is 0.
    
    Change-Id: Ib901ac941db57756e9a951bacbc573ca206316e0
    Reviewed-on: https://gerrit.libreoffice.org/38165
    Tested-by: Jenkins <ci at libreoffice.org>
    Reviewed-by: Marco Cecchetti <mrcekets at gmail.com>

diff --git a/vcl/source/gdi/bitmap.cxx b/vcl/source/gdi/bitmap.cxx
index 8dc4bd07e0d3..71d5d73f15ab 100644
--- a/vcl/source/gdi/bitmap.cxx
+++ b/vcl/source/gdi/bitmap.cxx
@@ -275,6 +275,21 @@ BitmapChecksum Bitmap::GetChecksum() const
     if( mxImpBmp )
     {
         nRet = mxImpBmp->ImplGetChecksum();
+
+        if (!nRet)
+        {
+            // nRet == 0 => probably, we were not able to acquire
+            // the buffer in SalBitmap::updateChecksum;
+            // so, we need to update the imp bitmap for this bitmap instance
+            // as we do in BitmapInfoAccess::ImplCreate
+            std::shared_ptr<ImpBitmap> xNewImpBmp(new ImpBitmap);
+            if (xNewImpBmp->ImplCreate(*mxImpBmp, GetBitCount()))
+            {
+                Bitmap* pThis = const_cast<Bitmap*>(this);
+                pThis->mxImpBmp = xNewImpBmp;
+                nRet = mxImpBmp->ImplGetChecksum();
+            }
+        }
     }
 
     return nRet;


More information about the Libreoffice-commits mailing list