summaryrefslogtreecommitdiff
path: root/sc/source
diff options
context:
space:
mode:
authorEike Rathke <erack@redhat.com>2015-12-01 13:48:56 +0100
committerEike Rathke <erack@redhat.com>2015-12-01 14:12:19 +0100
commit87ad1705746f8e6a15ae60037a1dd8a163eeecd7 (patch)
tree355f792ad41742d0cd5a241cceebabc1f02e2230 /sc/source
parent6d7b984ed17930bbfb884734ed83b98fb03ab06a (diff)
add DebugCalculationEntry::mnGroup
Change-Id: Ic8b6c661be7570479c271d3ce0aa750e13724fc7
Diffstat (limited to 'sc/source')
-rw-r--r--sc/source/core/data/formulacell.cxx31
1 files changed, 26 insertions, 5 deletions
diff --git a/sc/source/core/data/formulacell.cxx b/sc/source/core/data/formulacell.cxx
index 3963e6ada123..b37fbaa32518 100644
--- a/sc/source/core/data/formulacell.cxx
+++ b/sc/source/core/data/formulacell.cxx
@@ -78,11 +78,13 @@ struct DebugCalculationEntry
ScAddress maPos;
OUString maResult;
const ScDocument* mpDoc;
+ sal_uInt32 mnGroup;
sal_uInt16 mnRecursion;
- DebugCalculationEntry( const ScAddress& rPos, ScDocument* pDoc ) :
+ DebugCalculationEntry( const ScAddress& rPos, ScDocument* pDoc, sal_uInt32 nGroup ) :
maPos(rPos),
mpDoc(pDoc),
+ mnGroup(nGroup),
mnRecursion(pDoc->GetRecursionHelper().GetRecursionCount())
{
}
@@ -99,12 +101,14 @@ static struct DebugCalculation
std::vector< DebugCalculationEntry > mvPos;
std::vector< DebugCalculationEntry > mvResults;
ScAddress maTrigger;
+ sal_uInt32 mnGroup;
bool mbActive;
bool mbSwitchOff;
bool mbPrint;
bool mbPrintResults;
- DebugCalculation() : mbActive(bDebugCalculationActive), mbSwitchOff(false), mbPrint(true), mbPrintResults(false) {}
+ DebugCalculation() : mnGroup(0), mbActive(bDebugCalculationActive), mbSwitchOff(false),
+ mbPrint(true), mbPrintResults(false) {}
/** Print chain in encountered dependency order. */
void print() const
@@ -112,7 +116,7 @@ static struct DebugCalculation
for (auto const& it : mvPos)
{
OUString aStr( it.maPos.Format( SCA_VALID | SCA_TAB_3D, it.mpDoc) +
- " [" + OUString::number( it.mnRecursion) + "]");
+ " [" + OUString::number( it.mnRecursion) + "," + OUString::number( it.mnGroup) + "]");
fprintf( stderr, "%s -> ", aStr.toUtf8().getStr());
}
fprintf( stderr, "%s", "END\n");
@@ -148,6 +152,16 @@ static struct DebugCalculation
mvPos.back().maResult = "Err:" + OUString::number( nErr);
}
+ void enterGroup()
+ {
+ ++mnGroup;
+ }
+
+ void leaveGroup()
+ {
+ --mnGroup;
+ }
+
} aDC;
struct DebugCalculationStacker
@@ -158,7 +172,7 @@ struct DebugCalculationStacker
aDC.mbActive = aDC.mbSwitchOff = true;
if (aDC.mbActive)
{
- aDC.mvPos.push_back( DebugCalculationEntry( rPos, pDoc));
+ aDC.mvPos.push_back( DebugCalculationEntry( rPos, pDoc, aDC.mnGroup));
aDC.mbPrint = true;
}
}
@@ -1537,7 +1551,14 @@ void ScFormulaCell::Interpret()
}
else
{
- if ( ! InterpretFormulaGroup() )
+#if DEBUG_CALCULATION
+ aDC.enterGroup();
+#endif
+ bool bGroupInterpreted = InterpretFormulaGroup();
+#if DEBUG_CALCULATION
+ aDC.leaveGroup();
+#endif
+ if (!bGroupInterpreted)
InterpretTail( SCITP_NORMAL);
}