[Libreoffice-commits] core.git: Branch 'feature/formula-core-rework' - sc/inc sc/source

Kohei Yoshida kohei.yoshida at gmail.com
Thu Jul 25 19:35:16 PDT 2013


 sc/inc/compiler.hxx              |    1 
 sc/source/core/data/conditio.cxx |   12 +-
 sc/source/core/tool/compiler.cxx |  188 ---------------------------------------
 3 files changed, 6 insertions(+), 195 deletions(-)

New commits:
commit 27aed32209a71d86c32ee352538f9c9731f89cb2
Author: Kohei Yoshida <kohei.yoshida at gmail.com>
Date:   Thu Jul 25 22:35:47 2013 -0400

    Make this guy unused, and remove it.
    
    Change-Id: Ib4a2f195b3ff1d291b0ffe99c27b1d3e807252d5

diff --git a/sc/inc/compiler.hxx b/sc/inc/compiler.hxx
index adaa339..687d544 100644
--- a/sc/inc/compiler.hxx
+++ b/sc/inc/compiler.hxx
@@ -457,7 +457,6 @@ public:
                                   const ScAddress& rOldPos, const ScRange&,
                                   SCsCOL nDx, SCsROW nDy, SCsTAB nDz );
 
-    ScRangeData* UpdateDeleteTab(SCTAB nTable, bool bIsMove, bool bIsName, bool& bCompile, SCTAB nSheets = 1);
     ScRangeData* UpdateMoveTab(SCTAB nOldPos, SCTAB nNewPos, bool bIsName );
 
     bool HasModifiedRange();
