summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sc/source/core/inc/interpre.hxx2
-rw-r--r--sc/source/core/tool/interpr1.cxx68
2 files changed, 29 insertions, 41 deletions
diff --git a/sc/source/core/inc/interpre.hxx b/sc/source/core/inc/interpre.hxx
index 9948392ea622..314be921d69c 100644
--- a/sc/source/core/inc/interpre.hxx
+++ b/sc/source/core/inc/interpre.hxx
@@ -574,7 +574,7 @@ size_t GetRefListArrayMaxSize( short nParamCount );
/** Switch to array reference list if current TOS is one and create/init or
update matrix and return true. Else return false. */
bool SwitchToArrayRefList( ScMatrixRef& xResMat, SCSIZE nMatRows, double fCurrent,
- const std::function<bool( double& fVectorResult, const double& fCurrent )>& AssignFunc );
+ const std::function<void( SCSIZE i, double fCurrent )>& MatOpFunc );
void IterateParameters( ScIterFunc, bool bTextAsZero = false );
void ScSumSQ();
void ScSum();
diff --git a/sc/source/core/tool/interpr1.cxx b/sc/source/core/tool/interpr1.cxx
index 675e9c8165bf..f455cb43dccf 100644
--- a/sc/source/core/tool/interpr1.cxx
+++ b/sc/source/core/tool/interpr1.cxx
@@ -3457,7 +3457,7 @@ void ScInterpreter::ScUnichar()
}
bool ScInterpreter::SwitchToArrayRefList( ScMatrixRef& xResMat, SCSIZE nMatRows, double fCurrent,
- const std::function<bool( double& fVectorResult, const double& fCurrent )>& AssignFunc )
+ const std::function<void( SCSIZE i, double fCurrent )>& MatOpFunc )
{
const ScRefListToken* p = dynamic_cast<const ScRefListToken*>(pStack[sp-1]);
if (!p || !p->IsArrayResult())
@@ -3476,9 +3476,7 @@ bool ScInterpreter::SwitchToArrayRefList( ScMatrixRef& xResMat, SCSIZE nMatRows,
// for each vector position.
for (SCSIZE i=0; i < nMatRows; ++i)
{
- double fVecRes = xResMat->GetDouble(0,i);
- if (AssignFunc( fVecRes, fCurrent))
- xResMat->PutDouble( fVecRes, 0,i);
+ MatOpFunc( i, fCurrent);
}
}
return true;
@@ -3489,10 +3487,18 @@ void ScInterpreter::ScMin( bool bTextAsZero )
short nParamCount = GetByte();
if (!MustHaveParamCountMin( nParamCount, 1))
return;
- const SCSIZE nMatRows = GetRefListArrayMaxSize( nParamCount);
+
ScMatrixRef xResMat;
- size_t nRefArrayPos = std::numeric_limits<size_t>::max();
double nMin = ::std::numeric_limits<double>::max();
+ auto MatOpFunc = [&xResMat]( SCSIZE i, double fCurMin )
+ {
+ double fVecRes = xResMat->GetDouble(0,i);
+ if (fVecRes > fCurMin)
+ xResMat->PutDouble( fCurMin, 0,i);
+ };
+ const SCSIZE nMatRows = GetRefListArrayMaxSize( nParamCount);
+ size_t nRefArrayPos = std::numeric_limits<size_t>::max();
+
double nVal = 0.0;
ScAddress aAdr;
ScRange aRange;
@@ -3527,16 +3533,7 @@ void ScInterpreter::ScMin( bool bTextAsZero )
break;
case svRefList :
{
- auto AssignFunc = []( double& fVecRes, double fMin )
- {
- if (fVecRes > fMin)
- {
- fVecRes = fMin;
- return true;
- }
- return false;
- };
- if (SwitchToArrayRefList( xResMat, nMatRows, nMin, AssignFunc))
+ if (SwitchToArrayRefList( xResMat, nMatRows, nMin, MatOpFunc))
nRefArrayPos = nRefInList;
}
SAL_FALLTHROUGH;
@@ -3560,9 +3557,7 @@ void ScInterpreter::ScMin( bool bTextAsZero )
if (nRefArrayPos != std::numeric_limits<size_t>::max())
{
// Update vector element with current value.
- double fVecRes = xResMat->GetDouble(0,nRefArrayPos);
- if (fVecRes > nMin)
- xResMat->PutDouble( nMin, 0,nRefArrayPos);
+ MatOpFunc( nRefArrayPos, nMin);
// Reset.
nMin = std::numeric_limits<double>::max();
@@ -3610,9 +3605,7 @@ void ScInterpreter::ScMin( bool bTextAsZero )
{
for (SCSIZE i=0; i < nMatRows; ++i)
{
- double fVecRes = xResMat->GetDouble(0,i);
- if (fVecRes > nMin)
- xResMat->PutDouble( nMin, 0,i);
+ MatOpFunc( i, nMin);
}
}
else
@@ -3644,10 +3637,18 @@ void ScInterpreter::ScMax( bool bTextAsZero )
short nParamCount = GetByte();
if (!MustHaveParamCountMin( nParamCount, 1))
return;
- const SCSIZE nMatRows = GetRefListArrayMaxSize( nParamCount);
+
ScMatrixRef xResMat;
- size_t nRefArrayPos = std::numeric_limits<size_t>::max();
double nMax = std::numeric_limits<double>::lowest();
+ auto MatOpFunc = [&xResMat]( SCSIZE i, double fCurMax )
+ {
+ double fVecRes = xResMat->GetDouble(0,i);
+ if (fVecRes < fCurMax)
+ xResMat->PutDouble( fCurMax, 0,i);
+ };
+ const SCSIZE nMatRows = GetRefListArrayMaxSize( nParamCount);
+ size_t nRefArrayPos = std::numeric_limits<size_t>::max();
+
double nVal = 0.0;
ScAddress aAdr;
ScRange aRange;
@@ -3682,16 +3683,7 @@ void ScInterpreter::ScMax( bool bTextAsZero )
break;
case svRefList :
{
- auto AssignFunc = []( double& fVecRes, double fMax )
- {
- if (fVecRes < fMax)
- {
- fVecRes = fMax;
- return true;
- }
- return false;
- };
- if (SwitchToArrayRefList( xResMat, nMatRows, nMax, AssignFunc))
+ if (SwitchToArrayRefList( xResMat, nMatRows, nMax, MatOpFunc))
nRefArrayPos = nRefInList;
}
SAL_FALLTHROUGH;
@@ -3715,9 +3707,7 @@ void ScInterpreter::ScMax( bool bTextAsZero )
if (nRefArrayPos != std::numeric_limits<size_t>::max())
{
// Update vector element with current value.
- double fVecRes = xResMat->GetDouble(0,nRefArrayPos);
- if (fVecRes < nMax)
- xResMat->PutDouble( nMax, 0,nRefArrayPos);
+ MatOpFunc( nRefArrayPos, nMax);
// Reset.
nMax = std::numeric_limits<double>::lowest();
@@ -3765,9 +3755,7 @@ void ScInterpreter::ScMax( bool bTextAsZero )
{
for (SCSIZE i=0; i < nMatRows; ++i)
{
- double fVecRes = xResMat->GetDouble(0,i);
- if (fVecRes < nMax)
- xResMat->PutDouble( nMax, 0,i);
+ MatOpFunc( i, nMax);
}
}
else