[Libreoffice-commits] core.git: Branch 'feature/formula-core-rework' - sc/inc sc/source
Kohei Yoshida
kohei.yoshida at gmail.com
Thu Jul 25 19:44:50 PDT 2013
sc/inc/compiler.hxx | 8 -
sc/source/core/data/conditio.cxx | 9 -
sc/source/core/tool/compiler.cxx | 250 ---------------------------------------
3 files changed, 3 insertions(+), 264 deletions(-)
New commits:
commit 4ba6b270c25f373f5c21b4b3302d83219654ee3c
Author: Kohei Yoshida <kohei.yoshida at gmail.com>
Date: Thu Jul 25 22:45:15 2013 -0400
More on removing unused methods after some adjustments.
Change-Id: Ib8322228f25094c7c90a6623293e61f56b66b659
diff --git a/sc/inc/compiler.hxx b/sc/inc/compiler.hxx
index 687d544..4792f79 100644
--- a/sc/inc/compiler.hxx
+++ b/sc/inc/compiler.hxx
@@ -451,14 +451,6 @@ public:
SCsCOL nDx, SCsROW nDy, SCsTAB nDz,
bool& rChanged, bool& rRefSizeChanged );
- /// Only once for converted shared formulas,
- /// token array has to be compiled afterwards.
- void UpdateSharedFormulaReference( UpdateRefMode eUpdateRefMode,
- const ScAddress& rOldPos, const ScRange&,
- SCsCOL nDx, SCsROW nDy, SCsTAB nDz );
-
- ScRangeData* UpdateMoveTab(SCTAB nOldPos, SCTAB nNewPos, bool bIsName );
-
bool HasModifiedRange();
/** If the character is allowed as first character in sheet names or
diff --git a/sc/source/core/data/conditio.cxx b/sc/source/core/data/conditio.cxx
index 0d7cf36..3fb8a5f 100644
--- a/sc/source/core/data/conditio.cxx
+++ b/sc/source/core/data/conditio.cxx
@@ -587,16 +587,13 @@ void ScConditionEntry::UpdateMoveTab( SCTAB nOldPos, SCTAB nNewPos )
{
if (pFormula1)
{
- ScCompiler aComp( mpDoc, aSrcPos, *pFormula1);
- aComp.SetGrammar(mpDoc->GetGrammar());
- aComp.UpdateMoveTab(nOldPos, nNewPos, true );
+ pFormula1->AdjustReferenceOnMovedTab(nOldPos, nNewPos, aSrcPos);
DELETEZ(pFCell1);
}
+
if (pFormula2)
{
- ScCompiler aComp( mpDoc, aSrcPos, *pFormula2);
- aComp.SetGrammar(mpDoc->GetGrammar());
- aComp.UpdateMoveTab(nOldPos, nNewPos, true );
+ pFormula2->AdjustReferenceOnMovedTab(nOldPos, nNewPos, aSrcPos);
DELETEZ(pFCell2);
}
}
diff --git a/sc/source/core/tool/compiler.cxx b/sc/source/core/tool/compiler.cxx
index 6c5107b..4c17edf 100644
--- a/sc/source/core/tool/compiler.cxx
+++ b/sc/source/core/tool/compiler.cxx
@@ -4359,256 +4359,6 @@ bool ScCompiler::UpdateNameReference(UpdateRefMode eUpdateRefMode,
return bRelRef;
}
-
-void ScCompiler::UpdateSharedFormulaReference( UpdateRefMode eUpdateRefMode,
- const ScAddress& rOldPos, const ScRange& r,
- SCsCOL nDx, SCsROW nDy, SCsTAB nDz )
-{
- if ( eUpdateRefMode == URM_COPY )
- return ;
- else
- {
- ScToken* t;
- pArr->Reset();
- while ( (t = static_cast<ScToken*>(pArr->GetNextReference())) != NULL )
- {
- if( t->GetType() != svIndex ) // it may be a DB area!!!
- {
- // Absolute references have been already adjusted in the named
- // shared formula itself prior to breaking the shared formula
- // and calling this function. Don't readjust them again.
- SingleDoubleRefModifier aMod( *t );
- ScComplexRefData& rRef = aMod.Ref();
- ScComplexRefData aBkp = rRef;
- ScRange aRefRange = rRef.toAbs(rOldPos);
- ScRange aBkpRange = aRefRange;
- ScRefUpdate::Update(pDoc, eUpdateRefMode, aPos, r, nDx, nDy, nDz, rRef, aRefRange);
- rRef.SetRange(aRefRange, rOldPos);
-
- // restore absolute parts
- if ( !aBkp.Ref1.IsColRel() )
- {
- rRef.Ref1.nCol = aBkpRange.aStart.Col();
- rRef.Ref1.SetColDeleted( aBkp.Ref1.IsColDeleted() );
- }
- if ( !aBkp.Ref1.IsRowRel() )
- {
- rRef.Ref1.nRow = aBkpRange.aStart.Row();
- rRef.Ref1.SetRowDeleted( aBkp.Ref1.IsRowDeleted() );
- }
- if ( !aBkp.Ref1.IsTabRel() )
- {
- rRef.Ref1.nTab = aBkpRange.aStart.Tab();
- rRef.Ref1.SetTabDeleted( aBkp.Ref1.IsTabDeleted() );
- }
- if ( t->GetType() == svDoubleRef )
- {
- if ( !aBkp.Ref2.IsColRel() )
- {
- rRef.Ref2.nCol = aBkpRange.aEnd.Col();
- rRef.Ref2.SetColDeleted( aBkp.Ref2.IsColDeleted() );
- }
- if ( !aBkp.Ref2.IsRowRel() )
- {
- rRef.Ref2.nRow = aBkpRange.aEnd.Row();
- rRef.Ref2.SetRowDeleted( aBkp.Ref2.IsRowDeleted() );
- }
- if ( !aBkp.Ref2.IsTabRel() )
- {
- rRef.Ref2.nTab = aBkpRange.aEnd.Tab();
- rRef.Ref2.SetTabDeleted( aBkp.Ref2.IsTabDeleted() );
- }
- }
- }
- }
- }
-}
-
-// aPos.Tab() must be already adjusted!
-ScRangeData* ScCompiler::UpdateMoveTab( SCTAB nOldTab, SCTAB nNewTab,
- bool bIsName )
-{
- ScRangeData* pRangeData = NULL;
- SCsTAB nTab;
-
- SCTAB nStart, nEnd;
- short nDir; // direction in which others move
- if ( nOldTab < nNewTab )
- {
- nDir = -1;
- nStart = nOldTab;
- nEnd = nNewTab;
- }
- else
- {
- nDir = 1;
- nStart = nNewTab;
- nEnd = nOldTab;
- }
- SCTAB nPosTab = aPos.Tab(); // current sheet
- SCTAB nOldPosTab; // previously it was this one
- if ( nPosTab == nNewTab )
- nOldPosTab = nOldTab; // look, it's me!
- else if ( nPosTab < nStart || nEnd < nPosTab )
- nOldPosTab = nPosTab; // wasn't moved
- else
- nOldPosTab = nPosTab - nDir; // moved by one
-
- 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;
- }
- }
- else if( t->GetType() != svIndex ) // it may be a DB area!!!
- {
- ScSingleRefData& rRef1 = t->GetSingleRef();
- if ( !(bIsName && rRef1.IsTabRel()) )
- { // of names only adjust absolute references
- if ( rRef1.IsTabRel() )
- nTab = rRef1.nRelTab + nOldPosTab;
- else
- nTab = rRef1.nTab;
- if ( nTab == nOldTab )
- rRef1.nTab = nNewTab;
- else if ( nStart <= nTab && nTab <= nEnd )
- rRef1.nTab = nTab + nDir;
- rRef1.nRelTab = rRef1.nTab - nPosTab;
- }
- else
- bIsRel = true;
- if ( t->GetType() == svDoubleRef )
- {
- ScSingleRefData& rRef2 = t->GetDoubleRef().Ref2;
- if ( !(bIsName && rRef2.IsTabRel()) )
- { // of names only adjust absolute references
- if ( rRef2.IsTabRel() )
- nTab = rRef2.nRelTab + nOldPosTab;
- else
- nTab = rRef2.nTab;
- if ( nTab == nOldTab )
- rRef2.nTab = nNewTab;
- else if ( nStart <= nTab && nTab <= nEnd )
- rRef2.nTab = nTab + nDir;
- rRef2.nRelTab = rRef2.nTab - nPosTab;
- }
- else
- bIsRel = true;
- SCsTAB nTab1, nTab2;
- if ( rRef1.IsTabRel() )
- nTab1 = rRef1.nRelTab + nPosTab;
- else
- nTab1 = rRef1.nTab;
- if ( rRef2.IsTabRel() )
- nTab2 = rRef2.nRelTab + nPosTab;
- else
- nTab2 = rRef2.nTab;
- if ( nTab2 < nTab1 )
- { // PutInOrder
- rRef1.nTab = nTab2;
- rRef2.nTab = nTab1;
- rRef1.nRelTab = rRef1.nTab - nPosTab;
- rRef2.nRelTab = rRef2.nTab - nPosTab;
- }
- }
- 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 )
- {
- SCsTAB nMaxTabMod = (SCsTAB) pDoc->GetTableCount();
- pArr->Reset();
- while ( (t = static_cast<ScToken*>(pArr->GetNextReferenceRPN())) != NULL )
- {
- if ( t->GetRef() == 1 )
- {
- ScSingleRefData& rRef1 = t->GetSingleRef();
- if ( rRef1.IsRelName() && rRef1.IsTabRel() )
- { // possibly wrap RelName, like lcl_MoveItWrap in refupdat.cxx
- nTab = rRef1.nRelTab + nPosTab;
- if ( nTab < 0 )
- nTab = sal::static_int_cast<SCsTAB>( nTab + nMaxTabMod );
- else if ( nTab > nMaxTab )
- nTab = sal::static_int_cast<SCsTAB>( nTab - nMaxTabMod );
- rRef1.nRelTab = nTab - nPosTab;
- }
- else
- {
- if ( rRef1.IsTabRel() )
- nTab = rRef1.nRelTab + nOldPosTab;
- else
- nTab = rRef1.nTab;
- if ( nTab == nOldTab )
- rRef1.nTab = nNewTab;
- else if ( nStart <= nTab && nTab <= nEnd )
- rRef1.nTab = nTab + nDir;
- rRef1.nRelTab = rRef1.nTab - nPosTab;
- }
- if( t->GetType() == svDoubleRef )
- {
- ScSingleRefData& rRef2 = t->GetDoubleRef().Ref2;
- if ( rRef2.IsRelName() && rRef2.IsTabRel() )
- { // possibly wrap RelName, like lcl_MoveItWrap in refupdat.cxx
- nTab = rRef2.nRelTab + nPosTab;
- if ( nTab < 0 )
- nTab = sal::static_int_cast<SCsTAB>( nTab + nMaxTabMod );
- else if ( nTab > nMaxTab )
- nTab = sal::static_int_cast<SCsTAB>( nTab - nMaxTabMod );
- rRef2.nRelTab = nTab - nPosTab;
- }
- else
- {
- if ( rRef2.IsTabRel() )
- nTab = rRef2.nRelTab + nOldPosTab;
- else
- nTab = rRef2.nTab;
- if ( nTab == nOldTab )
- rRef2.nTab = nNewTab;
- else if ( nStart <= nTab && nTab <= nEnd )
- rRef2.nTab = nTab + nDir;
- rRef2.nRelTab = rRef2.nTab - nPosTab;
- }
- SCsTAB nTab1, nTab2;
- if ( rRef1.IsTabRel() )
- nTab1 = rRef1.nRelTab + nPosTab;
- else
- nTab1 = rRef1.nTab;
- if ( rRef2.IsTabRel() )
- nTab2 = rRef2.nRelTab + nPosTab;
- else
- nTab2 = rRef2.nTab;
- if ( nTab2 < nTab1 )
- { // PutInOrder
- rRef1.nTab = nTab2;
- rRef2.nTab = nTab1;
- rRef1.nRelTab = rRef1.nTab - nPosTab;
- rRef2.nRelTab = rRef2.nTab - nPosTab;
- }
- }
- }
- }
- }
- return pRangeData;
-}
-
-
void ScCompiler::CreateStringFromExternal(OUStringBuffer& rBuffer, FormulaToken* pTokenP)
{
FormulaToken* t = pTokenP;
More information about the Libreoffice-commits
mailing list