diff --git a/sc/source/core/data/conditio.cxx b/sc/source/core/data/conditio.cxx
index 9f1db33..0d7cf36 100644
--- a/sc/source/core/data/conditio.cxx
+++ b/sc/source/core/data/conditio.cxx
@@ -544,12 +544,12 @@ void ScConditionEntry::UpdateReference( UpdateRefMode eUpdateRefMode,
             lcl_CondUpdateInsertTab( *pFormula1, rRange.aStart.Tab(), bChanged1, nDz );
         else
         {
-            ScCompiler aComp( mpDoc, aSrcPos, *pFormula1 );
-            aComp.SetGrammar(mpDoc->GetGrammar());
             if ( bDeleteTab )
-                aComp.UpdateDeleteTab( rRange.aStart.Tab(), false, true, bChanged1, static_cast<SCTAB>(-1 * nDz) );
+                pFormula1->AdjustReferenceOnDeletedTab(rRange.aStart.Tab(), static_cast<SCTAB>(-1*nDz), aSrcPos);
             else
             {
+                ScCompiler aComp( mpDoc, aSrcPos, *pFormula1 );
+                aComp.SetGrammar(mpDoc->GetGrammar());
                 bool bSizeChanged;
                 aComp.UpdateReference( eUpdateRefMode, aOldSrcPos, rRange, nDx,
                         nDy, nDz, bChanged1, bSizeChanged );
@@ -566,12 +566,12 @@ void ScConditionEntry::UpdateReference( UpdateRefMode eUpdateRefMode,
             lcl_CondUpdateInsertTab( *pFormula2, rRange.aStart.Tab(), bChanged2, nDz );
         else
         {
-            ScCompiler aComp( mpDoc, aSrcPos, *pFormula2);
-            aComp.SetGrammar(mpDoc->GetGrammar());
             if ( bDeleteTab )
-                aComp.UpdateDeleteTab( rRange.aStart.Tab(), false, true, bChanged2, static_cast<SCTAB>(-1*nDz) );
+                pFormula2->AdjustReferenceOnDeletedTab(rRange.aStart.Tab(), static_cast<SCTAB>(-1*nDz), aSrcPos);
             else
             {
+                ScCompiler aComp( mpDoc, aSrcPos, *pFormula2);
+                aComp.SetGrammar(mpDoc->GetGrammar());
                 bool bSizeChanged;
                 aComp.UpdateReference( eUpdateRefMode, aOldSrcPos, rRange, nDx,
                         nDy, nDz, bChanged2, bSizeChanged );
diff --git a/sc/source/core/tool/compiler.cxx b/sc/source/core/tool/compiler.cxx
index a2cc262..6c5107b 100644
--- a/sc/source/core/tool/compiler.cxx
+++ b/sc/source/core/tool/compiler.cxx
@@ -4424,194 +4424,6 @@ void ScCompiler::UpdateSharedFormulaReference( UpdateRefMode eUpdateRefMode,
     }
 }
 
-ScRangeData* ScCompiler::UpdateDeleteTab(SCTAB nTable, bool /* bIsMove */, bool bIsName,
-                                 bool& rChanged, SCTAB nSheets)
-{
-    ScRangeData* pRangeData = NULL;
-    SCTAB nTab, nTab2;
-    SCTAB nPosTab = aPos.Tab();          // _after_ decremented!
-    SCTAB nOldPosTab = ((nPosTab >= nTable) ? (nPosTab + nSheets) : nPosTab);
-    rChanged = false;
-    bool bIsRel = false;
-    ScToken* t;
-    pArr->Reset();
-    if (bIsName)
-        t = static_cast<ScToken*>(pArr->GetNextReference());
-    else
-        t = static_cast<ScToken*>(pArr->GetNextReferenceOrName());
-    while( t )
-    {
-        if( t->GetOpCode() == ocName )
-        {
-            if (!bIsName)
-            {
-                ScRangeData* pName = GetRangeData( *t);
-                if (pName && pName->HasType(RT_SHAREDMOD))
-                    pRangeData = pName;
-            }
-            rChanged = true;
-        }
-        else if( t->GetType() != svIndex )  // it may be a DB area!!!
-        {
-            if ( !(bIsName && t->GetSingleRef().IsTabRel()) )
-            {   // of names only adjust absolute references
-                ScSingleRefData& rRef = t->GetSingleRef();
-                if ( rRef.IsTabRel() )
-                    nTab = rRef.nTab = rRef.nRelTab + nOldPosTab;
-                else
-                    nTab = rRef.nTab;
-                if ( nTable < nTab )
-                {
-                    rRef.nTab = nTab - nSheets;
-                    rChanged = true;
-                }
-                else if ( nTable == nTab )
-                {
-                    if ( t->GetType() == svDoubleRef )
-                    {
-                        ScSingleRefData& rRef2 = t->GetDoubleRef().Ref2;
-                        if ( rRef2.IsTabRel() )
-                            nTab2 = rRef2.nRelTab + nOldPosTab;
-                        else
-                            nTab2 = rRef2.nTab;
-                        if ( nTab == nTab2
-                          || (nTab+nSheets) >= pDoc->GetTableCount() )
-                        {
-                            rRef.nTab = MAXTAB+1;
-                            rRef.SetTabDeleted( true );
-                        }
-                        // else: nTab later points to what's nTable+1 now
-                        // => area shrunk
-                    }
-                    else
-                    {
-                        rRef.nTab = MAXTAB+1;
-                        rRef.SetTabDeleted( true );
-                    }
-                    rChanged = true;
-                }
-                rRef.nRelTab = rRef.nTab - nPosTab;
-            }
-            else
-                bIsRel = true;
-            if ( t->GetType() == svDoubleRef )
-            {
-                if ( !(bIsName && t->GetDoubleRef().Ref2.IsTabRel()) )
-                {   // of names only adjust absolute references
-                    ScSingleRefData& rRef = t->GetDoubleRef().Ref2;
-                    if ( rRef.IsTabRel() )
-                        nTab = rRef.nTab = rRef.nRelTab + nOldPosTab;
-                    else
-                        nTab = rRef.nTab;
-                    if ( nTable < nTab )
-                    {
-                        rRef.nTab = nTab - nSheets;
-                        rChanged = true;
-                    }
-                    else if ( nTable == nTab )
-                    {
-                        if ( !t->GetDoubleRef().Ref1.IsTabDeleted() )
-                            rRef.nTab = nTab - nSheets;   // shrink area
-                        else
-                        {
-                            rRef.nTab = MAXTAB+1;
-                            rRef.SetTabDeleted( true );
-                        }
-                        rChanged = true;
-                    }
-                    rRef.nRelTab = rRef.nTab - nPosTab;
-                }
-                else
-                    bIsRel = true;
-            }
-            if ( bIsName && bIsRel )
-                pRangeData = (ScRangeData*) this;   // not dereferenced in rangenam
-        }
-        if (bIsName)
-            t = static_cast<ScToken*>(pArr->GetNextReference());
-        else
-            t = static_cast<ScToken*>(pArr->GetNextReferenceOrName());
-    }
-    if ( !bIsName )
-    {
-        pArr->Reset();
-        while ( (t = static_cast<ScToken*>(pArr->GetNextReferenceRPN())) != NULL )
-        {
-            if ( t->GetRef() == 1 )
-            {
-                ScSingleRefData& rRef1 = t->GetSingleRef();
-                if ( !(rRef1.IsRelName() && rRef1.IsTabRel()) )
-                {   // of names only adjust absolute references
-                    if ( rRef1.IsTabRel() )
-                        nTab = rRef1.nTab = rRef1.nRelTab + nOldPosTab;
-                    else
-                        nTab = rRef1.nTab;
-                    if ( nTable < nTab )
-                    {
-                        rRef1.nTab = nTab - nSheets;
-                        rChanged = true;
-                    }
-                    else if ( nTable == nTab )
-                    {
-                        if ( t->GetType() == svDoubleRef )
-                        {
-                            ScSingleRefData& rRef2 = t->GetDoubleRef().Ref2;
-                            if ( rRef2.IsTabRel() )
-                                nTab2 = rRef2.nRelTab + nOldPosTab;
-                            else
-                                nTab2 = rRef2.nTab;
-                            if ( nTab == nTab2
-                              || (nTab+1) >= pDoc->GetTableCount() )
-                            {
-                                rRef1.nTab = MAXTAB+1;
-                                rRef1.SetTabDeleted( true );
-                            }
-                            // else: nTab later points to what's nTable+1 now
-                            // => area shrunk
-                        }
-                        else
-                        {
-                            rRef1.nTab = MAXTAB+1;
-                            rRef1.SetTabDeleted( true );
-                        }
-                        rChanged = true;
-                    }
-                    rRef1.nRelTab = rRef1.nTab - nPosTab;
-                }
-                if ( t->GetType() == svDoubleRef )
-                {
-                    ScSingleRefData& rRef2 = t->GetDoubleRef().Ref2;
-                    if ( !(rRef2.IsRelName() && rRef2.IsTabRel()) )
-                    {   // of names only adjust absolute references
-                        if ( rRef2.IsTabRel() )
-                            nTab = rRef2.nTab = rRef2.nRelTab + nOldPosTab;
-                        else
-                            nTab = rRef2.nTab;
-                        if ( nTable < nTab )
-                        {
-                            rRef2.nTab = nTab - nSheets;
-                            rChanged = true;
-                        }
-                        else if ( nTable == nTab )
-                        {
-                            if ( !rRef1.IsTabDeleted() )
-                                rRef2.nTab = nTab - nSheets;  // shrink area
-                            else
-                            {
-                                rRef2.nTab = MAXTAB+1;
-                                rRef2.SetTabDeleted( true );
-                            }
-                            rChanged = true;
-                        }
-                        rRef2.nRelTab = rRef2.nTab - nPosTab;
-                    }
-                }
-            }
-        }
-    }
-    return pRangeData;
-}
-
 // aPos.Tab() must be already adjusted!
 ScRangeData* ScCompiler::UpdateMoveTab( SCTAB nOldTab, SCTAB nNewTab,
         bool bIsName )


More information about the Libreoffice-commits mailing list