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

Eike Rathke erack at redhat.com
Mon Sep 14 08:38:06 PDT 2015


 sc/source/core/data/document.cxx |   16 ++++++++++++----
 1 file changed, 12 insertions(+), 4 deletions(-)

New commits:
commit 97ad6393525a928b5dfe2a6562d7604446da7af0
Author: Eike Rathke <erack at redhat.com>
Date:   Mon Sep 14 17:27:41 2015 +0200

    Resolves: tdf#93895 broadcast cell changes when multi-selection was pasted
    
    It is not sufficient to collect the cells, one has to broadcast on the
    collection.
    
    Change-Id: I11f889936aff43f958c56789e539809289819752

diff --git a/sc/source/core/data/document.cxx b/sc/source/core/data/document.cxx
index e485885..f4aacca 100644
--- a/sc/source/core/data/document.cxx
+++ b/sc/source/core/data/document.cxx
@@ -2960,10 +2960,18 @@ void ScDocument::CopyMultiRangeFromClip(
     // Create Listener after everything has been inserted
     StartListeningFromClip(aDestRange.aStart.Col(), aDestRange.aStart.Row(),
                            aDestRange.aEnd.Col(), aDestRange.aEnd.Row(), rMark, nInsFlag );
-    // Re-broadcast after all Listener have been created
-    SetDirtyFromClip(
-        aDestRange.aStart.Col(), aDestRange.aStart.Row(), aDestRange.aEnd.Col(), aDestRange.aEnd.Row(),
-        rMark, nInsFlag, aBroadcastSpans);
+
+    {
+        ScBulkBroadcast aBulkBroadcast( GetBASM());
+
+        // Set formula cells dirty and collect non-formula cells.
+        SetDirtyFromClip(
+                aDestRange.aStart.Col(), aDestRange.aStart.Row(), aDestRange.aEnd.Col(), aDestRange.aEnd.Row(),
+                rMark, nInsFlag, aBroadcastSpans);
+
+        BroadcastAction aAction(*this);
+        aBroadcastSpans.executeColumnAction(*this, aAction);
+    }
 
     if (bResetCut)
         pClipDoc->GetClipParam().mbCutMode = false;


More information about the Libreoffice-commits mailing list