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

Eike Rathke (via logerrit) logerrit at kemper.freedesktop.org
Thu Apr 1 22:49:26 UTC 2021


 sc/inc/formulacell.hxx |   22 +++++++++++++++++-----
 1 file changed, 17 insertions(+), 5 deletions(-)

New commits:
commit 465b8b0e9ad4b0c9c7701dee2820a99c5d00b5bf
Author:     Eike Rathke <erack at redhat.com>
AuthorDate: Thu Apr 1 23:51:46 2021 +0200
Commit:     Eike Rathke <erack at redhat.com>
CommitDate: Fri Apr 2 00:48:46 2021 +0200

    Work around assert() in circular reference within group calc, tdf#141146
    
    Triggered by crash test loading document of
    wget 'https://bz.apache.org/ooo/attachment.cgi?id=71756' -O ooo114587-1.ods
    
    after
    
        commit 042dbf83122b14fd1dd32705c8f8b7d65c22f21b
        CommitDate: Thu Mar 25 16:31:29 2021 +0100
    
            Resolves: tdf#141146 Fix LOOKUP in array with result
            scalar / single reference
    
    Though could happen any time whenever a shared formula group calc
    attempts to obtain a result from an already running cell.
    
    Change-Id: Id668b31a8d81389c593c6fd2191fd444efcdb70f
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/113494
    Reviewed-by: Eike Rathke <erack at redhat.com>
    Tested-by: Jenkins

diff --git a/sc/inc/formulacell.hxx b/sc/inc/formulacell.hxx
index ae889d7ba77b..28317d60690a 100644
--- a/sc/inc/formulacell.hxx
+++ b/sc/inc/formulacell.hxx
@@ -22,11 +22,13 @@
 #include <memory>
 
 #include <formula/tokenarray.hxx>
+#include <formula/errorcodes.hxx>
 #include <svl/listener.hxx>
 
 #include "types.hxx"
 #include "interpretercontext.hxx"
 #include "document.hxx"
+#include "docoptio.hxx"
 #include "formulalogger.hxx"
 #include "formularesult.hxx"
 
@@ -436,15 +438,25 @@ public:
         return (rDocument.GetAutoCalc() || (cMatrixFlag != ScMatrixMode::NONE));
     }
 
-    bool MaybeInterpret()
+    void MaybeInterpret()
     {
         if (NeedsInterpret())
         {
-            assert(!rDocument.IsThreadedGroupCalcInProgress());
-            Interpret();
-            return true;
+            if (bRunning && !rDocument.GetDocOptions().IsIter() && rDocument.IsThreadedGroupCalcInProgress())
+            {
+                // This is actually copied from Interpret()'s if(bRunning)
+                // block that once caught this circular reference but now is
+                // prepended with various threaded group calc things which the
+                // assert() below is supposed to fail on when entering again.
+                // Nevertheless, we need some state here the caller can obtain.
+                aResult.SetResultError( FormulaError::CircularReference );
+            }
+            else
+            {
+                assert(!rDocument.IsThreadedGroupCalcInProgress());
+                Interpret();
+            }
         }
-        return false;
     }
 
     /**


More information about the Libreoffice-commits mailing list