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

Libreoffice Gerrit user logerrit at kemper.freedesktop.org
Mon Nov 12 05:15:04 UTC 2018


 sc/inc/formulacell.hxx              |   30 +++++++++++++++++++++++++++---
 sc/source/core/data/formulacell.cxx |   27 ---------------------------
 2 files changed, 27 insertions(+), 30 deletions(-)

New commits:
commit eb51a44ca493b29d4caee393cf39d09a0df97f9e
Author:     Dennis Francis <dennis.francis at collabora.co.uk>
AuthorDate: Thu Nov 8 10:03:44 2018 +0530
Commit:     Dennis Francis <dennis.francis at collabora.com>
CommitDate: Mon Nov 12 06:14:42 2018 +0100

    Make MaybeInterpret, NeedsInterpret, IsDirtyOrInTableOpDirty inline
    
    because they are in the hot path of the most common workload.
    For example, in SUM(A1:A50000) where column A is itself a
    formula-group, in threaded mode(default) A1:A50000 will already
    be evaluated, so cost to calling MaybeInterpret/NeedsInterpret etc
    should be as minimal as possible.
    
    Change-Id: Ie15c1483573391a718fb3af14cba3c798323363d
    Reviewed-on: https://gerrit.libreoffice.org/63064
    Reviewed-by: Michael Meeks <michael.meeks at collabora.com>
    Tested-by: Jenkins

diff --git a/sc/inc/formulacell.hxx b/sc/inc/formulacell.hxx
index 3af68fbbfadc..9434ed8087de 100644
--- a/sc/inc/formulacell.hxx
+++ b/sc/inc/formulacell.hxx
@@ -27,6 +27,7 @@
 
 #include "types.hxx"
 #include "interpretercontext.hxx"
+#include "document.hxx"
 #include "formulalogger.hxx"
 #include "formularesult.hxx"
 
@@ -222,7 +223,12 @@ public:
     void            SetDirtyAfterLoad();
     void ResetTableOpDirtyVar();
     void            SetTableOpDirty();
-    bool            IsDirtyOrInTableOpDirty() const;
+
+    bool IsDirtyOrInTableOpDirty() const
+    {
+        return bDirty || (bTableOpDirty && pDocument->IsInInterpreterTableOp());
+    }
+
     bool GetDirty() const { return bDirty; }
     void ResetDirty();
     bool NeedsListening() const { return bNeedListening; }
@@ -414,9 +420,27 @@ public:
     /** Determines whether or not the result string contains more than one paragraph */
     bool            IsMultilineResult();
 
-    bool NeedsInterpret() const;
+    bool NeedsInterpret() const
+    {
+        if (bIsIterCell)
+            // Shortcut to force return of current value and not enter Interpret()
+            // as we're looping over all iteration cells.
+            return false;
 
-    void            MaybeInterpret();
+        if (!IsDirtyOrInTableOpDirty())
+            return false;
+
+        return (pDocument->GetAutoCalc() || (cMatrixFlag != ScMatrixMode::NONE));
+    }
+
+    void MaybeInterpret()
+    {
+        if (NeedsInterpret())
+        {
+            assert(!pDocument->IsThreadedGroupCalcInProgress());
+            Interpret();
+        }
+    }
 
     /**
      * Turn a non-grouped cell into the top of a grouped cell.
diff --git a/sc/source/core/data/formulacell.cxx b/sc/source/core/data/formulacell.cxx
index 07bf79af884b..23d518279896 100644
--- a/sc/source/core/data/formulacell.cxx
+++ b/sc/source/core/data/formulacell.cxx
@@ -2517,11 +2517,6 @@ void ScFormulaCell::SetTableOpDirty()
     }
 }
 
-bool ScFormulaCell::IsDirtyOrInTableOpDirty() const
-{
-    return bDirty || (bTableOpDirty && pDocument->IsInInterpreterTableOp());
-}
-
 void ScFormulaCell::SetResultDouble( double n )
 {
     aResult.SetDouble(n);
@@ -2652,28 +2647,6 @@ bool ScFormulaCell::IsMultilineResult()
     return false;
 }
 
-bool ScFormulaCell::NeedsInterpret() const
-{
-    if (bIsIterCell)
-        // Shortcut to force return of current value and not enter Interpret()
-        // as we're looping over all iteration cells.
-        return false;
-
-    if (!IsDirtyOrInTableOpDirty())
-        return false;
-
-    return (pDocument->GetAutoCalc() || (cMatrixFlag != ScMatrixMode::NONE));
-}
-
-void ScFormulaCell::MaybeInterpret()
-{
-    if (NeedsInterpret())
-    {
-        assert(!pDocument->IsThreadedGroupCalcInProgress());
-        Interpret();
-    }
-}
-
 bool ScFormulaCell::IsHyperLinkCell() const
 {
     return pCode && pCode->IsHyperLink();


More information about the Libreoffice-commits mailing list