sw/source/core/layout/paintfrm.cxx |   13 +++++++++++--
 1 file changed, 11 insertions(+), 2 deletions(-)

New commits:
commit 010cd7e81ef0f8c524ff764eed80e746caa1d94c
Author: Miklos Vajna <vmik...@collabora.co.uk>
Date:   Tue Feb 17 12:16:54 2015 +0100

    tdf#82661 SwFrm::PaintBackground: handle fill attrs when comparing 
background
    
    Regression from 7d9bb549d498d6beed2c4050c402d09643febdfa (Related:
    i#124638 Second step of DrawingLayer FillAttributes..., 2014-06-02),
    should be good enough till SdrAllFillAttributesHelper gets its own
    operator ==().
    
    Change-Id: I03f847bc1589e3771790427d9894cc330a7b8dc6
    (cherry picked from commit 1e33cd8355eb1d856a1439b4a095e379b3acf0bd)
    Reviewed-on: https://gerrit.libreoffice.org/14537
    Reviewed-by: Caolán McNamara <caol...@redhat.com>
    Tested-by: Caolán McNamara <caol...@redhat.com>

diff --git a/sw/source/core/layout/paintfrm.cxx 
b/sw/source/core/layout/paintfrm.cxx
index 0dc99f5..84dfcf6 100644
--- a/sw/source/core/layout/paintfrm.cxx
+++ b/sw/source/core/layout/paintfrm.cxx
@@ -6436,6 +6436,15 @@ void SwFrm::PaintBaBo( const SwRect& rRect, const 
SwPageFrm *pPage,
     pOut->Pop();
 }
 
+static bool lcl_compareFillAttributes(const 
drawinglayer::attribute::SdrAllFillAttributesHelperPtr& pA, const 
drawinglayer::attribute::SdrAllFillAttributesHelperPtr& pB)
+{
+    if (pA == pB)
+        return true;
+    if (!pA || !pB)
+        return false;
+    return pA->getFillAttribute() == pB->getFillAttribute();
+}
+
 /// OD 05.09.2002 #102912#
 /// Do not paint background for fly frames without a background brush by
 /// calling <PaintBaBo> at the page or at the fly frame its anchored
@@ -6540,8 +6549,8 @@ void SwFrm::PaintBackground( const SwRect &rRect, const 
SwPageFrm *pPage,
                 ::lcl_CalcBorderRect( aRect, this, rAttrs, false );
                 if ( (IsTxtFrm() || IsTabFrm()) && GetPrev() )
                 {
-                    if ( GetPrev()->GetAttrSet()->GetBackground() ==
-                         GetAttrSet()->GetBackground() )
+                    if ( GetPrev()->GetAttrSet()->GetBackground() == 
GetAttrSet()->GetBackground() &&
+                         
lcl_compareFillAttributes(GetPrev()->getSdrAllFillAttributesHelper(), 
getSdrAllFillAttributesHelper()))
                     {
                         aRect.Top( Frm().Top() );
                     }
_______________________________________________
Libreoffice-commits mailing list
libreoffice-comm...@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/libreoffice-commits

Reply via email to