sw/source/core/draw/dflyobj.cxx | 10 +++++++--- sw/source/core/inc/dflyobj.hxx | 3 ++- 2 files changed, 9 insertions(+), 4 deletions(-)
New commits: commit 6dc48ef517b60adb7cfe09a65773d4ff7d69489c Author: Michael Stahl <mst...@redhat.com> Date: Mon May 19 11:06:33 2014 +0200 fdo#78149: assert if SwVirtFlyDrawObj is being painted with no ViewPort set Change-Id: I2f94a28d85fa31c5623ff0c6067edc7060998d9e diff --git a/sw/source/core/draw/dflyobj.cxx b/sw/source/core/draw/dflyobj.cxx index c7b57fe..80f09d7 100644 --- a/sw/source/core/draw/dflyobj.cxx +++ b/sw/source/core/draw/dflyobj.cxx @@ -168,7 +168,7 @@ namespace drawinglayer virtual basegfx::B2DRange getB2DRange(const geometry::ViewInformation2D& rViewInformation) const SAL_OVERRIDE; - // overloaded to allow callbacks to wrap_DoPaintObject + // override to allow callbacks to wrap_DoPaintObject virtual Primitive2DSequence get2DDecomposition(const geometry::ViewInformation2D& rViewInformation) const SAL_OVERRIDE; // data read access @@ -233,7 +233,7 @@ namespace drawinglayer // when they do not know this primitive (and they do not). Inside wrap_DoPaintObject // there needs to be a test that paint is only done during SW repaints (see there). // Using this mechanism guarantees the correct Z-Order of the VirtualObject-based FlyFrames. - getSwVirtFlyDrawObj().wrap_DoPaintObject(); + getSwVirtFlyDrawObj().wrap_DoPaintObject(rViewInformation); // call parent return BufferedDecompositionPrimitive2D::get2DDecomposition(rViewInformation); @@ -445,7 +445,8 @@ namespace } // <-- -void SwVirtFlyDrawObj::wrap_DoPaintObject() const +void SwVirtFlyDrawObj::wrap_DoPaintObject( + drawinglayer::geometry::ViewInformation2D const& rViewInformation) const { SwViewShell* pShell = pFlyFrm->getRootFrm()->GetCurrShell(); @@ -465,6 +466,9 @@ void SwVirtFlyDrawObj::wrap_DoPaintObject() const if ( bDrawObject ) { + // if there's no viewport set, all fly-frames will be painted, + // which is slow, wastes memory, and can cause other trouble. + assert(!rViewInformation.getViewport().isEmpty()); if ( !pFlyFrm->IsFlyInCntFrm() ) { // it is also necessary to restore the VCL MapMode from ViewInformation since e.g. diff --git a/sw/source/core/inc/dflyobj.hxx b/sw/source/core/inc/dflyobj.hxx index f7b5da9..a839716 100644 --- a/sw/source/core/inc/dflyobj.hxx +++ b/sw/source/core/inc/dflyobj.hxx @@ -70,7 +70,8 @@ protected: public: // for paints triggered form ExecutePrimitive - void wrap_DoPaintObject() const; + void wrap_DoPaintObject( + drawinglayer::geometry::ViewInformation2D const&) const; // for simple access to inner and outer bounds basegfx::B2DRange getOuterBound() const; _______________________________________________ Libreoffice-commits mailing list libreoffice-comm...@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/libreoffice-commits