summaryrefslogtreecommitdiff
path: root/sc
diff options
context:
space:
mode:
authorNoel Grandin <noel@peralex.com>2016-09-14 15:22:20 +0200
committerEike Rathke <erack@redhat.com>2016-09-23 15:22:38 +0000
commit3e22dfa5eb1ccebdc719a671d23bde7ccab256fb (patch)
treec3890b2a33cc298ad786c50a9d5879531fc6afc4 /sc
parent7d8196ea2f4ec3634dbad7367345e62c4ea9893d (diff)
convert formula error codes to scoped enum
Change-Id: I5ff214bf1ec9031e30344bc125bc99916fd11bfb Reviewed-on: https://gerrit.libreoffice.org/28897 Reviewed-by: Eike Rathke <erack@redhat.com> Tested-by: Eike Rathke <erack@redhat.com>
Diffstat (limited to 'sc')
-rw-r--r--sc/inc/addincol.hxx4
-rw-r--r--sc/inc/column.hxx6
-rw-r--r--sc/inc/compiler.hxx6
-rw-r--r--sc/inc/dociter.hxx12
-rw-r--r--sc/inc/document.hxx9
-rw-r--r--sc/inc/formulacell.hxx12
-rw-r--r--sc/inc/formularesult.hxx14
-rw-r--r--sc/inc/global.hxx11
-rw-r--r--sc/inc/math.hxx2
-rw-r--r--sc/inc/rangenam.hxx2
-rw-r--r--sc/inc/scmatrix.hxx19
-rw-r--r--sc/inc/simpleformulacalc.hxx2
-rw-r--r--sc/inc/table.hxx9
-rw-r--r--sc/qa/unit/helper/qahelper.cxx4
-rw-r--r--sc/qa/unit/helper/shared_test_impl.hxx5
-rw-r--r--sc/qa/unit/subsequent_filters-test.cxx6
-rw-r--r--sc/qa/unit/ucalc.cxx10
-rw-r--r--sc/qa/unit/ucalc_formula.cxx48
-rw-r--r--sc/qa/unit/ucalc_pivottable.cxx6
-rw-r--r--sc/source/core/data/clipcontext.cxx5
-rw-r--r--sc/source/core/data/column.cxx23
-rw-r--r--sc/source/core/data/column2.cxx24
-rw-r--r--sc/source/core/data/column3.cxx18
-rw-r--r--sc/source/core/data/conditio.cxx3
-rw-r--r--sc/source/core/data/dbdocutl.cxx2
-rw-r--r--sc/source/core/data/dociter.cxx32
-rw-r--r--sc/source/core/data/documen2.cxx2
-rw-r--r--sc/source/core/data/documen4.cxx10
-rw-r--r--sc/source/core/data/document.cxx12
-rw-r--r--sc/source/core/data/dpcache.cxx3
-rw-r--r--sc/source/core/data/dpoutput.cxx2
-rw-r--r--sc/source/core/data/formulacell.cxx117
-rw-r--r--sc/source/core/data/global.cxx113
-rw-r--r--sc/source/core/data/global2.cxx12
-rw-r--r--sc/source/core/data/simpleformulacalc.cxx16
-rw-r--r--sc/source/core/data/table2.cxx2
-rw-r--r--sc/source/core/data/table3.cxx6
-rw-r--r--sc/source/core/data/table4.cxx10
-rw-r--r--sc/source/core/data/validat.cxx8
-rw-r--r--sc/source/core/inc/doubleref.hxx7
-rw-r--r--sc/source/core/inc/interpre.hxx38
-rw-r--r--sc/source/core/opencl/formulagroupcl.cxx16
-rw-r--r--sc/source/core/opencl/op_statistical.cxx12
-rw-r--r--sc/source/core/tool/addincol.cxx26
-rw-r--r--sc/source/core/tool/cellform.cxx8
-rw-r--r--sc/source/core/tool/chartarr.cxx3
-rw-r--r--sc/source/core/tool/compiler.cxx134
-rw-r--r--sc/source/core/tool/consoli.cxx2
-rw-r--r--sc/source/core/tool/detfunc.cxx7
-rw-r--r--sc/source/core/tool/doubleref.cxx8
-rw-r--r--sc/source/core/tool/formularesult.cxx36
-rw-r--r--sc/source/core/tool/interpr1.cxx606
-rw-r--r--sc/source/core/tool/interpr2.cxx156
-rw-r--r--sc/source/core/tool/interpr3.cxx196
-rw-r--r--sc/source/core/tool/interpr4.cxx386
-rw-r--r--sc/source/core/tool/interpr5.cxx156
-rw-r--r--sc/source/core/tool/interpr6.cxx94
-rw-r--r--sc/source/core/tool/interpr7.cxx28
-rw-r--r--sc/source/core/tool/interpr8.cxx80
-rw-r--r--sc/source/core/tool/jumpmatrix.cxx6
-rw-r--r--sc/source/core/tool/rangenam.cxx12
-rw-r--r--sc/source/core/tool/rangeseq.cxx8
-rw-r--r--sc/source/core/tool/scmatrix.cxx92
-rw-r--r--sc/source/core/tool/token.cxx22
-rw-r--r--sc/source/filter/dif/difexp.cxx3
-rw-r--r--sc/source/filter/excel/excform.cxx38
-rw-r--r--sc/source/filter/excel/xeformula.cxx7
-rw-r--r--sc/source/filter/excel/xehelper.cxx3
-rw-r--r--sc/source/filter/excel/xelink.cxx2
-rw-r--r--sc/source/filter/excel/xestream.cxx2
-rw-r--r--sc/source/filter/excel/xetable.cxx5
-rw-r--r--sc/source/filter/excel/xihelper.cxx4
-rw-r--r--sc/source/filter/excel/xltools.cxx55
-rw-r--r--sc/source/filter/inc/scflt.hxx6
-rw-r--r--sc/source/filter/inc/xihelper.hxx2
-rw-r--r--sc/source/filter/inc/xltools.hxx5
-rw-r--r--sc/source/filter/oox/defnamesbuffer.cxx2
-rw-r--r--sc/source/filter/starcalc/scflt.cxx3
-rw-r--r--sc/source/filter/xml/xmlexprt.cxx3
-rw-r--r--sc/source/filter/xml/xmlimprt.cxx3
-rw-r--r--sc/source/ui/app/inputhdl.cxx5
-rw-r--r--sc/source/ui/app/scmod.cxx2
-rw-r--r--sc/source/ui/app/transobj.cxx5
-rw-r--r--sc/source/ui/condformat/condformatdlgentry.cxx3
-rw-r--r--sc/source/ui/docshell/docsh.cxx5
-rw-r--r--sc/source/ui/docshell/externalrefmgr.cxx30
-rw-r--r--sc/source/ui/formdlg/formula.cxx5
-rw-r--r--sc/source/ui/inc/tabvwsh.hxx3
-rw-r--r--sc/source/ui/namedlg/namedefdlg.cxx6
-rw-r--r--sc/source/ui/namedlg/namedlg.cxx4
-rw-r--r--sc/source/ui/unoobj/cellsuno.cxx8
-rw-r--r--sc/source/ui/unoobj/chart2uno.cxx4
-rw-r--r--sc/source/ui/unoobj/funcuno.cxx6
-rw-r--r--sc/source/ui/view/cellsh.cxx4
-rw-r--r--sc/source/ui/view/output2.cxx2
-rw-r--r--sc/source/ui/view/tabvwsha.cxx6
-rw-r--r--sc/source/ui/view/viewfunc.cxx12
97 files changed, 1509 insertions, 1490 deletions
diff --git a/sc/inc/addincol.hxx b/sc/inc/addincol.hxx
index 09d6fc524146..49d30b6a7b7a 100644
--- a/sc/inc/addincol.hxx
+++ b/sc/inc/addincol.hxx
@@ -187,7 +187,7 @@ private:
css::uno::Reference<css::uno::XInterface> xCaller;
bool bValidCount;
// result:
- sal_uInt16 nErrCode;
+ FormulaError nErrCode;
bool bHasString;
double fValue;
OUString aString;
@@ -214,7 +214,7 @@ public:
void SetResult( const css::uno::Any& rNewRes );
- sal_uInt16 GetErrCode() const { return nErrCode; }
+ FormulaError GetErrCode() const { return nErrCode; }
bool HasString() const { return bHasString; }
bool HasMatrix() const { return xMatrix.get(); }
bool HasVarRes() const { return ( xVarRes.is() ); }
diff --git a/sc/inc/column.hxx b/sc/inc/column.hxx
index 186e41565048..2041ce79f87c 100644
--- a/sc/inc/column.hxx
+++ b/sc/inc/column.hxx
@@ -360,7 +360,7 @@ public:
void SetValue( SCROW nRow, double fVal );
void SetValues( SCROW nRow, const std::vector<double>& rVals );
void SetValue( sc::ColumnBlockPosition& rBlockPos, SCROW nRow, double fVal, bool bBroadcast = true );
- void SetError( SCROW nRow, const sal_uInt16 nError);
+ void SetError( SCROW nRow, const FormulaError nError);
void GetString( SCROW nRow, OUString& rString ) const;
double* GetValueCell( SCROW nRow );
@@ -376,7 +376,7 @@ public:
SCSIZE GetCellCount() const;
sal_uInt32 GetWeightedCount() const;
sal_uInt32 GetCodeCount() const; // RPN-Code in formulas
- sal_uInt16 GetErrCode( SCROW nRow ) const;
+ FormulaError GetErrCode( SCROW nRow ) const;
bool HasStringData( SCROW nRow ) const;
bool HasValueData( SCROW nRow ) const;
@@ -403,7 +403,7 @@ public:
position broadcasted. */
bool BroadcastBroadcasters( SCROW nRow1, SCROW nRow2, ScHint& rHint );
- bool CompileErrorCells( sc::CompileFormulaContext& rCxt, sal_uInt16 nErrCode );
+ bool CompileErrorCells( sc::CompileFormulaContext& rCxt, FormulaError nErrCode );
void ResetChanged( SCROW nStartRow, SCROW nEndRow );
diff --git a/sc/inc/compiler.hxx b/sc/inc/compiler.hxx
index 26be57dee30f..8c6485627cd1 100644
--- a/sc/inc/compiler.hxx
+++ b/sc/inc/compiler.hxx
@@ -130,7 +130,7 @@ public:
rtl_uString* mpDataIgnoreCase;
} sharedstring;
ScMatrix* pMat;
- sal_uInt16 nError;
+ FormulaError nError;
sal_Unicode cStr[ MAXSTRLEN+1 ]; // string (up to 255 characters + 0)
short nJump[ FORMULA_MAXJUMPCOUNT + 1 ]; // If/Chose token
};
@@ -152,7 +152,7 @@ public:
void SetSingleReference( const ScSingleRefData& rRef );
void SetDoubleReference( const ScComplexRefData& rRef );
void SetDouble( double fVal );
- void SetErrorConstant( sal_uInt16 nErr );
+ void SetErrorConstant( FormulaError nErr );
// These methods are ok to use, reference count not cleared.
void SetName(sal_Int16 nSheet, sal_uInt16 nIndex);
@@ -304,7 +304,7 @@ private:
bool NextNewToken(bool bInArray);
- virtual void SetError(sal_uInt16 nError) override;
+ virtual void SetError(FormulaError nError) override;
sal_Int32 NextSymbol(bool bInArray);
bool IsValue( const OUString& );
bool IsOpCode( const OUString&, bool bInArray );
diff --git a/sc/inc/dociter.hxx b/sc/inc/dociter.hxx
index 088ca7f37fc3..21f5ffcdac3e 100644
--- a/sc/inc/dociter.hxx
+++ b/sc/inc/dociter.hxx
@@ -77,7 +77,7 @@ class ScValueIterator // walk through all values in an area
* See if the cell at the current position is a non-empty cell. If not,
* move to the next non-empty cell position.
*/
- bool GetThis( double& rValue, sal_uInt16& rErr );
+ bool GetThis( double& rValue, FormulaError& rErr );
public:
@@ -88,10 +88,10 @@ public:
void GetCurNumFmtInfo( short& nType, sal_uLong& nIndex );
/// Does NOT reset rValue if no value found!
- bool GetFirst( double& rValue, sal_uInt16& rErr );
+ bool GetFirst( double& rValue, FormulaError& rErr );
/// Does NOT reset rValue if no value found!
- bool GetNext( double& rValue, sal_uInt16& rErr );
+ bool GetNext( double& rValue, FormulaError& rErr );
};
class ScDBQueryDataIterator
@@ -99,9 +99,9 @@ class ScDBQueryDataIterator
public:
struct Value
{
- OUString maString;
+ OUString maString;
double mfValue;
- sal_uInt16 mnError;
+ FormulaError mnError;
bool mbIsNumber;
Value();
@@ -466,7 +466,7 @@ public:
const ScRange& rRange );
~ScHorizontalValueIterator();
/// Does NOT reset rValue if no value found!
- bool GetNext( double& rValue, sal_uInt16& rErr );
+ bool GetNext( double& rValue, FormulaError& rErr );
};
// returns all areas with non-default formatting (horizontal)
diff --git a/sc/inc/document.hxx b/sc/inc/document.hxx
index 289d6df8a8f0..979257ec71ac 100644
--- a/sc/inc/document.hxx
+++ b/sc/inc/document.hxx
@@ -49,6 +49,7 @@
enum class SvtScriptType;
enum class ScMF;
+enum class FormulaError : sal_uInt16;
namespace editeng { class SvxBorderLine; }
namespace formula { struct VectorRefArray; }
namespace svl {
@@ -1000,7 +1001,7 @@ public:
void SetValues( const ScAddress& rPos, const std::vector<double>& rVals );
- void SetError( SCCOL nCol, SCROW nRow, SCTAB nTab, const sal_uInt16 nError);
+ void SetError( SCCOL nCol, SCROW nRow, SCTAB nTab, const FormulaError nError);
SC_DLLPUBLIC void SetFormula(
const ScAddress& rPos, const ScTokenArray& rArray );
@@ -1057,7 +1058,7 @@ public:
std::shared_ptr<sc::FormulaGroupContext>& GetFormulaGroupContext();
SC_DLLPUBLIC void GetInputString( SCCOL nCol, SCROW nRow, SCTAB nTab, OUString& rString );
- sal_uInt16 GetStringForFormula( const ScAddress& rPos, OUString& rString );
+ FormulaError GetStringForFormula( const ScAddress& rPos, OUString& rString );
SC_DLLPUBLIC double GetValue( const ScAddress& rPos ) const;
SC_DLLPUBLIC double GetValue( SCCOL nCol, SCROW nRow, SCTAB nTab ) const;
SC_DLLPUBLIC void GetValue( SCCOL nCol, SCROW nRow, SCTAB nTab, double& rValue ) const;
@@ -1188,7 +1189,7 @@ public:
* @return true if at least one cell is re-compiled, false if no cells are
* re-compiled.
*/
- bool CompileErrorCells(sal_uInt16 nErrCode);
+ bool CompileErrorCells(FormulaError nErrCode);
ScAutoNameCache* GetAutoNameCache() { return pAutoNameCache; }
void SetPreviewFont( SfxItemSet* pFontSet );
@@ -1225,7 +1226,7 @@ public:
// if CalcFormulaTree() is currently running
bool IsCalculatingFormulaTree() { return bCalculatingFormulaTree; }
- sal_uInt16 GetErrCode( const ScAddress& ) const;
+ FormulaError GetErrCode( const ScAddress& ) const;
/** Shrink a range to only include data area.
diff --git a/sc/inc/formulacell.hxx b/sc/inc/formulacell.hxx
index cec4b2d64db3..d30facaf4ce0 100644
--- a/sc/inc/formulacell.hxx
+++ b/sc/inc/formulacell.hxx
@@ -296,13 +296,13 @@ public:
bool GetMatrixOrigin( ScAddress& rPos ) const;
void GetResultDimensions( SCSIZE& rCols, SCSIZE& rRows );
sc::MatrixEdge GetMatrixEdge( ScAddress& rOrgPos ) const;
- sal_uInt16 GetErrCode(); // interpret first if necessary
- sal_uInt16 GetRawError(); // don't interpret, just return code or result error
- bool GetErrorOrValue( sal_uInt16& rErr, double& rVal );
+ FormulaError GetErrCode(); // interpret first if necessary
+ FormulaError GetRawError(); // don't interpret, just return code or result error
+ bool GetErrorOrValue( FormulaError& rErr, double& rVal );
sc::FormulaResultValue GetResult();
sc::FormulaResultValue GetResult() const;
sal_uInt8 GetMatrixFlag() const { return cMatrixFlag;}
- ScTokenArray* GetCode() { return pCode;}
+ ScTokenArray* GetCode() { return pCode;}
const ScTokenArray* GetCode() const { return pCode;}
void SetCode( ScTokenArray* pNew );
@@ -364,10 +364,10 @@ public:
svl::SharedString GetResultString() const;
/* Sets the shared code array to error state in addition to the cell result */
- void SetErrCode( sal_uInt16 n );
+ void SetErrCode( FormulaError n );
/* Sets just the result to error */
- void SetResultError( sal_uInt16 n );
+ void SetResultError( FormulaError n );
bool IsHyperLinkCell() const;
EditTextObject* CreateURLObject();
diff --git a/sc/inc/formularesult.hxx b/sc/inc/formularesult.hxx
index 68a08e52d797..0a977dcf043a 100644
--- a/sc/inc/formularesult.hxx
+++ b/sc/inc/formularesult.hxx
@@ -33,12 +33,12 @@ struct FormulaResultValue
double mfValue;
svl::SharedString maString;
- sal_uInt16 mnError;
+ FormulaError mnError;
FormulaResultValue();
FormulaResultValue( double fValue );
- FormulaResultValue(const svl::SharedString& rStr );
- FormulaResultValue( sal_uInt16 nErr );
+ FormulaResultValue( const svl::SharedString& rStr );
+ FormulaResultValue( FormulaError nErr );
};
}
@@ -71,7 +71,7 @@ class ScFormulaResult
double mfValue; // double result direct for performance and memory consumption
const formula::FormulaToken* mpToken; // if not, result token obtained from interpreter
};
- sal_uInt16 mnError; // error code
+ FormulaError mnError; // error code
bool mbToken :1; // whether content of union is a token
bool mbEmpty :1; // empty cell result
bool mbEmptyDisplayedAsString :1; // only if mbEmpty
@@ -154,15 +154,15 @@ public:
one paragraph */
bool IsMultiline() const;
- bool GetErrorOrDouble( sal_uInt16& rErr, double& rVal ) const;
+ bool GetErrorOrDouble( FormulaError& rErr, double& rVal ) const;
sc::FormulaResultValue GetResult() const;
/** Get error code if set or GetCellResultType() is formula::svError or svUnknown,
else 0. */
- sal_uInt16 GetResultError() const;
+ FormulaError GetResultError() const;
/** Set error code, don't touch token or double. */
- void SetResultError( sal_uInt16 nErr );
+ void SetResultError( FormulaError nErr );
/** Set direct double. Shouldn't be used externally except in
ScFormulaCell for rounded CalcAsShown or SetErrCode() or
diff --git a/sc/inc/global.hxx b/sc/inc/global.hxx
index 0e606f8563eb..63a716457c94 100644
--- a/sc/inc/global.hxx
+++ b/sc/inc/global.hxx
@@ -35,6 +35,7 @@ class SfxItemSet;
class Color;
struct ScCalcConfig;
enum class SvtScriptType;
+enum class FormulaError : sal_uInt16;
#define SC_COLLATOR_IGNORES ( \
css::i18n::CollatorOptions::CollatorOptions_IGNORE_CASE )
@@ -571,8 +572,8 @@ public:
static ScFunctionMgr* GetStarCalcFunctionMgr();
static void ResetFunctionList();
- static OUString GetErrorString(sal_uInt16 nErrNumber);
- static OUString GetLongErrorString(sal_uInt16 nErrNumber);
+ static OUString GetErrorString(FormulaError nErrNumber);
+ static OUString GetLongErrorString(FormulaError nErrNumber);
static bool EETextObjEqual( const EditTextObject* pObj1,
const EditTextObject* pObj2 );
static bool CheckWidthInvalidate( bool& bNumFormatChanged,
@@ -676,11 +677,11 @@ SC_DLLPUBLIC static const sal_Unicode* FindUnquoted( const sal_Unicode* pStri
In any case, if rError is set 0.0 is returned.
- If nStringNoValueError is errCellNoValue, that is unconditionally
+ If nStringNoValueError is FormulaError::CellNoValue, that is unconditionally
assigned to rError and 0.0 is returned. The caller is expected to
handle this situation. Used by the interpreter.
- Usually errNoValue is passed as nStringNoValueError.
+ Usually FormulaError::NoValue is passed as nStringNoValueError.
Otherwise, depending on the string conversion configuration different
approaches are taken:
@@ -778,7 +779,7 @@ SC_DLLPUBLIC static const sal_Unicode* FindUnquoted( const sal_Unicode* pStri
*/
static double ConvertStringToValue( const OUString& rStr, const ScCalcConfig& rConfig,
- sal_uInt16 & rError, sal_uInt16 nStringNoValueError,
+ FormulaError & rError, FormulaError nStringNoValueError,
SvNumberFormatter* pFormatter, short & rCurFmtType );
};
diff --git a/sc/inc/math.hxx b/sc/inc/math.hxx
index ecea704052a4..c2a3b992dd00 100644
--- a/sc/inc/math.hxx
+++ b/sc/inc/math.hxx
@@ -30,7 +30,7 @@ namespace sc {
inline double div( const double& fNumerator, const double& fDenominator )
{
return (fDenominator != 0.0) ? (fNumerator / fDenominator) :
- formula::CreateDoubleError( formula::errDivisionByZero);
+ CreateDoubleError( FormulaError::DivisionByZero);
}
/** Return fNumerator/fDenominator if fDenominator!=0 else +-Infinity if
diff --git a/sc/inc/rangenam.hxx b/sc/inc/rangenam.hxx
index e5a6dfea8a21..a1924de86a26 100644
--- a/sc/inc/rangenam.hxx
+++ b/sc/inc/rangenam.hxx
@@ -119,7 +119,7 @@ public:
ScTokenArray* GetCode() { return pCode; }
SC_DLLPUBLIC void SetCode( ScTokenArray& );
const ScTokenArray* GetCode() const { return pCode; }
- SC_DLLPUBLIC sal_uInt16 GetErrCode() const;
+ SC_DLLPUBLIC FormulaError GetErrCode() const;
bool HasReferences() const;
void AddType( Type nType );
Type GetType() const { return eType; }
diff --git a/sc/inc/scmatrix.hxx b/sc/inc/scmatrix.hxx
index b4899681b70b..d26961d155fd 100644
--- a/sc/inc/scmatrix.hxx
+++ b/sc/inc/scmatrix.hxx
@@ -40,6 +40,7 @@
class ScInterpreter;
class SvNumberFormatter;
class ScMatrixImpl;
+enum class FormulaError : sal_uInt16;
namespace formula { class DoubleVectorRefToken; }
@@ -64,7 +65,7 @@ struct ScMatrixValue
const svl::SharedString& GetString() const { return aStr; }
/// Only valid if ScMatrix methods indicate that this is no string!
- sal_uInt16 GetError() const { return formula::GetDoubleErrorValue( fVal); }
+ FormulaError GetError() const { return GetDoubleErrorValue(fVal); }
/// Only valid if ScMatrix methods indicate that this is a boolean
bool GetBoolean() const { return fVal != 0.0; }
@@ -274,7 +275,7 @@ public:
/// Jump sal_False without path
virtual void PutEmptyPath( SCSIZE nC, SCSIZE nR) = 0;
- virtual void PutError( sal_uInt16 nErrorCode, SCSIZE nC, SCSIZE nR ) = 0;
+ virtual void PutError( FormulaError nErrorCode, SCSIZE nC, SCSIZE nR ) = 0;
virtual void PutBoolean( bool bVal, SCSIZE nC, SCSIZE nR) = 0;
virtual void FillDouble( double fVal,
@@ -300,12 +301,12 @@ public:
@ATTENTION: MUST NOT be used if the element is a string!
Use GetErrorIfNotString() instead if not sure.
@returns 0 if no error, else one of err... constants */
- virtual sal_uInt16 GetError( SCSIZE nC, SCSIZE nR) const = 0;
+ virtual FormulaError GetError( SCSIZE nC, SCSIZE nR) const = 0;
/** Use in ScInterpreter to obtain the error code, if any.
@returns 0 if no error or string element, else one of err... constants */
- sal_uInt16 GetErrorIfNotString( SCSIZE nC, SCSIZE nR) const
- { return IsValue( nC, nR) ? GetError( nC, nR) : 0; }
+ FormulaError GetErrorIfNotString( SCSIZE nC, SCSIZE nR) const
+ { return IsValue( nC, nR) ? GetError( nC, nR) : FormulaError::NONE; }
/// @return 0.0 if empty or empty path, else value or DoubleError.
virtual double GetDouble( SCSIZE nC, SCSIZE nR) const = 0;
@@ -493,7 +494,7 @@ public:
/// Jump sal_False without path
virtual void PutEmptyPath( SCSIZE nC, SCSIZE nR) override;
- virtual void PutError( sal_uInt16 nErrorCode, SCSIZE nC, SCSIZE nR ) override;
+ virtual void PutError( FormulaError nErrorCode, SCSIZE nC, SCSIZE nR ) override;
virtual void PutBoolean( bool bVal, SCSIZE nC, SCSIZE nR) override;
virtual void FillDouble( double fVal,
@@ -519,7 +520,7 @@ public:
@ATTENTION: MUST NOT be used if the element is a string!
Use GetErrorIfNotString() instead if not sure.
@returns 0 if no error, else one of err... constants */
- virtual sal_uInt16 GetError( SCSIZE nC, SCSIZE nR) const override;
+ virtual FormulaError GetError( SCSIZE nC, SCSIZE nR) const override;
/// @return 0.0 if empty or empty path, else value or DoubleError.
virtual double GetDouble( SCSIZE nC, SCSIZE nR) const override;
@@ -711,7 +712,7 @@ public:
/// Jump sal_False without path
virtual void PutEmptyPath(SCSIZE nC, SCSIZE nR) override;
- virtual void PutError(sal_uInt16 nErrorCode, SCSIZE nC, SCSIZE nR ) override;
+ virtual void PutError(FormulaError nErrorCode, SCSIZE nC, SCSIZE nR ) override;
virtual void PutBoolean(bool bVal, SCSIZE nC, SCSIZE nR) override;
virtual void FillDouble(double fVal, SCSIZE nC1, SCSIZE nR1, SCSIZE nC2, SCSIZE nR2) override;
@@ -736,7 +737,7 @@ public:
@ATTENTION: MUST NOT be used if the element is a string!
Use GetErrorIfNotString() instead if not sure.
@returns 0 if no error, else one of err... constants */
- virtual sal_uInt16 GetError(SCSIZE nC, SCSIZE nR) const override;
+ virtual FormulaError GetError(SCSIZE nC, SCSIZE nR) const override;
/// @return 0.0 if empty or empty path, else value or DoubleError.
virtual double GetDouble(SCSIZE nC, SCSIZE nR) const override;
diff --git a/sc/inc/simpleformulacalc.hxx b/sc/inc/simpleformulacalc.hxx
index fef4fe9400a7..64229aff77ce 100644
--- a/sc/inc/simpleformulacalc.hxx
+++ b/sc/inc/simpleformulacalc.hxx
@@ -45,7 +45,7 @@ public:
void Calculate();
bool IsValue();
bool IsMatrix();
- sal_uInt16 GetErrCode();
+ FormulaError GetErrCode();
double GetValue();
svl::SharedString GetString();
short GetFormatType() const { return mnFormatType; }
diff --git a/sc/inc/table.hxx b/sc/inc/table.hxx
index 8e35256f48c0..d987071274a5 100644
--- a/sc/inc/table.hxx
+++ b/sc/inc/table.hxx
@@ -34,6 +34,7 @@
#include "cellvalue.hxx"
#include <formula/types.hxx>
#include "calcmacros.hxx"
+#include "formula/errorcodes.hxx"
#include <set>
#include <map>
@@ -362,7 +363,7 @@ public:
void SetValue( SCCOL nCol, SCROW nRow, const double& rVal );
void SetValues( SCCOL nCol, SCROW nRow, const std::vector<double>& rVals );
- void SetError( SCCOL nCol, SCROW nRow, sal_uInt16 nError);
+ void SetError( SCCOL nCol, SCROW nRow, FormulaError nError);
SCSIZE GetPatternCount( SCCOL nCol ) const;
SCSIZE GetPatternCount( SCCOL nCol, SCROW nRow1, SCROW nRow2 ) const;
bool ReservePatternCount( SCCOL nCol, SCSIZE nReserve );
@@ -522,11 +523,11 @@ public:
bool HasStringCells( SCCOL nStartCol, SCROW nStartRow,
SCCOL nEndCol, SCROW nEndRow ) const;
- sal_uInt16 GetErrCode( const ScAddress& rPos ) const
+ FormulaError GetErrCode( const ScAddress& rPos ) const
{
return ValidColRow(rPos.Col(),rPos.Row()) ?
aCol[rPos.Col()].GetErrCode( rPos.Row() ) :
- 0;
+ FormulaError::NONE;
}
void ResetChanged( const ScRange& rRange );
@@ -549,7 +550,7 @@ public:
position broadcasted. */
bool BroadcastBroadcasters( SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2, ScHint& rHint );
- bool CompileErrorCells( sc::CompileFormulaContext& rCxt, sal_uInt16 nErrCode );
+ bool CompileErrorCells( sc::CompileFormulaContext& rCxt, FormulaError nErrCode );
void UpdateReference(
sc::RefUpdateContext& rCxt, ScDocument* pUndoDoc = nullptr,
diff --git a/sc/qa/unit/helper/qahelper.cxx b/sc/qa/unit/helper/qahelper.cxx
index 7e74465a5cf1..7153c4b69c49 100644
--- a/sc/qa/unit/helper/qahelper.cxx
+++ b/sc/qa/unit/helper/qahelper.cxx
@@ -18,7 +18,7 @@
#include <svx/svdoole2.hxx>
#include <editeng/brushitem.hxx>
#include <editeng/justifyitem.hxx>
-
+#include <formula/errorcodes.hxx>
#include <cppunit/Asserter.h>
#include <cppunit/AdditionalMessage.h>
@@ -522,7 +522,7 @@ bool isFormulaWithoutError(ScDocument& rDoc, const ScAddress& rPos)
if (!pFC)
return false;
- return pFC->GetErrCode() == 0;
+ return pFC->GetErrCode() == FormulaError::NONE;
}
OUString toString(
diff --git a/sc/qa/unit/helper/shared_test_impl.hxx b/sc/qa/unit/helper/shared_test_impl.hxx
index 0c274816c20c..7a27d31a5927 100644
--- a/sc/qa/unit/helper/shared_test_impl.hxx
+++ b/sc/qa/unit/helper/shared_test_impl.hxx
@@ -14,6 +14,7 @@
#include "conditio.hxx"
#include "document.hxx"
#include "formulacell.hxx"
+#include <formula/errorcodes.hxx>
struct FindCondFormatByEnclosingRange
{
@@ -259,8 +260,8 @@ void testFunctionsExcel2010_Impl( ScDocument& rDoc )
OString::number( rDoc.GetValue( ScAddress( 2, nRow, 0)) );
ScFormulaCell* pFC = rDoc.GetFormulaCell( ScAddress( 1, nRow, 0) );
- if ( pFC && pFC->GetErrCode() != 0 )
- aStr += ", error code =" + OString::number( pFC->GetErrCode() );
+ if ( pFC && pFC->GetErrCode() != FormulaError::NONE )
+ aStr += ", error code =" + OString::number( (int)pFC->GetErrCode() );
CPPUNIT_ASSERT_MESSAGE( OString( "Expected a formula cell without error at row " +
aStr ).getStr(), isFormulaWithoutError( rDoc, ScAddress( 1, nRow, 0)));
diff --git a/sc/qa/unit/subsequent_filters-test.cxx b/sc/qa/unit/subsequent_filters-test.cxx
index 9adc1a055d67..4b53e2d4a3ff 100644
--- a/sc/qa/unit/subsequent_filters-test.cxx
+++ b/sc/qa/unit/subsequent_filters-test.cxx
@@ -3364,8 +3364,8 @@ void ScFiltersTest::testVBAUserFunctionXLSM()
CPPUNIT_ASSERT_EQUAL(OUString("=MYFUNC()"), aFormula);
// Check the formula state after the load.
- sal_uInt16 nErrCode = pFC->GetErrCode();
- CPPUNIT_ASSERT_EQUAL(static_cast<sal_uInt16>(0), nErrCode);
+ FormulaError nErrCode = pFC->GetErrCode();
+ CPPUNIT_ASSERT_EQUAL(0, (int)nErrCode);
// Check the result.
CPPUNIT_ASSERT_EQUAL(42.0, rDoc.GetValue(ScAddress(0,0,0)));
@@ -3409,7 +3409,7 @@ void ScFiltersTest::testErrorOnExternalReferences()
ScFormulaCell* pFC = rDoc.GetFormulaCell(ScAddress(0,0,0));
CPPUNIT_ASSERT(pFC);
- CPPUNIT_ASSERT_EQUAL(formula::errNoName, pFC->GetErrCode());
+ CPPUNIT_ASSERT_EQUAL((int)FormulaError::NoName, (int)pFC->GetErrCode());
if (!checkFormula(rDoc, ScAddress(0,0,0), "'file:///Path/To/FileA.ods'#$Sheet1.A1A"))
CPPUNIT_FAIL("Formula changed");
diff --git a/sc/qa/unit/ucalc.cxx b/sc/qa/unit/ucalc.cxx
index 7e8654f3ea0e..0db6a1c270be 100644
--- a/sc/qa/unit/ucalc.cxx
+++ b/sc/qa/unit/ucalc.cxx
@@ -900,12 +900,12 @@ void Test::testValueIterator()
bool bHas = false;
size_t nCheckPos = 0;
double fVal;
- sal_uInt16 nErr;
+ FormulaError nErr;
for (bHas = aIter.GetFirst(fVal, nErr); bHas; bHas = aIter.GetNext(fVal, nErr), ++nCheckPos)
{
CPPUNIT_ASSERT_MESSAGE("Iteration longer than expected.", nCheckPos < nCheckLen);
CPPUNIT_ASSERT_EQUAL(aChecks[nCheckPos], fVal);
- CPPUNIT_ASSERT_EQUAL(static_cast<sal_uInt16>(0), nErr);
+ CPPUNIT_ASSERT_EQUAL(0, (int)nErr);
}
}
@@ -5776,8 +5776,8 @@ void Test::testFormulaWizardSubformula()
m_pDoc->SetString(ScAddress(1,2,0), "=gibberish"); // B3
ScSimpleFormulaCalculator aFCell1( m_pDoc, ScAddress(0,0,0), "=B1:B3", true );
- sal_uInt16 nErrCode = aFCell1.GetErrCode();
- CPPUNIT_ASSERT( nErrCode == 0 || aFCell1.IsMatrix() );
+ FormulaError nErrCode = aFCell1.GetErrCode();
+ CPPUNIT_ASSERT( nErrCode == FormulaError::NONE || aFCell1.IsMatrix() );
CPPUNIT_ASSERT_EQUAL( OUString("{1;#DIV/0!;#NAME?}"), aFCell1.GetString().getString() );
m_pDoc->SetString(ScAddress(1,0,0), "=NA()"); // B1
@@ -5785,7 +5785,7 @@ void Test::testFormulaWizardSubformula()
m_pDoc->SetString(ScAddress(1,2,0), "=1+2"); // B3
ScSimpleFormulaCalculator aFCell2( m_pDoc, ScAddress(0,0,0), "=B1:B3", true );
nErrCode = aFCell2.GetErrCode();
- CPPUNIT_ASSERT( nErrCode == 0 || aFCell2.IsMatrix() );
+ CPPUNIT_ASSERT( nErrCode == FormulaError::NONE || aFCell2.IsMatrix() );
CPPUNIT_ASSERT_EQUAL( OUString("{#N/A;2;3}"), aFCell2.GetString().getString() );
m_pDoc->DeleteTab(0);
diff --git a/sc/qa/unit/ucalc_formula.cxx b/sc/qa/unit/ucalc_formula.cxx
index 38f15fadcafd..c3436863c09a 100644
--- a/sc/qa/unit/ucalc_formula.cxx
+++ b/sc/qa/unit/ucalc_formula.cxx
@@ -1141,11 +1141,11 @@ void Test::testFormulaRefUpdate()
aPos = ScAddress(2,1,0);
ScFormulaCell* pFC = m_pDoc->GetFormulaCell(aPos);
CPPUNIT_ASSERT_MESSAGE("This should be a formula cell.", pFC);
- CPPUNIT_ASSERT_EQUAL(formula::errNoRef, pFC->GetErrCode());
+ CPPUNIT_ASSERT_EQUAL((int)FormulaError::NoRef, (int)pFC->GetErrCode());
aPos = ScAddress(2,2,0);
pFC = m_pDoc->GetFormulaCell(aPos);
CPPUNIT_ASSERT_MESSAGE("This should be a formula cell.", pFC);
- CPPUNIT_ASSERT_EQUAL(formula::errNoRef, pFC->GetErrCode());
+ CPPUNIT_ASSERT_EQUAL((int)FormulaError::NoRef, (int)pFC->GetErrCode());
// Clear all and start over.
clearRange(m_pDoc, ScRange(0,0,0,10,10,0));
@@ -1245,11 +1245,11 @@ void Test::testFormulaRefUpdate()
// Both A4 and A5 should show #REF! errors.
pFC = m_pDoc->GetFormulaCell(ScAddress(0,3,0));
CPPUNIT_ASSERT_MESSAGE("This should be a formula cell.", pFC);
- CPPUNIT_ASSERT_EQUAL(formula::errNoRef, pFC->GetErrCode());
+ CPPUNIT_ASSERT_EQUAL((int)FormulaError::NoRef, (int)pFC->GetErrCode());
pFC = m_pDoc->GetFormulaCell(ScAddress(0,4,0));
CPPUNIT_ASSERT_MESSAGE("This should be a formula cell.", pFC);
- CPPUNIT_ASSERT_EQUAL(formula::errNoRef, pFC->GetErrCode());
+ CPPUNIT_ASSERT_EQUAL((int)FormulaError::NoRef, (int)pFC->GetErrCode());
m_pDoc->DeleteTab(0);
}
@@ -1862,7 +1862,7 @@ void Test::testFormulaRefUpdateInsertRows()
rFunc.InsertCells(ScRange(0,1,0,MAXCOL,3,0), &aMark, INS_INSROWS_BEFORE, false, true);
ScFormulaCell* pFC = m_pDoc->GetFormulaCell(ScAddress(0,5,0));
CPPUNIT_ASSERT(pFC);
- CPPUNIT_ASSERT_EQUAL_MESSAGE("This formula cell should not be an error.", static_cast<sal_uInt16>(0), pFC->GetErrCode());
+ CPPUNIT_ASSERT_EQUAL_MESSAGE("This formula cell should not be an error.", 0, (int)pFC->GetErrCode());
ASSERT_DOUBLES_EQUAL(3.0, m_pDoc->GetValue(ScAddress(0,5,0)));
ASSERT_FORMULA_EQUAL(*m_pDoc, ScAddress(0,5,0), "MAX(A7:A9)", "Wrong formula!");
@@ -3547,19 +3547,19 @@ void Test::testFuncSUM()
// Set #DIV/0! error to A3. A4 should also inherit this error.
m_pDoc->SetString(ScAddress(0,2,0), "=1/0");
- sal_uInt16 nErr = m_pDoc->GetErrCode(ScAddress(0,2,0));
+ FormulaError nErr = m_pDoc->GetErrCode(ScAddress(0,2,0));
CPPUNIT_ASSERT_EQUAL_MESSAGE("Cell should have a division by zero error.",
- errDivisionByZero, nErr);
+ (int)FormulaError::DivisionByZero, (int)nErr);
nErr = m_pDoc->GetErrCode(ScAddress(0,3,0));
CPPUNIT_ASSERT_EQUAL_MESSAGE("SUM should have also inherited a div-by-zero error.",
- errDivisionByZero, nErr);
+ (int)FormulaError::DivisionByZero, (int)nErr);
// Set #NA! to A2. A4 should now inherit this error.
m_pDoc->SetString(ScAddress(0,1,0), "=NA()");
nErr = m_pDoc->GetErrCode(ScAddress(0,1,0));
- CPPUNIT_ASSERT_MESSAGE("A2 should be an error.", nErr);
+ CPPUNIT_ASSERT_MESSAGE("A2 should be an error.", nErr != FormulaError::NONE);
CPPUNIT_ASSERT_EQUAL_MESSAGE("A4 should have inherited the same error as A2.",
- nErr, m_pDoc->GetErrCode(ScAddress(0,3,0)));
+ (int)nErr, (int)m_pDoc->GetErrCode(ScAddress(0,3,0)));
m_pDoc->DeleteTab(0);
}
@@ -3642,8 +3642,8 @@ void Test::testFuncSUMPRODUCT()
// Force an error in C2 and test ForcedArray matrix error propagation.
m_pDoc->SetString( 2, 1, 0, "=1/0");
- sal_uInt16 nError = m_pDoc->GetErrCode(aPos);
- CPPUNIT_ASSERT_MESSAGE("Formula result should be a propagated error", nError);
+ FormulaError nError = m_pDoc->GetErrCode(aPos);
+ CPPUNIT_ASSERT_MESSAGE("Formula result should be a propagated error", nError != FormulaError::NONE);
// Test ForceArray propagation of SUMPRODUCT parameters to ABS and + operator.
// => ABS({-3,4})*({-3,4}+{-3,4}) => {3,4}*{-6,8} => {-18,32} => 14
@@ -3715,8 +3715,8 @@ void Test::testFuncMIN()
CPPUNIT_ASSERT_EQUAL(static_cast<SCCOL>(1), nCols);
CPPUNIT_ASSERT_EQUAL(static_cast<SCROW>(2), nRows);
- CPPUNIT_ASSERT_EQUAL_MESSAGE("Formula in C1 is invalid.", static_cast<sal_uInt16>(0), m_pDoc->GetErrCode(ScAddress(2,0,0)));
- CPPUNIT_ASSERT_EQUAL_MESSAGE("Formula in C2 is invalid.", static_cast<sal_uInt16>(0), m_pDoc->GetErrCode(ScAddress(2,1,0)));
+ CPPUNIT_ASSERT_EQUAL_MESSAGE("Formula in C1 is invalid.", 0, (int)m_pDoc->GetErrCode(ScAddress(2,0,0)));
+ CPPUNIT_ASSERT_EQUAL_MESSAGE("Formula in C2 is invalid.", 0, (int)m_pDoc->GetErrCode(ScAddress(2,1,0)));
CPPUNIT_ASSERT_EQUAL(0.0, m_pDoc->GetValue(ScAddress(2,0,0)));
CPPUNIT_ASSERT_EQUAL(0.0, m_pDoc->GetValue(ScAddress(2,1,0)));
@@ -3962,8 +3962,8 @@ void Test::testFuncCHOOSE()
m_pDoc->InsertTab(0, "Formula");
m_pDoc->SetString(ScAddress(0,0,0), "=CHOOSE(B1;\"one\";\"two\";\"three\")");
- sal_uInt16 nError = m_pDoc->GetErrCode(ScAddress(0,0,0));
- CPPUNIT_ASSERT_MESSAGE("Formula result should be an error since B1 is still empty.", nError);
+ FormulaError nError = m_pDoc->GetErrCode(ScAddress(0,0,0));
+ CPPUNIT_ASSERT_MESSAGE("Formula result should be an error since B1 is still empty.", nError != FormulaError::NONE);
m_pDoc->SetValue(ScAddress(1,0,0), 1.0);
CPPUNIT_ASSERT_EQUAL(OUString("one"), m_pDoc->GetString(ScAddress(0,0,0)));
m_pDoc->SetValue(ScAddress(1,0,0), 2.0);
@@ -3972,7 +3972,7 @@ void Test::testFuncCHOOSE()
CPPUNIT_ASSERT_EQUAL(OUString("three"), m_pDoc->GetString(ScAddress(0,0,0)));
m_pDoc->SetValue(ScAddress(1,0,0), 4.0);
nError = m_pDoc->GetErrCode(ScAddress(0,0,0));
- CPPUNIT_ASSERT_MESSAGE("Formula result should be an error due to out-of-bound input..", nError);
+ CPPUNIT_ASSERT_MESSAGE("Formula result should be an error due to out-of-bound input..", nError != FormulaError::NONE);
m_pDoc->DeleteTab(0);
}
@@ -4285,9 +4285,9 @@ void Test::testFuncLOOKUP()
printRange(m_pDoc, ScRange(0,4,0,1,6,0), "Data range for LOOKUP.");
// Values for B5:B7 should be 1, 2, and 3.
- CPPUNIT_ASSERT_EQUAL_MESSAGE("This formula should not have an error code.", static_cast<sal_uInt16>(0), m_pDoc->GetErrCode(ScAddress(1,4,0)));
- CPPUNIT_ASSERT_EQUAL_MESSAGE("This formula should not have an error code.", static_cast<sal_uInt16>(0), m_pDoc->GetErrCode(ScAddress(1,5,0)));
- CPPUNIT_ASSERT_EQUAL_MESSAGE("This formula should not have an error code.", static_cast<sal_uInt16>(0), m_pDoc->GetErrCode(ScAddress(1,6,0)));
+ CPPUNIT_ASSERT_EQUAL_MESSAGE("This formula should not have an error code.", 0, (int)m_pDoc->GetErrCode(ScAddress(1,4,0)));
+ CPPUNIT_ASSERT_EQUAL_MESSAGE("This formula should not have an error code.", 0, (int)m_pDoc->GetErrCode(ScAddress(1,5,0)));
+ CPPUNIT_ASSERT_EQUAL_MESSAGE("This formula should not have an error code.", 0, (int)m_pDoc->GetErrCode(ScAddress(1,6,0)));
ASSERT_DOUBLES_EQUAL(1.0, m_pDoc->GetValue(ScAddress(1,4,0)));
ASSERT_DOUBLES_EQUAL(2.0, m_pDoc->GetValue(ScAddress(1,5,0)));
@@ -4923,7 +4923,7 @@ void Test::testFuncINDIRECT2()
// Check formula cell error
ScFormulaCell* pFC = m_pDoc->GetFormulaCell(ScAddress(0,9,2));
CPPUNIT_ASSERT_MESSAGE("This should be a formula cell.", pFC);
- CPPUNIT_ASSERT_MESSAGE("This formula cell should be an error.", pFC->GetErrCode() != 0);
+ CPPUNIT_ASSERT_MESSAGE("This formula cell should be an error.", pFC->GetErrCode() != FormulaError::NONE);
m_pDoc->DeleteTab(2);
m_pDoc->DeleteTab(1);
@@ -5620,15 +5620,15 @@ void Test::testExternalRefFunctions()
// areas these tests may be adapted.
m_pDoc->SetString(0, 0, 0, "=SUM('file:///extdata.fake'#Data.B1:AMJ1048575)");
ScFormulaCell* pFC = m_pDoc->GetFormulaCell( ScAddress(0,0,0));
- sal_uInt16 nErr = pFC->GetErrCode();
- CPPUNIT_ASSERT_EQUAL_MESSAGE("huge external range reference expected to yield errMatrixSize", errMatrixSize, nErr);
+ FormulaError nErr = pFC->GetErrCode();
+ CPPUNIT_ASSERT_EQUAL_MESSAGE("huge external range reference expected to yield FormulaError::MatrixSize", (int)FormulaError::MatrixSize, (int)nErr);
ScMarkData aMark;
aMark.SelectOneTable(0);
m_pDoc->InsertMatrixFormula(0,0,0,0, aMark, "'file:///extdata.fake'#Data.B1:AMJ1048575");
pFC = m_pDoc->GetFormulaCell( ScAddress(0,0,0));
nErr = pFC->GetErrCode();
- CPPUNIT_ASSERT_EQUAL_MESSAGE("huge external range reference expected to yield errMatrixSize", errMatrixSize, nErr);
+ CPPUNIT_ASSERT_EQUAL_MESSAGE("huge external range reference expected to yield FormulaError::MatrixSize", (int)FormulaError::MatrixSize, (int)nErr);
SCSIZE nMatCols, nMatRows;
const ScMatrix* pMat = pFC->GetMatrix();
CPPUNIT_ASSERT_MESSAGE("matrix expected", pMat != nullptr);
diff --git a/sc/qa/unit/ucalc_pivottable.cxx b/sc/qa/unit/ucalc_pivottable.cxx
index c8aa1b3930cf..9bf5522186bf 100644
--- a/sc/qa/unit/ucalc_pivottable.cxx
+++ b/sc/qa/unit/ucalc_pivottable.cxx
@@ -19,6 +19,7 @@
#include "stringutil.hxx"
#include "dbdocfun.hxx"
+#include <formula/errorcodes.hxx>
#include <com/sun/star/sheet/DataPilotFieldOrientation.hpp>
#include <com/sun/star/sheet/DataPilotFieldGroupBy.hpp>
#include <com/sun/star/sheet/DataPilotFieldReference.hpp>
@@ -2304,11 +2305,10 @@ void Test::testFuncGETPIVOTDATALeafAccess()
m_pDoc->CalcAll();
- const sal_uInt16 nNoError = 0; // no error
for (size_t i = 0; i < SAL_N_ELEMENTS(aChecks); ++i)
{
- sal_uInt16 nErr = m_pDoc->GetErrCode(ScAddress(4,i,1));
- CPPUNIT_ASSERT_EQUAL(nNoError, nErr);
+ FormulaError nErr = m_pDoc->GetErrCode(ScAddress(4,i,1));
+ CPPUNIT_ASSERT_EQUAL((sal_uInt16)FormulaError::NONE, (sal_uInt16)nErr);
double fVal = m_pDoc->GetValue(ScAddress(4,i,1));
CPPUNIT_ASSERT_EQUAL(aChecks[i].mfResult, fVal);
}
diff --git a/sc/source/core/data/clipcontext.cxx b/sc/source/core/data/clipcontext.cxx
index b0ac3019c67c..16084be70c6d 100644
--- a/sc/source/core/data/clipcontext.cxx
+++ b/sc/source/core/data/clipcontext.cxx
@@ -17,6 +17,7 @@
#include <clipparam.hxx>
#include <svl/intitem.hxx>
+#include <formula/errorcodes.hxx>
namespace sc {
@@ -203,8 +204,8 @@ void CopyFromClipContext::setSingleCell( const ScAddress& rSrcPos, const ScColum
// Good.
break;
- sal_uInt16 nErr = rSrcCell.mpFormula->GetErrCode();
- if (nErr)
+ FormulaError nErr = rSrcCell.mpFormula->GetErrCode();
+ if (nErr != FormulaError::NONE)
{
// error codes are cloned with values
if (!bNumeric)
diff --git a/sc/source/core/data/column.cxx b/sc/source/core/data/column.cxx
index 67c51a4f54d5..dfe343ec46ca 100644
--- a/sc/source/core/data/column.cxx
+++ b/sc/source/core/data/column.cxx
@@ -51,6 +51,7 @@
#include <svl/sharedstringpool.hxx>
#include <editeng/scripttypeitem.hxx>
#include <editeng/fieldupdater.hxx>
+#include <formula/errorcodes.hxx>
#include <osl/diagnose.h>
#include <cstring>
@@ -1125,7 +1126,7 @@ void ScColumn::CopyStaticToDocument(
if (rFC.GetDirty() && pDocument->GetAutoCalc())
rFC.Interpret();
- if (rFC.GetErrCode())
+ if (rFC.GetErrCode() != FormulaError::NONE)
// Skip cells with error.
break;
@@ -1445,8 +1446,8 @@ class CopyByCloneHandler
if (bCloneValue)
{
- sal_uInt16 nErr = rSrcCell.GetErrCode();
- if (nErr)
+ FormulaError nErr = rSrcCell.GetErrCode();
+ if (nErr != FormulaError::NONE)
{
// error codes are cloned with values
ScFormulaCell* pErrCell = new ScFormulaCell(&mrDestCol.GetDoc(), aDestPos);
@@ -2875,7 +2876,7 @@ public:
{
// for unconditional compilation
// bCompile=true and pCode->nError=0
- pCell->GetCode()->SetCodeError(0);
+ pCell->GetCode()->SetCodeError(FormulaError::NONE);
pCell->SetCompile(true);
pCell->CompileTokenArray(mrCxt);
}
@@ -2913,10 +2914,10 @@ class CompileErrorCellsHandler
sc::CompileFormulaContext& mrCxt;
ScColumn& mrColumn;
sc::CellStoreType::iterator miPos;
- sal_uInt16 mnErrCode;
+ FormulaError mnErrCode;
bool mbCompiled;
public:
- CompileErrorCellsHandler( sc::CompileFormulaContext& rCxt, ScColumn& rColumn, sal_uInt16 nErrCode ) :
+ CompileErrorCellsHandler( sc::CompileFormulaContext& rCxt, ScColumn& rColumn, FormulaError nErrCode ) :
mrCxt(rCxt),
mrColumn(rColumn),
miPos(mrColumn.GetCellStore().begin()),
@@ -2927,19 +2928,19 @@ public:
void operator() (size_t nRow, ScFormulaCell* pCell)
{
- sal_uInt16 nCurError = pCell->GetRawError();
- if (!nCurError)
+ FormulaError nCurError = pCell->GetRawError();
+ if (nCurError == FormulaError::NONE)
// It's not an error cell. Skip it.
return;
- if (mnErrCode && nCurError != mnErrCode)
+ if (mnErrCode != FormulaError::NONE && nCurError != mnErrCode)
// Error code is specified, and it doesn't match. Skip it.
return;
sc::CellStoreType::position_type aPos = mrColumn.GetCellStore().position(miPos, nRow);
miPos = aPos.first;
sc::SharedFormulaUtil::unshareFormulaCell(aPos, *pCell);
- pCell->GetCode()->SetCodeError(0);
+ pCell->GetCode()->SetCodeError(FormulaError::NONE);
OUString aFormula = pCell->GetFormula(mrCxt);
pCell->Compile(mrCxt, aFormula);
ScColumn::JoinNewFormulaCell(aPos, *pCell);
@@ -3456,7 +3457,7 @@ void ScColumn::CompileXML( sc::CompileFormulaContext& rCxt, ScProgress& rProgres
RegroupFormulaCells();
}
-bool ScColumn::CompileErrorCells( sc::CompileFormulaContext& rCxt, sal_uInt16 nErrCode )
+bool ScColumn::CompileErrorCells( sc::CompileFormulaContext& rCxt, FormulaError nErrCode )
{
CompileErrorCellsHandler aHdl(rCxt, *this, nErrCode);
sc::ProcessFormula(maCells, aHdl);
diff --git a/sc/source/core/data/column2.cxx b/sc/source/core/data/column2.cxx
index 37d8ccd7cf65..60035652315b 100644
--- a/sc/source/core/data/column2.cxx
+++ b/sc/source/core/data/column2.cxx
@@ -2224,14 +2224,14 @@ public:
continue;
}
- sal_uInt16 nErr;
+ FormulaError nErr;
double fVal;
if (rCell.GetErrorOrValue(nErr, fVal))
{
ScAddress aAdr(mnCol, nThisRow, mnTab);
- if (nErr)
- fVal = formula::CreateDoubleError(nErr);
+ if (nErr != FormulaError::NONE)
+ fVal = CreateDoubleError(nErr);
if (!aBucket.maNumVals.empty() && nThisRow == nPrevRow + 1)
{
@@ -2362,12 +2362,12 @@ bool appendToBlock(
sc::FormulaResultValue aRes = rFC.GetResult();
- if (aRes.meType == sc::FormulaResultValue::Invalid || aRes.mnError)
+ if (aRes.meType == sc::FormulaResultValue::Invalid || aRes.mnError != FormulaError::NONE)
{
- if (aRes.mnError == formula::errCircularReference)
+ if (aRes.mnError == FormulaError::CircularReference)
{
// This cell needs to be recalculated on next visit.
- rFC.SetErrCode(0);
+ rFC.SetErrCode(FormulaError::NONE);
rFC.SetDirtyVar();
}
return false;
@@ -2483,12 +2483,12 @@ copyFirstFormulaBlock(
{
ScFormulaCell& rFC = **it;
sc::FormulaResultValue aRes = rFC.GetResult();
- if (aRes.meType == sc::FormulaResultValue::Invalid || aRes.mnError)
+ if (aRes.meType == sc::FormulaResultValue::Invalid || aRes.mnError != FormulaError::NONE)
{
- if (aRes.mnError == formula::errCircularReference)
+ if (aRes.mnError == FormulaError::CircularReference)
{
// This cell needs to be recalculated on next visit.
- rFC.SetErrCode(0);
+ rFC.SetErrCode(FormulaError::NONE);
rFC.SetDirtyVar();
}
return nullptr;
@@ -2730,8 +2730,8 @@ void ScColumn::SetFormulaResults( SCROW nRow, const double* pResults, size_t nLe
for (; pResults != pResEnd; ++pResults, ++itCell)
{
ScFormulaCell& rCell = **itCell;
- sal_uInt16 nErr = formula::GetDoubleErrorValue(*pResults);
- if (nErr != 0)
+ FormulaError nErr = GetDoubleErrorValue(*pResults);
+ if (nErr != FormulaError::NONE)
rCell.SetResultError(nErr);
else
rCell.SetResultDouble(*pResults);
@@ -3151,7 +3151,7 @@ public:
if (mrData.eFunc != SUBTOTAL_FUNC_CNT2) // it doesn't interest us
{
- if (pCell->GetErrCode())
+ if (pCell->GetErrCode() != FormulaError::NONE)
{
if (mrData.eFunc != SUBTOTAL_FUNC_CNT) // simply remove from count
mrData.bError = true;
diff --git a/sc/source/core/data/column3.cxx b/sc/source/core/data/column3.cxx
index 27abbbf249fe..89aa5e05e6c2 100644
--- a/sc/source/core/data/column3.cxx
+++ b/sc/source/core/data/column3.cxx
@@ -936,8 +936,8 @@ public:
// Always just copy the original row to the Undo Documen;
// do not create Value/string cells from formulas
- sal_uInt16 nErr = rSrcCell.GetErrCode();
- if (nErr)
+ FormulaError nErr = rSrcCell.GetErrCode();
+ if (nErr != FormulaError::NONE)
{
// error codes are cloned with values
if (bNumeric)
@@ -1190,7 +1190,7 @@ class MixDataHandler
ScAddress aPos(mrDestColumn.GetCol(), nDestRow, mrDestColumn.GetTab());
ScFormulaCell* pFC = new ScFormulaCell(&mrDestColumn.GetDoc(), aPos);
- pFC->SetErrCode(errNoValue);
+ pFC->SetErrCode(FormulaError::NoValue);
miNewCellsPos = maNewCells.set(miNewCellsPos, nDestRow-mnRowOffset, pFC);
}
@@ -1998,8 +1998,8 @@ class FilterEntriesHandler
case CELLTYPE_FORMULA:
{
ScFormulaCell* pFC = rCell.mpFormula;
- sal_uInt16 nErr = pFC->GetErrCode();
- if (nErr)
+ FormulaError nErr = pFC->GetErrCode();
+ if (nErr != FormulaError::NONE)
{
// Error cell is evaluated as string (for now).
OUString aErr = ScGlobal::GetErrorString(nErr);
@@ -2365,7 +2365,7 @@ void ScColumn::RemoveProtected( SCROW nStartRow, SCROW nEndRow )
aFunc.commitCells(*this);
}
-void ScColumn::SetError( SCROW nRow, const sal_uInt16 nError)
+void ScColumn::SetError( SCROW nRow, const FormulaError nError)
{
if (!ValidRow(nRow))
return;
@@ -2605,15 +2605,15 @@ SCSIZE ScColumn::GetCellCount() const
return aFunc.getCount();
}
-sal_uInt16 ScColumn::GetErrCode( SCROW nRow ) const
+FormulaError ScColumn::GetErrCode( SCROW nRow ) const
{
std::pair<sc::CellStoreType::const_iterator,size_t> aPos = maCells.position(nRow);
sc::CellStoreType::const_iterator it = aPos.first;
if (it == maCells.end())
- return 0;
+ return FormulaError::NONE;
if (it->type != sc::element_type_formula)
- return 0;
+ return FormulaError::NONE;
const ScFormulaCell* p = sc::formula_block::at(*it->data, aPos.second);
return const_cast<ScFormulaCell*>(p)->GetErrCode();
diff --git a/sc/source/core/data/conditio.cxx b/sc/source/core/data/conditio.cxx
index 2a6b48aeb07a..c5d712cac926 100644
--- a/sc/source/core/data/conditio.cxx
+++ b/sc/source/core/data/conditio.cxx
@@ -41,6 +41,7 @@
#include "editutil.hxx"
#include "tokenarray.hxx"
#include "refupdatecontext.hxx"
+#include <formula/errorcodes.hxx>
#include <svl/sharedstring.hxx>
#include <svl/sharedstringpool.hxx>
#include <memory>
@@ -1037,7 +1038,7 @@ bool ScConditionEntry::IsError( const ScAddress& rPos ) const
if (rCell.meType == CELLTYPE_FORMULA)
{
- if (rCell.mpFormula->GetErrCode())
+ if (rCell.mpFormula->GetErrCode() != FormulaError::NONE)
return true;
}
diff --git a/sc/source/core/data/dbdocutl.cxx b/sc/source/core/data/dbdocutl.cxx
index 6e681f645148..60a7610e478d 100644
--- a/sc/source/core/data/dbdocutl.cxx
+++ b/sc/source/core/data/dbdocutl.cxx
@@ -157,7 +157,7 @@ void ScDatabaseDocUtil::PutData( ScDocument* pDoc, SCCOL nCol, SCROW nRow, SCTAB
pDoc->SetEmptyCell(aPos);
else if (bError)
{
- pDoc->SetError( nCol, nRow, nTab, formula::NOTAVAILABLE );
+ pDoc->SetError( nCol, nRow, nTab, FormulaError::NotAvailable );
}
else if (bValue)
{
diff --git a/sc/source/core/data/dociter.cxx b/sc/source/core/data/dociter.cxx
index b9bc4db58ac6..ed391238baac 100644
--- a/sc/source/core/data/dociter.cxx
+++ b/sc/source/core/data/dociter.cxx
@@ -151,7 +151,7 @@ void ScValueIterator::SetPos(size_t nPos)
maCurPos = mpCells->position(maCurPos.first, nPos);
}
-bool ScValueIterator::GetThis(double& rValue, sal_uInt16& rErr)
+bool ScValueIterator::GetThis(double& rValue, FormulaError& rErr)
{
while (true)
{
@@ -175,7 +175,7 @@ bool ScValueIterator::GetThis(double& rValue, sal_uInt16& rErr)
++mnTab;
if (mnTab > maEndPos.Tab())
{
- rErr = 0;
+ rErr = FormulaError::NONE;
return false; // Over and out
}
}
@@ -205,7 +205,7 @@ bool ScValueIterator::GetThis(double& rValue, sal_uInt16& rErr)
{
bNumValid = false;
rValue = sc::numeric_block::at(*maCurPos.first->data, maCurPos.second);
- rErr = 0;
+ rErr = FormulaError::NONE;
if (bCalcAsShown)
{
ScAttrArray_IterGetNumberFormat(nNumFormat, pAttrArray,
@@ -227,7 +227,7 @@ bool ScValueIterator::GetThis(double& rValue, sal_uInt16& rErr)
if (rCell.GetErrorOrValue(rErr, rValue))
{
- if ( rErr && ( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) )
+ if ( rErr != FormulaError::NONE && ( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) )
{
IncPos();
break;
@@ -249,7 +249,7 @@ bool ScValueIterator::GetThis(double& rValue, sal_uInt16& rErr)
{
if (bTextAsZero)
{
- rErr = 0;
+ rErr = FormulaError::NONE;
rValue = 0.0;
nNumFmtType = css::util::NumberFormat::NUMBER;
nNumFmtIndex = 0;
@@ -282,7 +282,7 @@ void ScValueIterator::GetCurNumFmtInfo( short& nType, sal_uLong& nIndex )
nIndex = nNumFmtIndex;
}
-bool ScValueIterator::GetFirst(double& rValue, sal_uInt16& rErr)
+bool ScValueIterator::GetFirst(double& rValue, FormulaError& rErr)
{
mnCol = maStartPos.Col();
mnTab = maStartPos.Tab();
@@ -300,7 +300,7 @@ bool ScValueIterator::GetFirst(double& rValue, sal_uInt16& rErr)
return GetThis(rValue, rErr);
}
-bool ScValueIterator::GetNext(double& rValue, sal_uInt16& rErr)
+bool ScValueIterator::GetNext(double& rValue, FormulaError& rErr)
{
IncPos();
return GetThis(rValue, rErr);
@@ -388,7 +388,7 @@ bool ScDBQueryDataIterator::DataAccessInternal::getCurrent(Value& rValue)
if (maCurPos.first == mpCells->end() || nRow > mpParam->nRow2)
{
// Bottom of the range reached. Bail out.
- rValue.mnError = 0;
+ rValue.mnError = FormulaError::NONE;
return false;
}
@@ -426,7 +426,7 @@ bool ScDBQueryDataIterator::DataAccessInternal::getCurrent(Value& rValue)
}
nNumFmtType = css::util::NumberFormat::NUMBER;
nNumFmtIndex = 0;
- rValue.mnError = 0;
+ rValue.mnError = FormulaError::NONE;
return true; // Found it!
}
@@ -461,7 +461,7 @@ bool ScDBQueryDataIterator::DataAccessInternal::getCurrent(Value& rValue)
{
rValue.maString = aCell.getString(mpDoc);
rValue.mfValue = 0.0;
- rValue.mnError = 0;
+ rValue.mnError = FormulaError::NONE;
rValue.mbIsNumber = false;
return true;
}
@@ -554,7 +554,7 @@ bool ScDBQueryDataIterator::DataAccessMatrix::getCurrent(Value& rValue)
rValue.maString = rMat.GetString(mpParam->mnField, mnCurRow).getString();
rValue.mfValue = rMat.GetDouble(mpParam->mnField, mnCurRow);
rValue.mbIsNumber = !bIsStrVal;
- rValue.mnError = 0;
+ rValue.mnError = FormulaError::NONE;
return true;
}
}
@@ -748,7 +748,7 @@ bool ScDBQueryDataIterator::DataAccessMatrix::isValidQuery(SCROW nRow, const ScM
}
ScDBQueryDataIterator::Value::Value() :
- mnError(0), mbIsNumber(true)
+ mnError(FormulaError::NONE), mbIsNumber(true)
{
::rtl::math::setNan(&mfValue);
}
@@ -965,7 +965,7 @@ bool ScCellIterator::getCurrent()
ScFormulaCell* pCell = sc::formula_block::at(*maCurColPos.first->data, maCurColPos.second);
// Skip formula cells with Subtotal formulae or errors, depending on mnSubTotalFlags
if ( ( ( mnSubTotalFlags & SUBTOTAL_IGN_NESTED_ST_AG ) && pCell->IsSubTotal() ) ||
- ( ( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) && pCell->GetErrCode() ) )
+ ( ( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) && pCell->GetErrCode() != FormulaError::NONE ) )
{
incPos();
continue;
@@ -2204,7 +2204,7 @@ ScHorizontalValueIterator::~ScHorizontalValueIterator()
delete pCellIter;
}
-bool ScHorizontalValueIterator::GetNext( double& rValue, sal_uInt16& rErr )
+bool ScHorizontalValueIterator::GetNext( double& rValue, FormulaError& rErr )
{
bool bFound = false;
while ( !bFound )
@@ -2225,7 +2225,7 @@ bool ScHorizontalValueIterator::GetNext( double& rValue, sal_uInt16& rErr )
case CELLTYPE_VALUE:
{
rValue = pCell->mfValue;
- rErr = 0;
+ rErr = FormulaError::NONE;
if ( bCalcAsShown )
{
ScColumn* pCol = &pDoc->maTabs[nCurTab]->aCol[nCurCol];
@@ -2239,7 +2239,7 @@ bool ScHorizontalValueIterator::GetNext( double& rValue, sal_uInt16& rErr )
case CELLTYPE_FORMULA:
{
rErr = pCell->mpFormula->GetErrCode();
- if (rErr || pCell->mpFormula->IsValue())
+ if (rErr != FormulaError::NONE || pCell->mpFormula->IsValue())
{
rValue = pCell->mpFormula->GetValue();
bFound = true;
diff --git a/sc/source/core/data/documen2.cxx b/sc/source/core/data/documen2.cxx
index 1de362027221..534a78849e38 100644
--- a/sc/source/core/data/documen2.cxx
+++ b/sc/source/core/data/documen2.cxx
@@ -1095,7 +1095,7 @@ sal_uLong ScDocument::TransferTab( ScDocument* pSrcDoc, SCTAB nSrcPos,
return nRetVal;
}
-void ScDocument::SetError( SCCOL nCol, SCROW nRow, SCTAB nTab, const sal_uInt16 nError)
+void ScDocument::SetError( SCCOL nCol, SCROW nRow, SCTAB nTab, const FormulaError nError)
{
if (ValidTab(nTab) && nTab < static_cast<SCTAB>(maTabs.size()))
if (maTabs[nTab])
diff --git a/sc/source/core/data/documen4.cxx b/sc/source/core/data/documen4.cxx
index d2dcdb28c8bd..c503b2fa6137 100644
--- a/sc/source/core/data/documen4.cxx
+++ b/sc/source/core/data/documen4.cxx
@@ -110,7 +110,7 @@ bool ScDocument::Solver(SCCOL nFCol, SCROW nFRow, SCTAB nFTab,
fBestX = fXPrev = fSaveVal;
pFormula->Interpret();
- bool bError = ( pFormula->GetErrCode() != 0 );
+ bool bError = ( pFormula->GetErrCode() != FormulaError::NONE );
// bError always corresponds with fF
fFPrev = pFormula->GetValue() - fTargetVal;
@@ -132,7 +132,7 @@ bool ScDocument::Solver(SCCOL nFCol, SCROW nFRow, SCTAB nFTab,
*pVCell = fX;
SetDirty( aVRange, false );
pFormula->Interpret();
- bError = ( pFormula->GetErrCode() != 0 );
+ bError = ( pFormula->GetErrCode() != FormulaError::NONE );
fF = pFormula->GetValue() - fTargetVal;
if ( fF == fFPrev && !bError )
@@ -166,7 +166,7 @@ bool ScDocument::Solver(SCCOL nFCol, SCROW nFRow, SCTAB nFTab,
*pVCell = fHorX;
SetDirty( aVRange, false );
pFormula->Interpret();
- bHorMoveError = ( pFormula->GetErrCode() != 0 );
+ bHorMoveError = ( pFormula->GetErrCode() != FormulaError::NONE );
if ( bHorMoveError )
break;
@@ -243,12 +243,12 @@ bool ScDocument::Solver(SCCOL nFCol, SCROW nFRow, SCTAB nFTab,
pFormula->Interpret();
if ( !bDoneIteration )
{
- SetError( nVCol, nVRow, nVTab, NOTAVAILABLE );
+ SetError( nVCol, nVRow, nVTab, FormulaError::NotAvailable );
}
}
else
{
- SetError( nVCol, nVRow, nVTab, NOTAVAILABLE );
+ SetError( nVCol, nVRow, nVTab, FormulaError::NotAvailable );
}
}
return bRet;
diff --git a/sc/source/core/data/document.cxx b/sc/source/core/data/document.cxx
index 2d698accfb43..adcf0c93ffc5 100644
--- a/sc/source/core/data/document.cxx
+++ b/sc/source/core/data/document.cxx
@@ -3498,7 +3498,7 @@ void ScDocument::GetInputString( SCCOL nCol, SCROW nRow, SCTAB nTab, OUString& r
rString.clear();
}
-sal_uInt16 ScDocument::GetStringForFormula( const ScAddress& rPos, OUString& rString )
+FormulaError ScDocument::GetStringForFormula( const ScAddress& rPos, OUString& rString )
{
// Used in formulas (add-in parameters etc), so it must use the same semantics as
// ScInterpreter::GetCellString: always format values as numbers.
@@ -3508,10 +3508,10 @@ sal_uInt16 ScDocument::GetStringForFormula( const ScAddress& rPos, OUString& rSt
if (aCell.isEmpty())
{
rString = EMPTY_OUSTRING;
- return 0;
+ return FormulaError::NONE;
}
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
OUString aStr;
SvNumberFormatter* pFormatter = GetFormatTable();
switch (aCell.meType)
@@ -3948,7 +3948,7 @@ void ScDocument::CompileXML()
SetAutoCalc( bOldAutoCalc );
}
-bool ScDocument::CompileErrorCells(sal_uInt16 nErrCode)
+bool ScDocument::CompileErrorCells(FormulaError nErrCode)
{
bool bCompiled = false;
sc::CompileFormulaContext aCxt(this);
@@ -4000,12 +4000,12 @@ void ScDocument::CalcAfterLoad( bool bStartListening )
}
}
-sal_uInt16 ScDocument::GetErrCode( const ScAddress& rPos ) const
+FormulaError ScDocument::GetErrCode( const ScAddress& rPos ) const
{
SCTAB nTab = rPos.Tab();
if ( nTab < static_cast<SCTAB>(maTabs.size()) && maTabs[nTab] )
return maTabs[nTab]->GetErrCode( rPos );
- return 0;
+ return FormulaError::NONE;
}
void ScDocument::ResetChanged( const ScRange& rRange )
diff --git a/sc/source/core/data/dpcache.cxx b/sc/source/core/data/dpcache.cxx
index 85de53846244..25a500c96ff3 100644
--- a/sc/source/core/data/dpcache.cxx
+++ b/sc/source/core/data/dpcache.cxx
@@ -33,6 +33,7 @@
#include <rtl/math.hxx>
#include <unotools/textsearch.hxx>
#include <unotools/localedatawrapper.hxx>
+#include <formula/errorcodes.hxx>
#include <svl/zforlist.hxx>
#include <o3tl/make_unique.hxx>
@@ -129,7 +130,7 @@ void initFromCell(
ScAddress aPos(nCol, nRow, nTab);
- if (pDoc->GetErrCode(aPos))
+ if (pDoc->GetErrCode(aPos) != FormulaError::NONE)
{
rData.SetErrorString(rCache.InternString(aDocStr));
}
diff --git a/sc/source/core/data/dpoutput.cxx b/sc/source/core/data/dpoutput.cxx
index 5d4550df61e2..390aaf67592d 100644
--- a/sc/source/core/data/dpoutput.cxx
+++ b/sc/source/core/data/dpoutput.cxx
@@ -751,7 +751,7 @@ void ScDPOutput::DataCell( SCCOL nCol, SCROW nRow, SCTAB nTab, const sheet::Data
long nFlags = rData.Flags;
if ( nFlags & sheet::DataResultFlags::ERROR )
{
- pDoc->SetError( nCol, nRow, nTab, formula::errNoValue );
+ pDoc->SetError( nCol, nRow, nTab, FormulaError::NoValue );
}
else if ( nFlags & sheet::DataResultFlags::HASDATA )
{
diff --git a/sc/source/core/data/formulacell.cxx b/sc/source/core/data/formulacell.cxx
index 322f0d5180c1..cb4bb4de5340 100644
--- a/sc/source/core/data/formulacell.cxx
+++ b/sc/source/core/data/formulacell.cxx
@@ -557,7 +557,7 @@ void ScFormulaCellGroup::compileCode(
if (!mpCode)
return;
- if (mpCode->GetLen() && !mpCode->GetCodeError() && !mpCode->GetCodeLen())
+ if (mpCode->GetLen() && mpCode->GetCodeError() == FormulaError::NONE && !mpCode->GetCodeLen())
{
ScCompiler aComp(&rDoc, rPos, *mpCode);
aComp.SetGrammar(eGram);
@@ -700,7 +700,7 @@ ScFormulaCell::ScFormulaCell(
assert(pArray); // Never pass a NULL pointer here.
// Generate RPN token array.
- if (pCode->GetLen() && !pCode->GetCodeError() && !pCode->GetCodeLen())
+ if (pCode->GetLen() && pCode->GetCodeError() == FormulaError::NONE && !pCode->GetCodeLen())
{
ScCompiler aComp( pDocument, aPos, *pCode);
aComp.SetGrammar(eTempGrammar);
@@ -750,7 +750,7 @@ ScFormulaCell::ScFormulaCell(
SAL_INFO( "sc.core.formulacell", "ScFormulaCell ctor this " << this);
// RPN array generation
- if( pCode->GetLen() && !pCode->GetCodeError() && !pCode->GetCodeLen() )
+ if( pCode->GetLen() && pCode->GetCodeError() == FormulaError::NONE && !pCode->GetCodeLen() )
{
ScCompiler aComp( pDocument, aPos, *pCode);
aComp.SetGrammar(eTempGrammar);
@@ -838,9 +838,9 @@ ScFormulaCell::ScFormulaCell(const ScFormulaCell& rCell, ScDocument& rDoc, const
// set back any errors and recompile
// not in the Clipboard - it must keep the received error flag
// Special Length=0: as bad cells are generated, then they are also retained
- if ( pCode->GetCodeError() && !pDocument->IsClipboard() && pCode->GetLen() )
+ if ( pCode->GetCodeError() != FormulaError::NONE && !pDocument->IsClipboard() && pCode->GetLen() )
{
- pCode->SetCodeError( 0 );
+ pCode->SetCodeError( FormulaError::NONE );
bCompile = true;
}
// Compile ColRowNames on URM_MOVE/URM_COPY _after_ UpdateReference !
@@ -975,7 +975,7 @@ ScFormulaVectorState ScFormulaCell::GetVectorState() const
void ScFormulaCell::GetFormula( OUStringBuffer& rBuffer,
const FormulaGrammar::Grammar eGrammar ) const
{
- if( pCode->GetCodeError() && !pCode->GetLen() )
+ if( pCode->GetCodeError() != FormulaError::NONE && !pCode->GetLen() )
{
rBuffer = OUStringBuffer( ScGlobal::GetErrorString( pCode->GetCodeError()));
return;
@@ -1039,7 +1039,7 @@ void ScFormulaCell::GetFormula( OUString& rFormula, const FormulaGrammar::Gramma
OUString ScFormulaCell::GetFormula( sc::CompileFormulaContext& rCxt ) const
{
OUStringBuffer aBuf;
- if (pCode->GetCodeError() && !pCode->GetLen())
+ if (pCode->GetCodeError() != FormulaError::NONE && !pCode->GetLen())
{
aBuf = OUStringBuffer( ScGlobal::GetErrorString( pCode->GetCodeError()));
return aBuf.makeStringAndClear();
@@ -1097,7 +1097,7 @@ void ScFormulaCell::GetResultDimensions( SCSIZE& rCols, SCSIZE& rRows )
MaybeInterpret();
const ScMatrix* pMat = nullptr;
- if (!pCode->GetCodeError() && aResult.GetType() == svMatrixCell &&
+ if (pCode->GetCodeError() == FormulaError::NONE && aResult.GetType() == svMatrixCell &&
((pMat = aResult.GetToken().get()->GetMatrix()) != nullptr))
pMat->GetDimensions( rCols, rRows );
else
@@ -1136,7 +1136,7 @@ void ScFormulaCell::Compile( const OUString& rFormula, bool bNoListening,
aComp.SetGrammar(eGrammar);
pCode = aComp.CompileString( rFormula );
delete pCodeOld;
- if( !pCode->GetCodeError() )
+ if( pCode->GetCodeError() == FormulaError::NONE )
{
if ( !pCode->GetLen() && !aResult.GetHybridFormula().isEmpty() && rFormula == aResult.GetHybridFormula() )
{ // not recursive CompileTokenArray/Compile/CompileTokenArray
@@ -1170,7 +1170,7 @@ void ScFormulaCell::Compile(
ScCompiler aComp(rCxt, aPos);
pCode = aComp.CompileString( rFormula );
delete pCodeOld;
- if( !pCode->GetCodeError() )
+ if( pCode->GetCodeError() == FormulaError::NONE )
{
if ( !pCode->GetLen() && !aResult.GetHybridFormula().isEmpty() && rFormula == aResult.GetHybridFormula() )
{ // not recursive CompileTokenArray/Compile/CompileTokenArray
@@ -1196,7 +1196,7 @@ void ScFormulaCell::CompileTokenArray( bool bNoListening )
{
Compile( aResult.GetHybridFormula(), bNoListening, eTempGrammar);
}
- else if( bCompile && !pDocument->IsClipOrUndo() && !pCode->GetCodeError() )
+ else if( bCompile && !pDocument->IsClipOrUndo() && pCode->GetCodeError() == FormulaError::NONE )
{
// RPN length may get changed
bool bWasInFormulaTree = pDocument->IsInFormulaTree( this );
@@ -1212,7 +1212,7 @@ void ScFormulaCell::CompileTokenArray( bool bNoListening )
ScCompiler aComp(pDocument, aPos, *pCode);
aComp.SetGrammar(pDocument->GetGrammar());
bSubTotal = aComp.CompileTokenArray();
- if( !pCode->GetCodeError() )
+ if( pCode->GetCodeError() == FormulaError::NONE )
{
nFormatType = aComp.GetNumFormatType();
bChanged = true;
@@ -1237,7 +1237,7 @@ void ScFormulaCell::CompileTokenArray( sc::CompileFormulaContext& rCxt, bool bNo
rCxt.setGrammar(eTempGrammar);
Compile(rCxt, aResult.GetHybridFormula(), bNoListening);
}
- else if( bCompile && !pDocument->IsClipOrUndo() && !pCode->GetCodeError() )
+ else if( bCompile && !pDocument->IsClipOrUndo() && pCode->GetCodeError() == FormulaError::NONE)
{
// RPN length may get changed
bool bWasInFormulaTree = pDocument->IsInFormulaTree( this );
@@ -1252,7 +1252,7 @@ void ScFormulaCell::CompileTokenArray( sc::CompileFormulaContext& rCxt, bool bNo
EndListeningTo( pDocument );
ScCompiler aComp(rCxt, aPos, *pCode);
bSubTotal = aComp.CompileTokenArray();
- if( !pCode->GetCodeError() )
+ if( pCode->GetCodeError() == FormulaError::NONE )
{
nFormatType = aComp.GetNumFormatType();
bChanged = true;
@@ -1345,7 +1345,7 @@ void ScFormulaCell::CompileXML( sc::CompileFormulaContext& rCxt, ScProgress& rPr
pCode = aComp.CompileString( aFormula, aFormulaNmsp );
delete pCodeOld;
- if( !pCode->GetCodeError() )
+ if( pCode->GetCodeError() == FormulaError::NONE )
{
if ( !pCode->GetLen() )
{
@@ -1355,7 +1355,7 @@ void ScFormulaCell::CompileXML( sc::CompileFormulaContext& rCxt, ScProgress& rPr
pCode->AddBad( aFormula );
}
bSubTotal = aComp.CompileTokenArray();
- if( !pCode->GetCodeError() )
+ if( pCode->GetCodeError() == FormulaError::NONE )
{
nFormatType = aComp.GetNumFormatType();
bChanged = true;
@@ -1402,7 +1402,7 @@ void ScFormulaCell::CalcAfterLoad( sc::CompileFormulaContext& rCxt, bool bStartL
bNewCompiled = true;
}
// The RPN array is not created when a Calc 3.0-Doc has been read as the Range Names exist until now.
- if( pCode->GetLen() && !pCode->GetCodeLen() && !pCode->GetCodeError() )
+ if( pCode->GetLen() && !pCode->GetCodeLen() && pCode->GetCodeError() == FormulaError::NONE )
{
ScCompiler aComp(rCxt, aPos, *pCode);
bSubTotal = aComp.CompileTokenArray();
@@ -1421,7 +1421,7 @@ void ScFormulaCell::CalcAfterLoad( sc::CompileFormulaContext& rCxt, bool bStartL
if ( aResult.IsValue() && !::rtl::math::isFinite( aResult.GetDouble() ) )
{
OSL_FAIL("Formula cell INFINITY!!! Where does this document come from?");
- aResult.SetResultError( errIllegalFPOperation );
+ aResult.SetResultError( FormulaError::IllegalFPOperation );
bDirty = true;
}
@@ -1436,7 +1436,7 @@ void ScFormulaCell::CalcAfterLoad( sc::CompileFormulaContext& rCxt, bool bStartL
// Do the cells need to be calculated? After Load cells can contain an error code, and then start
// the listener and Recalculate (if needed) if not ScRecalcMode::NORMAL
- if( !bNewCompiled || !pCode->GetCodeError() )
+ if( !bNewCompiled || pCode->GetCodeError() == FormulaError::NONE )
{
if (bStartListening)
StartListeningTo(pDocument);
@@ -1505,12 +1505,12 @@ void ScFormulaCell::Interpret()
{
if (!pDocument->GetDocOptions().IsIter())
{
- aResult.SetResultError( errCircularReference );
+ aResult.SetResultError( FormulaError::CircularReference );
return;
}
- if (aResult.GetResultError() == errCircularReference)
- aResult.SetResultError( 0 );
+ if (aResult.GetResultError() == FormulaError::CircularReference)
+ aResult.SetResultError( FormulaError::NONE );
// Start or add to iteration list.
if (!pDocument->GetRecursionHelper().IsDoingIteration() ||
@@ -1684,7 +1684,7 @@ void ScFormulaCell::Interpret()
// circular dependency don't, no matter whether
// single cells did.
pIterCell->ResetDirty();
- pIterCell->aResult.SetResultError( errNoConvergence);
+ pIterCell->aResult.SetResultError( FormulaError::NoConvergence);
pIterCell->bChanged = true;
}
}
@@ -1750,7 +1750,7 @@ void ScFormulaCell::InterpretTail( ScInterpretTailParameter eTailParam )
{
RecursionCounter aRecursionCounter( pDocument->GetRecursionHelper(), this);
nSeenInIteration = pDocument->GetRecursionHelper().GetIteration();
- if( !pCode->GetCodeLen() && !pCode->GetCodeError() )
+ if( !pCode->GetCodeLen() && pCode->GetCodeError() == FormulaError::NONE )
{
// #i11719# no RPN and no error and no token code but result string present
// => interpretation of this cell during name-compilation and unknown names
@@ -1763,7 +1763,7 @@ void ScFormulaCell::InterpretTail( ScInterpretTailParameter eTailParam )
// condition further down.
if ( !pCode->GetLen() && !aResult.GetHybridFormula().isEmpty() )
{
- pCode->SetCodeError( errNoCode );
+ pCode->SetCodeError( FormulaError::NoCode );
// This is worth an assertion; if encountered in daily work
// documents we might need another solution. Or just confirm correctness.
OSL_FAIL( "ScFormulaCell::Interpret: no RPN, no error, no token, but hybrid formula string" );
@@ -1791,20 +1791,21 @@ void ScFormulaCell::InterpretTail( ScInterpretTailParameter eTailParam )
pDocument->IncInterpretLevel();
ScInterpreter* p = new ScInterpreter( this, pDocument, aPos, *pCode );
StackCleaner aStackCleaner( pDocument, p);
- sal_uInt16 nOldErrCode = aResult.GetResultError();
+ FormulaError nOldErrCode = aResult.GetResultError();
if ( nSeenInIteration == 0 )
{ // Only the first time
// With bChanged=false, if a newly compiled cell has a result of
// 0.0, no change is detected and the cell will not be repainted.
// bChanged = false;
- aResult.SetResultError( 0 );
+ aResult.SetResultError( FormulaError::NONE );
}
switch ( aResult.GetResultError() )
{
- case errCircularReference : // will be determined again if so
- aResult.SetResultError( 0 );
+ case FormulaError::CircularReference : // will be determined again if so
+ aResult.SetResultError( FormulaError::NONE );
break;
+ default: break;
}
bool bOldRunning = bRunning;
@@ -1823,20 +1824,20 @@ void ScFormulaCell::InterpretTail( ScInterpretTailParameter eTailParam )
bool bContentChanged = false;
// Do not create a HyperLink() cell if the formula results in an error.
- if( p->GetError() && pCode->IsHyperLink())
+ if( p->GetError() != FormulaError::NONE && pCode->IsHyperLink())
pCode->SetHyperLink(false);
- if( p->GetError() && p->GetError() != errCircularReference)
+ if( p->GetError() != FormulaError::NONE && p->GetError() != FormulaError::CircularReference)
{
bChanged = true;
- if (p->GetError() == errRetryCircular)
+ if (p->GetError() == FormulaError::RetryCircular)
{
// Array formula matrix calculation corner case. Keep dirty
// state, do not remove from formula tree or anything else, but
- // store errCircularReference in case this cell does not get
+ // store FormulaError::CircularReference in case this cell does not get
// recalculated.
- aResult.SetResultError( errCircularReference);
+ aResult.SetResultError( FormulaError::CircularReference);
return;
}
@@ -2068,7 +2069,7 @@ void ScFormulaCell::InterpretTail( ScInterpretTailParameter eTailParam )
}
// Precision as shown?
- if ( aResult.IsValue() && !p->GetError()
+ if ( aResult.IsValue() && p->GetError() == FormulaError::NONE
&& pDocument->GetDocOptions().IsCalcAsShown()
&& nFormatType != css::util::NumberFormat::DATE
&& nFormatType != css::util::NumberFormat::TIME
@@ -2092,7 +2093,7 @@ void ScFormulaCell::InterpretTail( ScInterpretTailParameter eTailParam )
if ( aResult.IsValue() && !::rtl::math::isFinite( aResult.GetDouble() ) )
{
// Coded double error may occur via filter import.
- sal_uInt16 nErr = GetDoubleErrorValue( aResult.GetDouble());
+ FormulaError nErr = GetDoubleErrorValue( aResult.GetDouble());
aResult.SetResultError( nErr);
bChanged = bContentChanged = true;
}
@@ -2162,7 +2163,7 @@ void ScFormulaCell::InterpretTail( ScInterpretTailParameter eTailParam )
else
{
// Cells with compiler errors should not be marked dirty forever
- OSL_ENSURE( pCode->GetCodeError(), "no RPN code und no errors ?!?!" );
+ OSL_ENSURE( pCode->GetCodeError() != FormulaError::NONE, "no RPN code and no errors ?!?!" );
ResetDirty();
}
}
@@ -2427,7 +2428,7 @@ void ScFormulaCell::SetResultMatrix( SCCOL nCols, SCROW nRows, const ScConstMatr
aResult.SetMatrix(nCols, nRows, pMat, pUL);
}
-void ScFormulaCell::SetErrCode( sal_uInt16 n )
+void ScFormulaCell::SetErrCode( FormulaError n )
{
/* FIXME: check the numerous places where ScTokenArray::GetCodeError() is
* used whether it is solely for transport of a simple result error and get
@@ -2439,7 +2440,7 @@ void ScFormulaCell::SetErrCode( sal_uInt16 n )
aResult.SetResultError( n );
}
-void ScFormulaCell::SetResultError( sal_uInt16 n )
+void ScFormulaCell::SetResultError( FormulaError n )
{
aResult.SetResultError( n );
}
@@ -2576,7 +2577,7 @@ bool ScFormulaCell::IsValue()
bool ScFormulaCell::IsValueNoError()
{
MaybeInterpret();
- if (pCode->GetCodeError())
+ if (pCode->GetCodeError() != FormulaError::NONE)
return false;
return aResult.IsValueNoError();
@@ -2588,7 +2589,7 @@ bool ScFormulaCell::IsValueNoError() const
// false if the cell is dirty & needs to be interpreted.
return false;
- if (pCode->GetCodeError())
+ if (pCode->GetCodeError() != FormulaError::NONE)
return false;
return aResult.IsValueNoError();
@@ -2602,8 +2603,8 @@ bool ScFormulaCell::IsHybridValueCell()
double ScFormulaCell::GetValue()
{
MaybeInterpret();
- if ((!pCode->GetCodeError() || pCode->GetCodeError() == errDoubleRef) &&
- !aResult.GetResultError())
+ if ((pCode->GetCodeError() == FormulaError::NONE || pCode->GetCodeError() == FormulaError::DoubleRef) &&
+ aResult.GetResultError() == FormulaError::NONE)
return aResult.GetDouble();
return 0.0;
}
@@ -2611,8 +2612,8 @@ double ScFormulaCell::GetValue()
svl::SharedString ScFormulaCell::GetString()
{
MaybeInterpret();
- if ((!pCode->GetCodeError() || pCode->GetCodeError() == errDoubleRef) &&
- !aResult.GetResultError())
+ if ((pCode->GetCodeError() == FormulaError::NONE || pCode->GetCodeError() == FormulaError::DoubleRef) &&
+ aResult.GetResultError() == FormulaError::NONE)
return aResult.GetString();
return svl::SharedString::getEmptyString();
@@ -2780,33 +2781,33 @@ sc::MatrixEdge ScFormulaCell::GetMatrixEdge( ScAddress& rOrgPos ) const
}
}
-sal_uInt16 ScFormulaCell::GetErrCode()
+FormulaError ScFormulaCell::GetErrCode()
{
MaybeInterpret();
/* FIXME: If ScTokenArray::SetCodeError() was really only for code errors
* and not also abused for signaling other error conditions we could bail
* out even before attempting to interpret broken code. */
- sal_uInt16 nErr = pCode->GetCodeError();
- if (nErr)
+ FormulaError nErr = pCode->GetCodeError();
+ if (nErr != FormulaError::NONE)
return nErr;
return aResult.GetResultError();
}
-sal_uInt16 ScFormulaCell::GetRawError()
+FormulaError ScFormulaCell::GetRawError()
{
- sal_uInt16 nErr = pCode->GetCodeError();
- if (nErr)
+ FormulaError nErr = pCode->GetCodeError();
+ if (nErr != FormulaError::NONE)
return nErr;
return aResult.GetResultError();
}
-bool ScFormulaCell::GetErrorOrValue( sal_uInt16& rErr, double& rVal )
+bool ScFormulaCell::GetErrorOrValue( FormulaError& rErr, double& rVal )
{
MaybeInterpret();
rErr = pCode->GetCodeError();
- if (rErr)
+ if (rErr != FormulaError::NONE)
return true;
return aResult.GetErrorOrDouble(rErr, rVal);
@@ -2816,8 +2817,8 @@ sc::FormulaResultValue ScFormulaCell::GetResult()
{
MaybeInterpret();
- sal_uInt16 nErr = pCode->GetCodeError();
- if (nErr)
+ FormulaError nErr = pCode->GetCodeError();
+ if (nErr != FormulaError::NONE)
return sc::FormulaResultValue(nErr);
return aResult.GetResult();
@@ -2825,8 +2826,8 @@ sc::FormulaResultValue ScFormulaCell::GetResult()
sc::FormulaResultValue ScFormulaCell::GetResult() const
{
- sal_uInt16 nErr = pCode->GetCodeError();
- if (nErr)
+ FormulaError nErr = pCode->GetCodeError();
+ if (nErr != FormulaError::NONE)
return sc::FormulaResultValue(nErr);
return aResult.GetResult();
@@ -3539,7 +3540,7 @@ void ScFormulaCell::UpdateCompile( bool bForceIfNameInUse )
if ( bForceIfNameInUse && !bCompile )
bCompile = pCode->HasNameOrColRowName();
if ( bCompile )
- pCode->SetCodeError( 0 ); // make sure it will really be compiled
+ pCode->SetCodeError( FormulaError::NONE ); // make sure it will really be compiled
CompileTokenArray();
}
diff --git a/sc/source/core/data/global.cxx b/sc/source/core/data/global.cxx
index 2605f9835788..9966874e313d 100644
--- a/sc/source/core/data/global.cxx
+++ b/sc/source/core/data/global.cxx
@@ -355,118 +355,111 @@ const OUString& ScGlobal::GetRscString( sal_uInt16 nIndex )
return *ppRscString[ nIndex ];
}
-OUString ScGlobal::GetErrorString(sal_uInt16 nErrNumber)
+OUString ScGlobal::GetErrorString(FormulaError nErr)
{
- OUString sResStr;
- switch (nErrNumber)
+ sal_uInt16 nErrNumber;
+ switch (nErr)
{
- case formula::NOTAVAILABLE : nErrNumber = STR_NV_STR; break;
- case formula::errNoRef : nErrNumber = STR_NO_REF_TABLE; break;
- case formula::errNoName : nErrNumber = STR_NO_NAME_REF; break;
- case formula::errNoAddin : nErrNumber = STR_NO_ADDIN; break;
- case formula::errNoMacro : nErrNumber = STR_NO_MACRO; break;
- case formula::errDoubleRef :
- case formula::errNoValue : nErrNumber = STR_NO_VALUE; break;
- case formula::errNoCode : nErrNumber = STR_NULL_ERROR; break;
- case formula::errDivisionByZero : nErrNumber = STR_DIV_ZERO; break;
- case formula::errIllegalFPOperation : nErrNumber = STR_NUM_ERROR; break;
-
- default : sResStr = GetRscString(STR_ERROR_STR) + OUString::number( nErrNumber );
- nErrNumber = 0;
- break;
+ case FormulaError::NotAvailable : nErrNumber = STR_NV_STR; break;
+ case FormulaError::NoRef : nErrNumber = STR_NO_REF_TABLE; break;
+ case FormulaError::NoName : nErrNumber = STR_NO_NAME_REF; break;
+ case FormulaError::NoAddin : nErrNumber = STR_NO_ADDIN; break;
+ case FormulaError::NoMacro : nErrNumber = STR_NO_MACRO; break;
+ case FormulaError::DoubleRef :
+ case FormulaError::NoValue : nErrNumber = STR_NO_VALUE; break;
+ case FormulaError::NoCode : nErrNumber = STR_NULL_ERROR; break;
+ case FormulaError::DivisionByZero : nErrNumber = STR_DIV_ZERO; break;
+ case FormulaError::IllegalFPOperation : nErrNumber = STR_NUM_ERROR; break;
+
+ default : return GetRscString(STR_ERROR_STR) + OUString::number( (int)nErr );
}
- if( nErrNumber )
- sResStr = GetRscString( nErrNumber );
- return sResStr;
+ return GetRscString( nErrNumber );
}
-OUString ScGlobal::GetLongErrorString(sal_uInt16 nErrNumber)
+OUString ScGlobal::GetLongErrorString(FormulaError nErr)
{
- switch (nErrNumber)
+ sal_uInt16 nErrNumber;
+ switch (nErr)
{
- case 0:
+ case FormulaError::NONE:
+ nErrNumber = 0;
break;
- case 1:
- case formula::errIllegalArgument:
+ case FormulaError::IllegalArgument:
nErrNumber = STR_LONG_ERR_ILL_ARG;
break;
- case 2:
- case 3:
- case 4:
- case 5:
- case formula::errIllegalFPOperation:
+ case FormulaError::IllegalFPOperation:
nErrNumber = STR_LONG_ERR_ILL_FPO;
break;
- case formula::errIllegalChar:
+ case FormulaError::IllegalChar:
nErrNumber = STR_LONG_ERR_ILL_CHAR;
break;
- case formula::errIllegalParameter:
+ case FormulaError::IllegalParameter:
nErrNumber = STR_LONG_ERR_ILL_PAR;
break;
- case formula::errSeparator:
+ case FormulaError::Separator:
nErrNumber = STR_LONG_ERR_ILL_SEP;
break;
- case formula::errPair:
- case formula::errPairExpected:
+ case FormulaError::Pair:
+ case FormulaError::PairExpected:
nErrNumber = STR_LONG_ERR_PAIR;
break;
- case formula::errOperatorExpected:
+ case FormulaError::OperatorExpected:
nErrNumber = STR_LONG_ERR_OP_EXP;
break;
- case formula::errVariableExpected:
- case formula::errParameterExpected:
+ case FormulaError::VariableExpected:
+ case FormulaError::ParameterExpected:
nErrNumber = STR_LONG_ERR_VAR_EXP;
break;
- case formula::errCodeOverflow:
+ case FormulaError::CodeOverflow:
nErrNumber = STR_LONG_ERR_CODE_OVF;
break;
- case formula::errStringOverflow:
+ case FormulaError::StringOverflow:
nErrNumber = STR_LONG_ERR_STR_OVF;
break;
- case formula::errStackOverflow:
+ case FormulaError::StackOverflow:
nErrNumber = STR_LONG_ERR_STACK_OVF;
break;
- case formula::errMatrixSize:
+ case FormulaError::MatrixSize:
nErrNumber = STR_LONG_ERR_MATRIX_SIZE;
break;
- case formula::errIllegalJump:
- case formula::errUnknownState:
- case formula::errUnknownVariable:
- case formula::errUnknownOpCode:
- case formula::errUnknownStackVariable:
- case formula::errUnknownToken:
- case formula::errNoCode:
- case formula::errDoubleRef:
+ case FormulaError::IllegalJump:
+ case FormulaError::UnknownState:
+ case FormulaError::UnknownVariable:
+ case FormulaError::UnknownOpCode:
+ case FormulaError::UnknownStackVariable:
+ case FormulaError::UnknownToken:
+ case FormulaError::NoCode:
+ case FormulaError::DoubleRef:
nErrNumber = STR_LONG_ERR_SYNTAX;
break;
- case formula::errCircularReference:
+ case FormulaError::CircularReference:
nErrNumber = STR_LONG_ERR_CIRC_REF;
break;
- case formula::errNoConvergence:
+ case FormulaError::NoConvergence:
nErrNumber = STR_LONG_ERR_NO_CONV;
break;
- case formula::errNoRef:
+ case FormulaError::NoRef:
nErrNumber = STR_LONG_ERR_NO_REF;
break;
- case formula::errNoName:
+ case FormulaError::NoName:
nErrNumber = STR_LONG_ERR_NO_NAME;
break;
- case formula::errNoAddin:
+ case FormulaError::NoAddin:
nErrNumber = STR_LONG_ERR_NO_ADDIN;
break;
- case formula::errNoMacro:
+ case FormulaError::NoMacro:
nErrNumber = STR_LONG_ERR_NO_MACRO;
break;
- case formula::errDivisionByZero:
+ case FormulaError::DivisionByZero:
nErrNumber = STR_LONG_ERR_DIV_ZERO;
break;
- case formula::errNestedArray:
+ case FormulaError::NestedArray:
nErrNumber = STR_ERR_LONG_NESTED_ARRAY;
break;
- case formula::errNoValue:
+ case FormulaError::NoValue:
nErrNumber = STR_LONG_ERR_NO_VALUE;
break;
- case formula::NOTAVAILABLE:
+ case FormulaError::NotAvailable:
nErrNumber = STR_LONG_ERR_NV;
break;
default:
diff --git a/sc/source/core/data/global2.cxx b/sc/source/core/data/global2.cxx
index 5be7bf0f9272..b4b189b60de7 100644
--- a/sc/source/core/data/global2.cxx
+++ b/sc/source/core/data/global2.cxx
@@ -378,14 +378,14 @@ bool isEmptyString( const OUString& rStr )
}
double ScGlobal::ConvertStringToValue( const OUString& rStr, const ScCalcConfig& rConfig,
- sal_uInt16 & rError, sal_uInt16 nStringNoValueError,
+ FormulaError & rError, FormulaError nStringNoValueError,
SvNumberFormatter* pFormatter, short & rCurFmtType )
{
// We keep ScCalcConfig::StringConversion::LOCALE default until
// we provide a friendly way to convert string numbers into numbers in the UI.
double fValue = 0.0;
- if (nStringNoValueError == formula::errCellNoValue)
+ if (nStringNoValueError == FormulaError::CellNoValue)
{
// Requested that all strings result in 0, error handled by caller.
rError = nStringNoValueError;
@@ -482,7 +482,7 @@ Label_fallback_to_unambiguous:
if (p < pStop && !rtl::isAsciiDigit(*p))
rError = nStringNoValueError;
p = pLastStart;
- while (p < pStop && !rError && eState < blank)
+ while (p < pStop && rError == FormulaError::NONE && eState < blank)
{
if (eState == minute)
rCurFmtType |= css::util::NumberFormat::TIME;
@@ -563,7 +563,7 @@ Label_fallback_to_unambiguous:
eState == hour || (eState == minute && p <= pLastStart))
rError = nStringNoValueError;
- if (!rError)
+ if (rError == FormulaError::NONE)
{
// Catch the very last unit at end of string.
if (p > pLastStart && eState < done)
@@ -574,7 +574,7 @@ Label_fallback_to_unambiguous:
}
if (bDate && nUnit[hour] > 23)
rError = nStringNoValueError;
- if (!rError)
+ if (rError == FormulaError::NONE)
{
if (bDate && nUnit[day] == 0)
nUnit[day] = 1;
@@ -611,7 +611,7 @@ Label_fallback_to_unambiguous:
default:
rError = nStringNoValueError;
}
- if (rError)
+ if (rError != FormulaError::NONE)
fValue = 0.0;
}
return fValue;
diff --git a/sc/source/core/data/simpleformulacalc.cxx b/sc/source/core/data/simpleformulacalc.cxx
index df2755f41280..6a64dcfd1c81 100644
--- a/sc/source/core/data/simpleformulacalc.cxx
+++ b/sc/source/core/data/simpleformulacalc.cxx
@@ -31,7 +31,7 @@ ScSimpleFormulaCalculator::ScSimpleFormulaCalculator( ScDocument* pDoc, const Sc
ScCompiler aComp(mpDoc, maAddr);
aComp.SetGrammar(eGram);
mpCode.reset(aComp.CompileString(rFormula));
- if(!mpCode->GetCodeError() && mpCode->GetLen())
+ if(mpCode->GetCodeError() == FormulaError::NONE && mpCode->GetLen())
aComp.CompileTokenArray();
}
@@ -99,12 +99,12 @@ bool ScSimpleFormulaCalculator::IsMatrix()
return mbMatrixResult;
}
-sal_uInt16 ScSimpleFormulaCalculator::GetErrCode()
+FormulaError ScSimpleFormulaCalculator::GetErrCode()
{
Calculate();
- sal_uInt16 nErr = mpCode->GetCodeError();
- if (nErr)
+ FormulaError nErr = mpCode->GetCodeError();
+ if (nErr != FormulaError::NONE)
return nErr;
return maResult.GetResultError();
}
@@ -113,8 +113,8 @@ double ScSimpleFormulaCalculator::GetValue()
{
Calculate();
- if ((!mpCode->GetCodeError() || mpCode->GetCodeError() == formula::errDoubleRef) &&
- !maResult.GetResultError())
+ if ((mpCode->GetCodeError() == FormulaError::NONE || mpCode->GetCodeError() == FormulaError::DoubleRef) &&
+ maResult.GetResultError() == FormulaError::NONE)
return maResult.GetDouble();
return 0.0;
@@ -127,8 +127,8 @@ svl::SharedString ScSimpleFormulaCalculator::GetString()
if (mbMatrixResult)
return svl::SharedString( maMatrixFormulaResult); // string not interned
- if ((!mpCode->GetCodeError() || mpCode->GetCodeError() == formula::errDoubleRef) &&
- !maResult.GetResultError())
+ if ((mpCode->GetCodeError() == FormulaError::NONE || mpCode->GetCodeError() == FormulaError::DoubleRef) &&
+ maResult.GetResultError() == FormulaError::NONE)
return maResult.GetString();
return svl::SharedString::getEmptyString();
diff --git a/sc/source/core/data/table2.cxx b/sc/source/core/data/table2.cxx
index ef1a0ce327ce..341eeea0b864 100644
--- a/sc/source/core/data/table2.cxx
+++ b/sc/source/core/data/table2.cxx
@@ -1815,7 +1815,7 @@ void ScTable::CompileXML( sc::CompileFormulaContext& rCxt, ScProgress& rProgress
mpCondFormatList->CompileXML();
}
-bool ScTable::CompileErrorCells( sc::CompileFormulaContext& rCxt, sal_uInt16 nErrCode )
+bool ScTable::CompileErrorCells( sc::CompileFormulaContext& rCxt, FormulaError nErrCode )
{
bool bCompiled = false;
for (SCCOL i = 0; i <= MAXCOL; ++i)
diff --git a/sc/source/core/data/table3.cxx b/sc/source/core/data/table3.cxx
index 355978ad19cc..158686e9fbcf 100644
--- a/sc/source/core/data/table3.cxx
+++ b/sc/source/core/data/table3.cxx
@@ -2267,7 +2267,7 @@ public:
if (!rCell.isEmpty())
{
- if (rCell.meType == CELLTYPE_FORMULA && rCell.mpFormula->GetErrCode())
+ if (rCell.meType == CELLTYPE_FORMULA && rCell.mpFormula->GetErrCode() != FormulaError::NONE)
// Error values are compared as string.
return false;
@@ -2392,7 +2392,7 @@ public:
if (!rCell.isEmpty())
{
- if (rCell.meType == CELLTYPE_FORMULA && rCell.mpFormula->GetErrCode())
+ if (rCell.meType == CELLTYPE_FORMULA && rCell.mpFormula->GetErrCode() != FormulaError::NONE)
{
// Error cell is evaluated as string (for now).
aCellStr = mrStrPool.intern(ScGlobal::GetErrorString(rCell.mpFormula->GetErrCode()));
@@ -2590,7 +2590,7 @@ public:
{
if (rItem.meType == ScQueryEntry::ByString)
{
- if (rCell.meType == CELLTYPE_FORMULA && rCell.mpFormula->GetErrCode())
+ if (rCell.meType == CELLTYPE_FORMULA && rCell.mpFormula->GetErrCode() != FormulaError::NONE)
// Error values are compared as string.
return std::pair<bool,bool>(false, bTestEqual);
diff --git a/sc/source/core/data/table4.cxx b/sc/source/core/data/table4.cxx
index 52df776be131..5ed7af8e19a2 100644
--- a/sc/source/core/data/table4.cxx
+++ b/sc/source/core/data/table4.cxx
@@ -1732,9 +1732,9 @@ void ScTable::FillSeries( SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2,
}
if (bError)
- aCol[nCol].SetError(static_cast<SCROW>(nRow), formula::errNoValue);
+ aCol[nCol].SetError(static_cast<SCROW>(nRow), FormulaError::NoValue);
else if (bOverflow)
- aCol[nCol].SetError(static_cast<SCROW>(nRow), formula::errIllegalFPOperation);
+ aCol[nCol].SetError(static_cast<SCROW>(nRow), FormulaError::IllegalFPOperation);
else
aCol[nCol].SetValue(static_cast<SCROW>(nRow), nVal);
}
@@ -1834,9 +1834,9 @@ void ScTable::FillSeries( SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2,
}
if (bError)
- aCol[nCol].SetError(static_cast<SCROW>(nRow), formula::errNoValue);
+ aCol[nCol].SetError(static_cast<SCROW>(nRow), FormulaError::NoValue);
else if (bOverflow)
- aCol[nCol].SetError(static_cast<SCROW>(nRow), formula::errIllegalFPOperation);
+ aCol[nCol].SetError(static_cast<SCROW>(nRow), FormulaError::IllegalFPOperation);
else
{
nStringValue = (sal_Int32)nVal;
@@ -2183,7 +2183,7 @@ void ScTable::GetAutoFormatData(SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol,
}
}
-void ScTable::SetError( SCCOL nCol, SCROW nRow, sal_uInt16 nError)
+void ScTable::SetError( SCCOL nCol, SCROW nRow, FormulaError nError)
{
if (ValidColRow(nCol, nRow))
aCol[nCol].SetError( nRow, nError );
diff --git a/sc/source/core/data/validat.cxx b/sc/source/core/data/validat.cxx
index 2a6f8c572b34..46971e08ac8e 100644
--- a/sc/source/core/data/validat.cxx
+++ b/sc/source/core/data/validat.cxx
@@ -645,8 +645,8 @@ bool ScValidationData::GetSelectionFromFormula(
// Use an interim matrix to create the TypedStrData below.
xMatRef = new ScFullMatrix(1, 1, 0.0);
- sal_uInt16 nErrCode = aValidationSrc.GetErrCode();
- if (nErrCode)
+ FormulaError nErrCode = aValidationSrc.GetErrCode();
+ if (nErrCode != FormulaError::NONE)
{
/* TODO : to use later in an alert box?
* OUString rStrResult = "...";
@@ -750,9 +750,9 @@ bool ScValidationData::GetSelectionFromFormula(
}
else
{
- sal_uInt16 nErr = nMatVal.GetError();
+ FormulaError nErr = nMatVal.GetError();
- if( 0 != nErr )
+ if( FormulaError::NONE != nErr )
{
aValStr = ScGlobal::GetErrorString( nErr );
}
diff --git a/sc/source/core/inc/doubleref.hxx b/sc/source/core/inc/doubleref.hxx
index da6bfa3f9117..b4a94897fa54 100644
--- a/sc/source/core/inc/doubleref.hxx
+++ b/sc/source/core/inc/doubleref.hxx
@@ -30,6 +30,7 @@
class ScDocument;
struct ScDBQueryParamBase;
struct ScQueryParamBase;
+enum class FormulaError : sal_uInt16;
/**
* Base class for abstracting range data backends for database functions.
@@ -71,7 +72,7 @@ public:
* @return 0-based column index
*/
virtual SCCOL findFieldColumn(SCCOL nIndex) const = 0;
- virtual SCCOL findFieldColumn(const OUString& rStr, sal_uInt16* pErr = nullptr) const = 0;
+ virtual SCCOL findFieldColumn(const OUString& rStr, FormulaError* pErr = nullptr) const = 0;
virtual std::unique_ptr<ScDBQueryParamBase> createQueryParam(const ScDBRangeBase* pQueryRef) const = 0;
virtual bool isRangeEqual(const ScRange& rRange) const = 0;
@@ -122,7 +123,7 @@ public:
* @return 0-based column index
*/
virtual SCCOL findFieldColumn(SCCOL nIndex) const override;
- virtual SCCOL findFieldColumn(const OUString& rStr, sal_uInt16* pErr = nullptr) const override;
+ virtual SCCOL findFieldColumn(const OUString& rStr, FormulaError* pErr = nullptr) const override;
virtual std::unique_ptr<ScDBQueryParamBase> createQueryParam(const ScDBRangeBase* pQueryRef) const override;
virtual bool isRangeEqual(const ScRange& rRange) const override;
@@ -162,7 +163,7 @@ public:
* @return 0-based column index
*/
virtual SCCOL findFieldColumn(SCCOL nIndex) const override;
- virtual SCCOL findFieldColumn(const OUString& rStr, sal_uInt16* pErr = nullptr) const override;
+ virtual SCCOL findFieldColumn(const OUString& rStr, FormulaError* pErr = nullptr) const override;
virtual std::unique_ptr<ScDBQueryParamBase> createQueryParam(const ScDBRangeBase* pQueryRef) const override;
virtual bool isRangeEqual(const ScRange& rRange) const override;
diff --git a/sc/source/core/inc/interpre.hxx b/sc/source/core/inc/interpre.hxx
index 296ad4be9b53..f4ea691457f1 100644
--- a/sc/source/core/inc/interpre.hxx
+++ b/sc/source/core/inc/interpre.hxx
@@ -157,7 +157,7 @@ public:
*/
static utl::SearchParam::SearchType DetectSearchType( const OUString& rStr, const ScDocument* pDoc );
- /// Fail safe division, returning an errDivisionByZero coded into a double
+ /// Fail safe division, returning an FormulaError::DivisionByZero coded into a double
/// if denominator is 0.0
static inline double div( const double& fNumerator, const double& fDenominator );
@@ -195,7 +195,7 @@ private:
pCur; // current token
ScTokenStack* pStackObj; // contains the stacks
const formula::FormulaToken ** pStack; // the current stack
- sal_uInt16 nGlobalError; // global (local to this formula expression) error
+ FormulaError nGlobalError; // global (local to this formula expression) error
sal_uInt16 sp; // stack pointer
sal_uInt16 maxsp; // the maximal used stack pointer
sal_uLong nFuncFmtIndex; // NumberFormatIndex of a function
@@ -204,7 +204,7 @@ private:
short nFuncFmtType; // NumberFormatType of a function
short nCurFmtType; // current NumberFormatType
short nRetFmtType; // NumberFormatType of an expression
- sal_uInt16 mnStringNoValueError; // the error set in ConvertStringToValue() if no value
+ FormulaError mnStringNoValueError; // the error set in ConvertStringToValue() if no value
sal_uInt16 mnSubTotalFlags; // flags for subtotal and aggregate functions
sal_uInt8 cPar; // current count of parameters
bool bCalcAsShown; // precision as shown
@@ -235,13 +235,13 @@ double ConvertStringToValue( const OUString& );
public:
/** For matrix back calls into the current interpreter.
Uses rError instead of nGlobalError and rCurFmtType instead of nCurFmtType. */
-double ConvertStringToValue( const OUString&, sal_uInt16& rError, short& rCurFmtType );
+double ConvertStringToValue( const OUString&, FormulaError& rError, short& rCurFmtType );
private:
double GetCellValue( const ScAddress&, ScRefCellValue& rCell );
double GetCellValueOrZero( const ScAddress&, ScRefCellValue& rCell );
double GetValueCellValue( const ScAddress&, double fOrig );
void GetCellString( svl::SharedString& rStr, ScRefCellValue& rCell );
-static sal_uInt16 GetCellErrCode( const ScRefCellValue& rCell );
+static FormulaError GetCellErrCode( const ScRefCellValue& rCell );
bool CreateDoubleArr(SCCOL nCol1, SCROW nRow1, SCTAB nTab1,
SCCOL nCol2, SCROW nRow2, SCTAB nTab2, sal_uInt8* pCellArr);
@@ -267,7 +267,7 @@ void PushWithoutError( const formula::FormulaToken& r );
Increments RefCount of the original token if not substituted.
ATTENTION! The token had to be allocated with `new' and must not be used
after this call if no RefCount was set because possibly it gets immediately
- deleted in case of an errStackOverflow or if substituted with formula::FormulaErrorToken! */
+ deleted in case of an FormulaError::StackOverflow or if substituted with formula::FormulaErrorToken! */
void PushTempToken( formula::FormulaToken* );
/** Pushes the token or substitutes with formula::FormulaErrorToken in case
@@ -280,7 +280,7 @@ void PushTokenRef( const formula::FormulaConstTokenRef& );
explicit formula::FormulaErrorToken. Increments RefCount.
ATTENTION! The token had to be allocated with `new' and must not be used
after this call if no RefCount was set because possibly it gets immediately
- decremented again and thus deleted in case of an errStackOverflow! */
+ decremented again and thus deleted in case of an FormulaError::StackOverflow! */
void PushTempTokenWithoutError( const formula::FormulaToken* );
/** If nGlobalError is set push formula::FormulaErrorToken.
@@ -289,7 +289,7 @@ void PushTempTokenWithoutError( const formula::FormulaToken* );
@return: <TRUE/> if nGlobalError. */
inline bool IfErrorPushError()
{
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushTempTokenWithoutError( new formula::FormulaErrorToken( nGlobalError));
return true;
@@ -395,7 +395,7 @@ void PushSingleRef( const ScRefAddress& rRef );
void PushDoubleRef( const ScRefAddress& rRef1, const ScRefAddress& rRef2 );
void PushMatrix( const sc::RangeMatrix& rMat );
void PushMatrix(const ScMatrixRef& pMat);
-void PushError( sal_uInt16 nError );
+void PushError( FormulaError nError );
/// Raw stack type without default replacements.
formula::StackVar GetRawStackType();
/// Stack type with replacement of defaults, e.g. svMissing and formula::svEmptyCell will result in formula::svDouble.
@@ -651,7 +651,7 @@ void ScExternal();
void ScMissing();
void ScMacro();
bool SetSbxVariable( SbxVariable* pVar, const ScAddress& );
-sal_uInt16 GetErrorType();
+FormulaError GetErrorType();
void ScErrorType();
void ScErrorType_ODF();
void ScDBArea();
@@ -689,9 +689,9 @@ void ScGetWeekOfYear();
void ScGetIsoWeekOfYear();
void ScWeeknumOOo();
void ScEasterSunday();
-sal_uInt16 GetWeekendAndHolidayMasks( const sal_uInt8 nParamCount, const sal_uInt32 nNullDate,
+FormulaError GetWeekendAndHolidayMasks( const sal_uInt8 nParamCount, const sal_uInt32 nNullDate,
::std::vector<double>& rSortArray, bool bWeekendMask[ 7 ] );
-sal_uInt16 GetWeekendAndHolidayMasks_MS( const sal_uInt8 nParamCount, const sal_uInt32 nNullDate,
+FormulaError GetWeekendAndHolidayMasks_MS( const sal_uInt8 nParamCount, const sal_uInt32 nNullDate,
::std::vector<double>& rSortArray, bool bWeekendMask[ 7 ], bool bWorkdayFunction );
static inline sal_Int16 GetDayOfWeek( sal_Int32 n );
void ScNetWorkdays( bool bOOXML_Version );
@@ -965,14 +965,14 @@ public:
formula::StackVar Interpret();
- void SetError(sal_uInt16 nError)
- { if (nError && !nGlobalError) nGlobalError = nError; }
+ void SetError(FormulaError nError)
+ { if (nError != FormulaError::NONE && nGlobalError == FormulaError::NONE) nGlobalError = nError; }
void AssertFormulaMatrix();
void SetLinkManager(sfx2::LinkManager* pLinkMgr)
{ mpLinkManager = pLinkMgr; }
- sal_uInt16 GetError() const { return nGlobalError; }
+ FormulaError GetError() const { return nGlobalError; }
formula::StackVar GetResultType() const { return xResult->GetType(); }
svl::SharedString GetStringResult() const;
double GetNumResult() const { return xResult->GetDouble(); }
@@ -1066,7 +1066,7 @@ inline bool ScInterpreter::CheckStringResultLen( OUString& rResult, const OUStri
{
if ( rResult.getLength() + rAdd.getLength() > SAL_MAX_UINT16 )
{
- SetError( formula::errStringOverflow );
+ SetError( FormulaError::StringOverflow );
rResult.clear();
return false;
}
@@ -1077,11 +1077,11 @@ inline void ScInterpreter::TreatDoubleError( double& rVal )
{
if ( !::rtl::math::isFinite( rVal ) )
{
- sal_uInt16 nErr = formula::GetDoubleErrorValue( rVal );
- if ( nErr )
+ FormulaError nErr = GetDoubleErrorValue( rVal );
+ if ( nErr != FormulaError::NONE )
SetError( nErr );
else
- SetError( formula::errNoValue );
+ SetError( FormulaError::NoValue );
rVal = 0.0;
}
}
diff --git a/sc/source/core/opencl/formulagroupcl.cxx b/sc/source/core/opencl/formulagroupcl.cxx
index e5f0a1ecc63f..862b73ab20ea 100644
--- a/sc/source/core/opencl/formulagroupcl.cxx
+++ b/sc/source/core/opencl/formulagroupcl.cxx
@@ -36,9 +36,9 @@
static const char* publicFunc =
"\n"
- "#define errIllegalFPOperation 503 // #NUM!\n"
- "#define errNoValue 519 // #VALUE!\n"
- "#define errDivisionByZero 532 // #DIV/0!\n"
+ "#define FormulaError::IllegalFPOperation 503 // #NUM!\n"
+ "#define FormulaError::NoValue 519 // #VALUE!\n"
+ "#define FormulaError::DivisionByZero 532 // #DIV/0!\n"
"#define NOTAVAILABLE 0x7fff // #N/A\n"
"\n"
"double CreateDoubleError(ulong nErr)\n"
@@ -51,9 +51,9 @@ static const char* publicFunc =
" if (isfinite(fVal))\n"
" return 0;\n"
" if (isinf(fVal))\n"
- " return errIllegalFPOperation; // normal INF\n"
+ " return FormulaError::IllegalFPOperation; // normal INF\n"
" if (as_ulong(fVal) & 0XFFFF0000u)\n"
- " return errNoValue; // just a normal NAN\n"
+ " return FormulaError::NoValue; // just a normal NAN\n"
" return (as_ulong(fVal) & 0XFFFF); // any other error\n"
"}\n"
"\n"
@@ -1763,7 +1763,7 @@ public:
if (isAverage())
ss <<
"if (nCount==0)\n"
- " return CreateDoubleError(errDivisionByZero);\n";
+ " return CreateDoubleError(FormulaError::DivisionByZero);\n";
else if (isMinOrMax())
ss <<
"if (nCount==0)\n"
@@ -2157,7 +2157,7 @@ public:
virtual std::string GetBottom() override { return "1.0"; }
virtual std::string Gen2( const std::string& lhs, const std::string& rhs ) const override
{
- return "(" + rhs + "==0 ? CreateDoubleError(errDivisionByZero) : (" + lhs + "/" + rhs + ") )";
+ return "(" + rhs + "==0 ? CreateDoubleError(FormulaError::DivisionByZero) : (" + lhs + "/" + rhs + ") )";
}
virtual std::string BinFuncName() const override { return "fdiv"; }
@@ -2167,7 +2167,7 @@ public:
{
ss <<
"if (isnan(" << vSubArguments[argno]->GenSlidingWindowDeclRef() << ")) {\n"
- " return CreateDoubleError(errDivisionByZero);\n"
+ " return CreateDoubleError(FormulaError::DivisionByZero);\n"
"}\n";
return true;
}
diff --git a/sc/source/core/opencl/op_statistical.cxx b/sc/source/core/opencl/op_statistical.cxx
index ebb35d4df08d..203b54810a0a 100644
--- a/sc/source/core/opencl/op_statistical.cxx
+++ b/sc/source/core/opencl/op_statistical.cxx
@@ -194,7 +194,7 @@ void OpVar::GenSlidingWindowFunction(std::stringstream &ss,
}
}
ss << " if (fCount <= 1.0)\n";
- ss << " return CreateDoubleError(errDivisionByZero);\n";
+ ss << " return CreateDoubleError(FormulaError::DivisionByZero);\n";
ss << " else\n";
ss << " return vSum * pow(fCount - 1.0,-1.0);\n";
ss << "}\n";
@@ -2657,7 +2657,7 @@ void OpSlope::GenSlidingWindowFunction(std::stringstream &ss,
ss << " }\n";
ss << " if (fCount < 1.0)\n";
- ss << " return CreateDoubleError(errNoValue);\n";
+ ss << " return CreateDoubleError(FormulaError::NoValue);\n";
ss << " else\n";
ss << " {\n";
ss << " fMeanX = fSumX * pow(fCount,-1.0);\n";
@@ -2701,7 +2701,7 @@ void OpSlope::GenSlidingWindowFunction(std::stringstream &ss,
ss << " fSumSqrDeltaX += (argX-fMeanX) * (argX-fMeanX);\n";
ss << " }\n";
ss << " if(fSumSqrDeltaX == 0.0)\n";
- ss << " return CreateDoubleError(errDivisionByZero);\n";
+ ss << " return CreateDoubleError(FormulaError::DivisionByZero);\n";
ss << " else\n";
ss << " {\n";
ss << " return fSumDeltaXDeltaY*pow(fSumSqrDeltaX,-1.0);\n";
@@ -3321,7 +3321,7 @@ void OpPearson::GenSlidingWindowFunction(
ss << " double tmp = ( fSumDeltaXDeltaY / ";
ss << "sqrt( fSumX * fSumY));\n\t";
ss << " if (isnan(tmp))\n";
- ss << " return CreateDoubleError(errNoValue);\n";
+ ss << " return CreateDoubleError(FormulaError::NoValue);\n";
ss << " return tmp;\n";
ss << "}\n";
}
@@ -4738,7 +4738,7 @@ void OpNormsinv:: GenSlidingWindowFunction
ss << "z = q < 0.0 ? (-1)*z : z;\n";
ss <<"}\n";
ss <<"if (isnan(z))\n";
- ss <<" return CreateDoubleError(errNoValue);\n";
+ ss <<" return CreateDoubleError(FormulaError::NoValue);\n";
ss <<"return z;\n";
ss <<"}\n";
}
@@ -7012,7 +7012,7 @@ void OpCovar::GenSlidingWindowFunction(std::stringstream& ss,
ss << " }\n";
}
ss << " if(cnt < 1) {\n";
- ss << " return CreateDoubleError(errNoValue);\n";
+ ss << " return CreateDoubleError(FormulaError::NoValue);\n";
ss << " }\n";
ss << " else {\n";
ss << " vMean0 = vSum0 / cnt;\n";
diff --git a/sc/source/core/tool/addincol.cxx b/sc/source/core/tool/addincol.cxx
index 4d5fd7497f1a..15c4e92bfb27 100644
--- a/sc/source/core/tool/addincol.cxx
+++ b/sc/source/core/tool/addincol.cxx
@@ -1298,7 +1298,7 @@ bool ScUnoAddInCollection::FillFunctionDescFromData( const ScUnoAddInFuncData& r
ScUnoAddInCall::ScUnoAddInCall( ScUnoAddInCollection& rColl, const OUString& rName,
long nParamCount ) :
bValidCount( false ),
- nErrCode( formula::errNoCode ), // before function was called
+ nErrCode( FormulaError::NoCode ), // before function was called
bHasString( true ),
fValue( 0.0 ),
xMatrix( nullptr )
@@ -1464,7 +1464,7 @@ void ScUnoAddInCall::ExecuteCallWithArgs(uno::Sequence<uno::Any>& rCallArgs)
if ( xFunction.is() )
{
uno::Any aAny;
- nErrCode = 0;
+ nErrCode = FormulaError::NONE;
try
{
@@ -1472,34 +1472,32 @@ void ScUnoAddInCall::ExecuteCallWithArgs(uno::Sequence<uno::Any>& rCallArgs)
}
catch(lang::IllegalArgumentException&)
{
- nErrCode = formula::errIllegalArgument;
+ nErrCode = FormulaError::IllegalArgument;
}
-
catch(const reflection::InvocationTargetException& rWrapped)
{
if ( rWrapped.TargetException.getValueType().equals(
cppu::UnoType<lang::IllegalArgumentException>::get()) )
- nErrCode = formula::errIllegalArgument;
+ nErrCode = FormulaError::IllegalArgument;
else if ( rWrapped.TargetException.getValueType().equals(
cppu::UnoType<sheet::NoConvergenceException>::get()) )
- nErrCode = formula::errNoConvergence;
+ nErrCode = FormulaError::NoConvergence;
else
- nErrCode = formula::errNoValue;
+ nErrCode = FormulaError::NoValue;
}
-
catch(uno::Exception&)
{
- nErrCode = formula::errNoValue;
+ nErrCode = FormulaError::NoValue;
}
- if (!nErrCode)
+ if (nErrCode == FormulaError::NONE)
SetResult( aAny ); // convert result to Calc types
}
}
void ScUnoAddInCall::SetResult( const uno::Any& rNewRes )
{
- nErrCode = 0;
+ nErrCode = FormulaError::NONE;
xVarRes = nullptr;
// Reflection* pRefl = rNewRes.getReflection();
@@ -1509,7 +1507,7 @@ void ScUnoAddInCall::SetResult( const uno::Any& rNewRes )
switch (eClass)
{
case uno::TypeClass_VOID:
- nErrCode = formula::NOTAVAILABLE; // #NA
+ nErrCode = FormulaError::NotAvailable; // #NA
break;
case uno::TypeClass_ENUM:
@@ -1545,7 +1543,7 @@ void ScUnoAddInCall::SetResult( const uno::Any& rNewRes )
xVarRes.set( xInterface, uno::UNO_QUERY );
if (!xVarRes.is())
- nErrCode = formula::errNoValue; // unknown interface
+ nErrCode = FormulaError::NoValue; // unknown interface
}
break;
@@ -1683,7 +1681,7 @@ void ScUnoAddInCall::SetResult( const uno::Any& rNewRes )
}
if (!xMatrix) // no array found
- nErrCode = formula::errNoValue; //TODO: code for error in return type???
+ nErrCode = FormulaError::NoValue; //TODO: code for error in return type???
}
}
diff --git a/sc/source/core/tool/cellform.cxx b/sc/source/core/tool/cellform.cxx
index 38bf70ff5d88..0507d7c17abf 100644
--- a/sc/source/core/tool/cellform.cxx
+++ b/sc/source/core/tool/cellform.cxx
@@ -94,9 +94,9 @@ void ScCellFormat::GetString( ScRefCellValue& rCell, sal_uLong nFormat, OUString
}
else
{
- sal_uInt16 nErrCode = pFCell->GetErrCode();
+ FormulaError nErrCode = pFCell->GetErrCode();
- if (nErrCode != 0)
+ if (nErrCode != FormulaError::NONE)
rString = ScGlobal::GetErrorString(nErrCode);
else if ( pFCell->IsEmptyDisplayedAsString() )
rString.clear();
@@ -160,8 +160,8 @@ void ScCellFormat::GetInputString(
else
aString = pFC->GetString().getString();
- sal_uInt16 nErrCode = pFC->GetErrCode();
- if (nErrCode != 0)
+ FormulaError nErrCode = pFC->GetErrCode();
+ if (nErrCode != FormulaError::NONE)
aString = EMPTY_OUSTRING;
}
break;
diff --git a/sc/source/core/tool/chartarr.cxx b/sc/source/core/tool/chartarr.cxx
index e373b3b93cee..1cc85fdb7aa0 100644
--- a/sc/source/core/tool/chartarr.cxx
+++ b/sc/source/core/tool/chartarr.cxx
@@ -32,6 +32,7 @@
#include <comphelper/stl_types.hxx>
#include <o3tl/make_unique.hxx>
+#include <formula/errorcodes.hxx>
#include <vector>
@@ -122,7 +123,7 @@ double getCellValue( ScDocument& rDoc, const ScAddress& rPos, double fDefault, b
case CELLTYPE_FORMULA:
{
ScFormulaCell* pFCell = aCell.mpFormula;
- if (pFCell && !pFCell->GetErrCode() && pFCell->IsValue())
+ if (pFCell && pFCell->GetErrCode() == FormulaError::NONE && pFCell->IsValue())
fRet = pFCell->GetValue();
}
break;
diff --git a/sc/source/core/tool/compiler.cxx b/sc/source/core/tool/compiler.cxx
index 2a49e899b63b..488c893c9842 100644
--- a/sc/source/core/tool/compiler.cxx
+++ b/sc/source/core/tool/compiler.cxx
@@ -1903,9 +1903,9 @@ void ScCompiler::SetRefConvention( const ScCompiler::Convention *pConvP )
"ScCompiler::SetRefConvention: unsupported grammar resulting");
}
-void ScCompiler::SetError(sal_uInt16 nError)
+void ScCompiler::SetError(FormulaError nError)
{
- if( !pArr->GetCodeError() )
+ if( pArr->GetCodeError() == FormulaError::NONE)
pArr->SetCodeError( nError);
}
@@ -2158,7 +2158,7 @@ Label_MaskStateMachine:
{ // This catches also $Sheet1.A$1, for example.
if( pSym == &cSymbol[ MAXSTRLEN-1 ] )
{
- SetError(errStringOverflow);
+ SetError(FormulaError::StringOverflow);
eState = ssStop;
}
else
@@ -2178,7 +2178,7 @@ Label_MaskStateMachine:
{
if( pSym == &cSymbol[ MAXSTRLEN-1 ] )
{
- SetError(errStringOverflow);
+ SetError(FormulaError::StringOverflow);
eState = ssStop;
break; // for
}
@@ -2198,7 +2198,7 @@ Label_MaskStateMachine:
mnRangeOpPosInSymbol = pSym - &cSymbol[0];
if( pSym == &cSymbol[ MAXSTRLEN-1 ] )
{
- SetError(errStringOverflow);
+ SetError(FormulaError::StringOverflow);
eState = ssStop;
}
else
@@ -2236,7 +2236,7 @@ Label_MaskStateMachine:
{
if( pSym == &cSymbol[ MAXSTRLEN-1 ] )
{
- SetError(errStringOverflow);
+ SetError(FormulaError::StringOverflow);
eState = ssStop;
}
else if (c == cDecSep)
@@ -2307,7 +2307,7 @@ Label_MaskStateMachine:
{
if( pSym == &cSymbol[ MAXSTRLEN-1 ] )
{
- SetError(errStringOverflow);
+ SetError(FormulaError::StringOverflow);
eState = ssSkipString;
}
else
@@ -2365,7 +2365,7 @@ Label_MaskStateMachine:
{
if (pSym == &cSymbol[ MAXSTRLEN-1 ])
{
- SetError( errStringOverflow);
+ SetError( FormulaError::StringOverflow);
eState = ssStop;
}
else
@@ -2380,7 +2380,7 @@ Label_MaskStateMachine:
{
if( pSym == &cSymbol[ MAXSTRLEN-1 ] )
{
- SetError( errStringOverflow);
+ SetError( FormulaError::StringOverflow);
eState = ssStop;
}
else
@@ -2400,7 +2400,7 @@ Label_MaskStateMachine:
{
if( pSym == &cSymbol[ MAXSTRLEN-1 ] )
{
- SetError( errStringOverflow);
+ SetError( FormulaError::StringOverflow);
eState = ssStop;
}
else
@@ -2416,7 +2416,7 @@ Label_MaskStateMachine:
case ssGetReference:
if( pSym == &cSymbol[ MAXSTRLEN-1 ] )
{
- SetError( errStringOverflow);
+ SetError( FormulaError::StringOverflow);
eState = ssSkipReference;
}
SAL_FALLTHROUGH;
@@ -2597,7 +2597,7 @@ Label_MaskStateMachine:
nSrcPos = nSrcPos + nSpaces;
OUStringBuffer aSymbol;
mnRangeOpPosInSymbol = -1;
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
do
{
bi18n = false;
@@ -2608,10 +2608,10 @@ Label_MaskStateMachine:
ParseResult aRes = pConv->parseAnyToken( aFormula, nSrcPos, pCharClass );
if ( !aRes.TokenType )
- SetError( nErr = errIllegalChar ); // parsed chars as string
+ SetError( nErr = FormulaError::IllegalChar ); // parsed chars as string
if ( aRes.EndPos <= nSrcPos )
{ // ?!?
- SetError( nErr = errIllegalChar );
+ SetError( nErr = FormulaError::IllegalChar );
nSrcPos = aFormula.getLength();
aSymbol.truncate();
}
@@ -2645,11 +2645,11 @@ Label_MaskStateMachine:
if ( bi18n )
aSymbol.append(pStart[nSrcPos++]);
}
- } while ( bi18n && !nErr );
+ } while ( bi18n && nErr == FormulaError::NONE );
sal_Int32 nLen = aSymbol.getLength();
if ( nLen >= MAXSTRLEN )
{
- SetError( errStringOverflow );
+ SetError( FormulaError::StringOverflow );
nLen = MAXSTRLEN-1;
}
lcl_UnicodeStrNCpy( cSymbol, aSymbol.getStr(), nLen );
@@ -2926,7 +2926,7 @@ bool ScCompiler::IsValue( const OUString& rSym )
return false;
}
if (eStatus == rtl_math_ConversionStatus_OutOfRange)
- SetError( errIllegalArgument );
+ SetError( FormulaError::IllegalArgument );
maRawToken.SetDouble( fVal );
return true;
}
@@ -2955,7 +2955,7 @@ bool ScCompiler::IsValue( const OUString& rSym )
if( nType == css::util::NumberFormat::TEXT )
// HACK: number too big!
- SetError( errIllegalArgument );
+ SetError( FormulaError::IllegalArgument );
maRawToken.SetDouble( fVal );
return true;
}
@@ -2969,7 +2969,7 @@ bool ScCompiler::IsString()
bool bQuote = ((cSymbol[0] == '"') && (cSymbol[nLen] == '"'));
if ((bQuote ? nLen-2 : nLen) > MAXSTRLEN-1)
{
- SetError(errStringOverflow);
+ SetError(FormulaError::StringOverflow);
return false;
}
if ( bQuote )
@@ -3693,8 +3693,8 @@ bool ScCompiler::IsBoolean( const OUString& rName )
bool ScCompiler::IsErrorConstant( const OUString& rName ) const
{
- sal_uInt16 nError = GetErrorConstant( rName);
- if (nError)
+ FormulaError nError = GetErrorConstant( rName);
+ if (nError != FormulaError::NONE)
{
maRawToken.SetErrorConstant( nError);
return true;
@@ -4078,7 +4078,7 @@ bool ScCompiler::NextNewToken( bool bInArray )
aToken.sbyte.cByte = (sal_uInt8) ( nSpaces > 255 ? 255 : nSpaces );
if( !static_cast<ScTokenArray*>(pArr)->AddRawToken( aToken ) )
{
- SetError(errCodeOverflow);
+ SetError(FormulaError::CodeOverflow);
return false;
}
}
@@ -4276,7 +4276,7 @@ bool ScCompiler::NextNewToken( bool bInArray )
if ( meExtendedErrorDetection != EXTENDED_ERROR_DETECTION_NONE )
{
// set an error
- SetError( errNoName );
+ SetError( FormulaError::NoName );
if (meExtendedErrorDetection == EXTENDED_ERROR_DETECTION_NAME_BREAK)
return false; // end compilation
}
@@ -4400,7 +4400,7 @@ ScTokenArray* ScCompiler::CompileString( const OUString& rFormula )
{
if( !nBrackets )
{
- SetError( errPairExpected );
+ SetError( FormulaError::PairExpected );
if ( bAutoCorrect )
{
bCorrected = true;
@@ -4422,7 +4422,7 @@ ScTokenArray* ScCompiler::CompileString( const OUString& rFormula )
case ocArrayOpen:
{
if( bInArray )
- SetError( errNestedArray );
+ SetError( FormulaError::NestedArray );
else
bInArray = true;
// Don't count following column separator as parameter separator.
@@ -4442,7 +4442,7 @@ ScTokenArray* ScCompiler::CompileString( const OUString& rFormula )
}
else
{
- SetError( errPairExpected );
+ SetError( FormulaError::PairExpected );
if ( bAutoCorrect )
{
bCorrected = true;
@@ -4489,7 +4489,7 @@ ScTokenArray* ScCompiler::CompileString( const OUString& rFormula )
// args so the correction dialog can do better?
if ( !static_cast<ScTokenArray*>(pArr)->Add( new FormulaMissingToken ) )
{
- SetError(errCodeOverflow); break;
+ SetError(FormulaError::CodeOverflow); break;
}
}
if (bOOXML)
@@ -4504,7 +4504,7 @@ ScTokenArray* ScCompiler::CompileString( const OUString& rFormula )
if ( !static_cast<ScTokenArray*>(pArr)->Add( new FormulaToken( svSep, ocSep)) ||
!static_cast<ScTokenArray*>(pArr)->Add( new FormulaDoubleToken( 1.0)))
{
- SetError(errCodeOverflow); break;
+ SetError(FormulaError::CodeOverflow); break;
}
}
}
@@ -4520,7 +4520,7 @@ ScTokenArray* ScCompiler::CompileString( const OUString& rFormula )
if ( !static_cast<ScTokenArray*>(pArr)->Add( new FormulaToken( svSep, ocSep)) ||
!static_cast<ScTokenArray*>(pArr)->Add( new FormulaDoubleToken( 1.0)))
{
- SetError(errCodeOverflow); break;
+ SetError(FormulaError::CodeOverflow); break;
}
++pFunctionStack[ nFunction ].nSep;
}
@@ -4528,7 +4528,7 @@ ScTokenArray* ScCompiler::CompileString( const OUString& rFormula )
FormulaToken* pNewToken = static_cast<ScTokenArray*>(pArr)->Add( maRawToken.CreateToken());
if (!pNewToken)
{
- SetError(errCodeOverflow);
+ SetError(FormulaError::CodeOverflow);
break;
}
else if (eLastOp == ocRange && pNewToken->GetOpCode() == ocPush && pNewToken->GetType() == svSingleRef)
@@ -4553,14 +4553,14 @@ ScTokenArray* ScCompiler::CompileString( const OUString& rFormula )
case ocTableRefOpen:
SAL_WARN_IF( maTableRefs.empty(), "sc.core", "ocTableRefOpen without TableRefEntry");
if (maTableRefs.empty())
- SetError(errPair);
+ SetError(FormulaError::Pair);
else
++maTableRefs.back().mnLevel;
break;
case ocTableRefClose:
SAL_WARN_IF( maTableRefs.empty(), "sc.core", "ocTableRefClose without TableRefEntry");
if (maTableRefs.empty())
- SetError(errPair);
+ SetError(FormulaError::Pair);
else
{
if (--maTableRefs.back().mnLevel == 0)
@@ -4581,7 +4581,7 @@ ScTokenArray* ScCompiler::CompileString( const OUString& rFormula )
FormulaByteToken aToken( ocArrayClose );
if( !pArr->AddToken( aToken ) )
{
- SetError(errCodeOverflow);
+ SetError(FormulaError::CodeOverflow);
}
else if ( bAutoCorrect )
aCorrectedFormula += mxSymbols->getSymbol(ocArrayClose);
@@ -4594,7 +4594,7 @@ ScTokenArray* ScCompiler::CompileString( const OUString& rFormula )
{
if( !pArr->AddToken( aToken ) )
{
- SetError(errCodeOverflow);
+ SetError(FormulaError::CodeOverflow);
break; // while
}
if ( bAutoCorrect )
@@ -4662,9 +4662,9 @@ bool ScCompiler::HandleRange()
const ScRangeData* pRangeData = GetRangeData( *mpToken);
if (pRangeData)
{
- sal_uInt16 nErr = pRangeData->GetErrCode();
- if( nErr )
- SetError( errNoName );
+ FormulaError nErr = pRangeData->GetErrCode();
+ if( nErr != FormulaError::NONE )
+ SetError( FormulaError::NoName );
else if (mbJumpCommandReorder)
{
ScTokenArray* pNew;
@@ -4716,7 +4716,7 @@ bool ScCompiler::HandleRange()
}
}
else
- SetError(errNoName);
+ SetError(FormulaError::NoName);
return true;
}
@@ -4734,7 +4734,7 @@ bool ScCompiler::HandleExternalReference(const FormulaToken& _aToken)
const OUString* pFile = pRefMgr->getExternalFileName(_aToken.GetIndex());
if (!pFile)
{
- SetError(errNoName);
+ SetError(FormulaError::NoName);
return true;
}
@@ -4744,7 +4744,7 @@ bool ScCompiler::HandleExternalReference(const FormulaToken& _aToken)
if (!xNew)
{
- SetError(errNoName);
+ SetError(FormulaError::NoName);
return true;
}
@@ -4923,8 +4923,8 @@ void ScCompiler::CreateStringFromMatrix( OUStringBuffer& rBuffer, const FormulaT
AppendBoolean(rBuffer, pMatrix->GetDouble(nC, nR) != 0.0);
else
{
- sal_uInt16 nErr = pMatrix->GetError(nC, nR);
- if (nErr)
+ FormulaError nErr = pMatrix->GetError(nC, nR);
+ if (nErr != FormulaError::NONE)
rBuffer.append(ScGlobal::GetErrorString(nErr));
else
AppendDouble(rBuffer, pMatrix->GetDouble(nC, nR));
@@ -5072,12 +5072,12 @@ void ScCompiler::CreateStringFromIndex( OUStringBuffer& rBuffer, const FormulaTo
// Write the resulting reference if TableRef is not supported.
const ScTableRefToken* pTR = dynamic_cast<const ScTableRefToken*>(_pTokenP);
if (!pTR)
- AppendErrorConstant( aBuffer, errNoCode);
+ AppendErrorConstant( aBuffer, FormulaError::NoCode);
else
{
const FormulaToken* pRef = pTR->GetAreaRefRPN();
if (!pRef)
- AppendErrorConstant( aBuffer, errNoCode);
+ AppendErrorConstant( aBuffer, FormulaError::NoCode);
else
{
switch (pRef->GetType())
@@ -5092,7 +5092,7 @@ void ScCompiler::CreateStringFromIndex( OUStringBuffer& rBuffer, const FormulaTo
AppendErrorConstant( aBuffer, pRef->GetError());
break;
default:
- AppendErrorConstant( aBuffer, errNoCode);
+ AppendErrorConstant( aBuffer, FormulaError::NoCode);
}
}
}
@@ -5184,7 +5184,7 @@ bool ScCompiler::HandleColRowName()
const ScAddress aAbs = rRef.toAbs(aPos);
if (!ValidAddress(aAbs))
{
- SetError( errNoRef );
+ SetError( FormulaError::NoRef );
return true;
}
SCCOL nCol = aAbs.Col();
@@ -5343,7 +5343,7 @@ bool ScCompiler::HandleColRowName()
bFound = true;
}
if ( !bFound )
- SetError(errNoRef);
+ SetError(FormulaError::NoRef);
else if (mbJumpCommandReorder)
{
ScTokenArray* pNew = new ScTokenArray();
@@ -5386,7 +5386,7 @@ bool ScCompiler::HandleColRowName()
}
}
else
- SetError(errNoName);
+ SetError(FormulaError::NoName);
return true;
}
@@ -5394,7 +5394,7 @@ bool ScCompiler::HandleDbData()
{
ScDBData* pDBData = pDoc->GetDBCollection()->getNamedDBs().findByIndex(mpToken->GetIndex());
if ( !pDBData )
- SetError(errNoName);
+ SetError(FormulaError::NoName);
else if (mbJumpCommandReorder)
{
ScComplexRefData aRefData;
@@ -5433,20 +5433,20 @@ bool ScCompiler::HandleTableRef()
ScTableRefToken* pTR = dynamic_cast<ScTableRefToken*>(mpToken.get());
if (!pTR)
{
- SetError(errUnknownToken);
+ SetError(FormulaError::UnknownToken);
return true;
}
ScDBData* pDBData = pDoc->GetDBCollection()->getNamedDBs().findByIndex( pTR->GetIndex());
if ( !pDBData )
- SetError(errNoName);
+ SetError(FormulaError::NoName);
else if (mbJumpCommandReorder)
{
ScRange aDBRange;
pDBData->GetArea(aDBRange);
aDBRange.aEnd.SetTab(aDBRange.aStart.Tab());
ScRange aRange( aDBRange);
- sal_uInt16 nError = 0;
+ FormulaError nError = FormulaError::NONE;
bool bForwardToClose = false;
ScTableRefToken::Item eItem = pTR->GetItem();
switch (eItem)
@@ -5460,7 +5460,7 @@ bool ScCompiler::HandleTableRef()
if (pDBData->HasTotals())
aRange.aEnd.IncRow(-1);
if (aRange.aEnd.Row() < aRange.aStart.Row())
- nError = errNoRef;
+ nError = FormulaError::NoRef;
bForwardToClose = true;
}
break;
@@ -5474,7 +5474,7 @@ bool ScCompiler::HandleTableRef()
if (pDBData->HasHeader())
aRange.aEnd.SetRow( aRange.aStart.Row());
else
- nError = errNoRef;
+ nError = FormulaError::NoRef;
bForwardToClose = true;
}
break;
@@ -5489,7 +5489,7 @@ bool ScCompiler::HandleTableRef()
if (pDBData->HasTotals())
aRange.aEnd.IncRow(-1);
if (aRange.aEnd.Row() < aRange.aStart.Row())
- nError = errNoRef;
+ nError = FormulaError::NoRef;
bForwardToClose = true;
}
break;
@@ -5498,7 +5498,7 @@ bool ScCompiler::HandleTableRef()
if (pDBData->HasTotals())
aRange.aStart.SetRow( aRange.aEnd.Row());
else
- nError = errNoRef;
+ nError = FormulaError::NoRef;
bForwardToClose = true;
}
break;
@@ -5507,7 +5507,7 @@ bool ScCompiler::HandleTableRef()
if (pDBData->HasHeader())
aRange.aStart.IncRow();
if (aRange.aEnd.Row() < aRange.aStart.Row())
- nError = errNoRef;
+ nError = FormulaError::NoRef;
bForwardToClose = true;
}
break;
@@ -5520,7 +5520,7 @@ bool ScCompiler::HandleTableRef()
}
else
{
- nError = errNoValue;
+ nError = FormulaError::NoValue;
// For *some* relative row reference in named
// expressions' thisrow special handling below.
aRange.aEnd.SetRow( aRange.aStart.Row());
@@ -5560,7 +5560,7 @@ bool ScCompiler::HandleTableRef()
eState = ((eState == sOpen || eState == sSep) ? sOpen : sStop);
if (++nLevel > 2)
{
- SetError( errPair);
+ SetError( FormulaError::Pair);
eState = sStop;
}
break;
@@ -5594,8 +5594,8 @@ bool ScCompiler::HandleTableRef()
break;
case ocBad:
eState = sLast;
- if (!nError)
- nError = errNoName;
+ if (nError == FormulaError::NONE)
+ nError = FormulaError::NoName;
break;
default:
eState = sStop;
@@ -5608,9 +5608,9 @@ bool ScCompiler::HandleTableRef()
} while (eState != sStop);
}
ScTokenArray* pNew = new ScTokenArray();
- if (!nError || nError == errNoValue)
+ if (nError == FormulaError::NONE || nError == FormulaError::NoValue)
{
- // The errNoValue case generates a thisrow reference that can be
+ // The FormulaError::NoValue case generates a thisrow reference that can be
// used to save named expressions in A1 syntax notation.
if (bColumnRange)
{
@@ -5664,7 +5664,7 @@ bool ScCompiler::HandleTableRef()
}
aRefData.SetRelName( bCol1RelName);
aRefData.SetFlag3D( true);
- if (nError)
+ if (nError != FormulaError::NONE)
{
aRefData.SetAddress( aRange.aStart, aRange.aStart);
pTR->SetAreaRefRPN( new ScSingleRefToken( aRefData)); // set reference at TableRef
@@ -5693,7 +5693,7 @@ bool ScCompiler::HandleTableRef()
aRefData.Ref1.SetRelName( bRelName);
aRefData.Ref2.SetRelName( bRelName);
aRefData.Ref1.SetFlag3D( true);
- if (nError)
+ if (nError != FormulaError::NONE)
{
aRefData.SetRange( aRange, aRange.aStart);
pTR->SetAreaRefRPN( new ScDoubleRefToken( aRefData)); // set reference at TableRef
@@ -5708,7 +5708,7 @@ bool ScCompiler::HandleTableRef()
}
else
{
- pTR->SetAreaRefRPN( pNew->Add( new FormulaErrorToken( errNoRef)));
+ pTR->SetAreaRefRPN( pNew->Add( new FormulaErrorToken( FormulaError::NoRef)));
}
}
else
@@ -5718,7 +5718,7 @@ bool ScCompiler::HandleTableRef()
while (nLevel-- > 0)
{
if (!GetTokenIfOpCode( ocTableRefClose))
- SetError( errPair);
+ SetError( FormulaError::Pair);
}
PushTokenArray( pNew, true );
pNew->Reset();
diff --git a/sc/source/core/tool/consoli.cxx b/sc/source/core/tool/consoli.cxx
index 67bf01d4ad07..651e14ed0551 100644
--- a/sc/source/core/tool/consoli.cxx
+++ b/sc/source/core/tool/consoli.cxx
@@ -662,7 +662,7 @@ void ScConsData::OutputToDocument( ScDocument* pDestDoc, SCCOL nCol, SCROW nRow,
ppSumSqr[nArrX][nArrY]);
if (ppCount[nArrX][nArrY] < 0.0)
pDestDoc->SetError( sal::static_int_cast<SCCOL>(nCol+nArrX),
- sal::static_int_cast<SCROW>(nRow+nArrY), nTab, formula::errNoValue );
+ sal::static_int_cast<SCROW>(nRow+nArrY), nTab, FormulaError::NoValue );
else
pDestDoc->SetValue( sal::static_int_cast<SCCOL>(nCol+nArrX),
sal::static_int_cast<SCROW>(nRow+nArrY), nTab, fVal );
diff --git a/sc/source/core/tool/detfunc.cxx b/sc/source/core/tool/detfunc.cxx
index 9e3a2c94833c..bec278847141 100644
--- a/sc/source/core/tool/detfunc.cxx
+++ b/sc/source/core/tool/detfunc.cxx
@@ -21,6 +21,7 @@
#include <svtools/colorcfg.hxx>
#include <editeng/eeitem.hxx>
#include <editeng/outlobj.hxx>
+#include <formula/errorcodes.hxx>
#include <svx/sdshitm.hxx>
#include <svx/sdsxyitm.hxx>
#include <svx/sdtditm.hxx>
@@ -285,7 +286,7 @@ inline bool Intersect( SCCOL nStartCol1, SCROW nStartRow1, SCCOL nEndCol1, SCROW
bool ScDetectiveFunc::HasError( const ScRange& rRange, ScAddress& rErrPos )
{
rErrPos = rRange.aStart;
- sal_uInt16 nError = 0;
+ FormulaError nError = FormulaError::NONE;
ScCellIterator aIter( pDoc, rRange);
for (bool bHasCell = aIter.first(); bHasCell; bHasCell = aIter.next())
@@ -294,11 +295,11 @@ bool ScDetectiveFunc::HasError( const ScRange& rRange, ScAddress& rErrPos )
continue;
nError = aIter.getFormulaCell()->GetErrCode();
- if (nError)
+ if (nError != FormulaError::NONE)
rErrPos = aIter.GetPos();
}
- return (nError != 0);
+ return (nError != FormulaError::NONE);
}
Point ScDetectiveFunc::GetDrawPos( SCCOL nCol, SCROW nRow, DrawPosMode eMode ) const
diff --git a/sc/source/core/tool/doubleref.cxx b/sc/source/core/tool/doubleref.cxx
index d7ff17d74f8c..51b7c546f194 100644
--- a/sc/source/core/tool/doubleref.cxx
+++ b/sc/source/core/tool/doubleref.cxx
@@ -324,7 +324,7 @@ SCCOL ScDBInternalRange::findFieldColumn(SCCOL nIndex) const
return nIndex + nDBCol1 - 1;
}
-SCCOL ScDBInternalRange::findFieldColumn(const OUString& rStr, sal_uInt16* pErr) const
+SCCOL ScDBInternalRange::findFieldColumn(const OUString& rStr, FormulaError* pErr) const
{
const ScAddress& s = maRange.aStart;
const ScAddress& e = maRange.aEnd;
@@ -342,7 +342,7 @@ SCCOL ScDBInternalRange::findFieldColumn(const OUString& rStr, sal_uInt16* pErr)
ScAddress aLook( nDBCol1, nDBRow1, nDBTab1 );
while (!bFound && (aLook.Col() <= nDBCol2))
{
- sal_uInt16 nErr = getDoc()->GetStringForFormula( aLook, aCellStr );
+ FormulaError nErr = getDoc()->GetStringForFormula( aLook, aCellStr );
if (pErr)
*pErr = nErr;
lcl_uppercase(aCellStr);
@@ -433,10 +433,10 @@ SCCOL ScDBExternalRange::findFieldColumn(SCCOL nIndex) const
return nIndex - 1;
}
-SCCOL ScDBExternalRange::findFieldColumn(const OUString& rStr, sal_uInt16* pErr) const
+SCCOL ScDBExternalRange::findFieldColumn(const OUString& rStr, FormulaError* pErr) const
{
if (pErr)
- *pErr = 0;
+ *pErr = FormulaError::NONE;
OUString aUpper = rStr;
lcl_uppercase(aUpper);
diff --git a/sc/source/core/tool/formularesult.cxx b/sc/source/core/tool/formularesult.cxx
index 3d757e1ad601..2c1b646f605a 100644
--- a/sc/source/core/tool/formularesult.cxx
+++ b/sc/source/core/tool/formularesult.cxx
@@ -12,15 +12,15 @@
namespace sc {
-FormulaResultValue::FormulaResultValue() : meType(Invalid), mfValue(0.0), mnError(0) {}
-FormulaResultValue::FormulaResultValue( double fValue ) : meType(Value), mfValue(fValue), mnError(0) {}
-FormulaResultValue::FormulaResultValue( const svl::SharedString& rStr ) : meType(String), mfValue(0.0), maString(rStr), mnError(0) {}
-FormulaResultValue::FormulaResultValue( sal_uInt16 nErr ) : meType(Error), mfValue(0.0), mnError(nErr) {}
+FormulaResultValue::FormulaResultValue() : meType(Invalid), mfValue(0.0), mnError(FormulaError::NONE) {}
+FormulaResultValue::FormulaResultValue( double fValue ) : meType(Value), mfValue(fValue), mnError(FormulaError::NONE) {}
+FormulaResultValue::FormulaResultValue( const svl::SharedString& rStr ) : meType(String), mfValue(0.0), maString(rStr), mnError(FormulaError::NONE) {}
+FormulaResultValue::FormulaResultValue( FormulaError nErr ) : meType(Error), mfValue(0.0), mnError(nErr) {}
}
ScFormulaResult::ScFormulaResult() :
- mpToken(nullptr), mnError(0), mbToken(true),
+ mpToken(nullptr), mnError(FormulaError::NONE), mbToken(true),
mbEmpty(false), mbEmptyDisplayedAsString(false),
meMultiline(MULTILINE_UNKNOWN) {}
@@ -55,7 +55,7 @@ ScFormulaResult::ScFormulaResult( const ScFormulaResult & r ) :
}
ScFormulaResult::ScFormulaResult( const formula::FormulaToken* p ) :
- mnError(0), mbToken(false), mbEmpty(false), mbEmptyDisplayedAsString(false),
+ mnError(FormulaError::NONE), mbToken(false), mbEmpty(false), mbEmptyDisplayedAsString(false),
meMultiline(MULTILINE_UNKNOWN)
{
SetToken( p);
@@ -69,7 +69,7 @@ ScFormulaResult::~ScFormulaResult()
void ScFormulaResult::ResetToDefaults()
{
- mnError = 0;
+ mnError = FormulaError::NONE;
mbEmpty = false;
mbEmptyDisplayedAsString = false;
meMultiline = MULTILINE_UNKNOWN;
@@ -219,7 +219,7 @@ void ScFormulaResult::SetDouble( double f )
formula::StackVar ScFormulaResult::GetType() const
{
// Order is significant.
- if (mnError)
+ if (mnError != FormulaError::NONE)
return formula::svError;
if (mbEmpty)
return formula::svEmptyCell;
@@ -311,9 +311,9 @@ bool ScFormulaResult::IsMultiline() const
return meMultiline == MULTILINE_TRUE;
}
-bool ScFormulaResult::GetErrorOrDouble( sal_uInt16& rErr, double& rVal ) const
+bool ScFormulaResult::GetErrorOrDouble( FormulaError& rErr, double& rVal ) const
{
- if (mnError)
+ if (mnError != FormulaError::NONE)
{
rErr = mnError;
return true;
@@ -334,7 +334,7 @@ bool ScFormulaResult::GetErrorOrDouble( sal_uInt16& rErr, double& rVal ) const
}
}
- if (rErr)
+ if (rErr != FormulaError::NONE)
return true;
if (!isValue(sv))
@@ -346,11 +346,11 @@ bool ScFormulaResult::GetErrorOrDouble( sal_uInt16& rErr, double& rVal ) const
sc::FormulaResultValue ScFormulaResult::GetResult() const
{
- if (mnError)
+ if (mnError != FormulaError::NONE)
return sc::FormulaResultValue(mnError);
formula::StackVar sv = GetCellResultType();
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
if (sv == formula::svError)
{
if (GetType() == formula::svMatrixCell)
@@ -365,7 +365,7 @@ sc::FormulaResultValue ScFormulaResult::GetResult() const
}
}
- if (nErr)
+ if (nErr != FormulaError::NONE)
return sc::FormulaResultValue(nErr);
if (isValue(sv))
@@ -382,9 +382,9 @@ sc::FormulaResultValue ScFormulaResult::GetResult() const
return sc::FormulaResultValue();
}
-sal_uInt16 ScFormulaResult::GetResultError() const
+FormulaError ScFormulaResult::GetResultError() const
{
- if (mnError)
+ if (mnError != FormulaError::NONE)
return mnError;
formula::StackVar sv = GetCellResultType();
if (sv == formula::svError)
@@ -396,10 +396,10 @@ sal_uInt16 ScFormulaResult::GetResultError() const
if (mpToken)
return mpToken->GetError();
}
- return 0;
+ return FormulaError::NONE;
}
-void ScFormulaResult::SetResultError( sal_uInt16 nErr )
+void ScFormulaResult::SetResultError( FormulaError nErr )
{
mnError = nErr;
}
diff --git a/sc/source/core/tool/interpr1.cxx b/sc/source/core/tool/interpr1.cxx
index 0c380dcd1211..c40a6e2e2202 100644
--- a/sc/source/core/tool/interpr1.cxx
+++ b/sc/source/core/tool/interpr1.cxx
@@ -134,7 +134,7 @@ void ScInterpreter::ScIfJump()
// as error.
bIsValue = (!pMat->IsString(nC, nR) || pMat->IsEmpty(nC, nR));
bTrue = false;
- fVal = (bIsValue ? 0.0 : CreateDoubleError( errNoValue));
+ fVal = (bIsValue ? 0.0 : CreateDoubleError( FormulaError::NoValue));
}
if ( bTrue )
{ // TRUE
@@ -243,7 +243,7 @@ void ScInterpreter::ScIfError( bool bNAonly )
if (!sp || nJumpCount != 2)
{
// Reset nGlobalError here to not propagate the old error, if any.
- nGlobalError = (sp ? errParameterExpected : errUnknownStackVariable);
+ nGlobalError = (sp ? FormulaError::ParameterExpected : FormulaError::UnknownStackVariable);
PushError( nGlobalError);
aCode.Jump( pJump[ nJumpCount ], pJump[ nJumpCount ] );
return;
@@ -251,8 +251,8 @@ void ScInterpreter::ScIfError( bool bNAonly )
FormulaConstTokenRef xToken( pStack[ sp - 1 ] );
bool bError = false;
- sal_uInt16 nOldGlobalError = nGlobalError;
- nGlobalError = 0;
+ FormulaError nOldGlobalError = nGlobalError;
+ nGlobalError = FormulaError::NONE;
MatrixJumpConditionToMatrix();
switch (GetStackType())
@@ -260,9 +260,9 @@ void ScInterpreter::ScIfError( bool bNAonly )
default:
Pop();
// Act on implicitly propagated error, if any.
- if (nOldGlobalError)
+ if (nOldGlobalError != FormulaError::NONE)
nGlobalError = nOldGlobalError;
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
bError = true;
break;
case svError:
@@ -280,7 +280,7 @@ void ScInterpreter::ScIfError( bool bNAonly )
ScRefCellValue aCell(*pDok, aAdr);
nGlobalError = GetCellErrCode(aCell);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
bError = true;
}
}
@@ -293,14 +293,14 @@ void ScInterpreter::ScIfError( bool bNAonly )
// Handles also existing jump matrix case and sets error on
// elements.
GetDoubleOrStringFromMatrix( fVal, aStr);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
bError = true;
}
break;
case svMatrix:
{
const ScMatrixRef pMat = PopMatrix();
- if (!pMat || (nGlobalError && (!bNAonly || nGlobalError == NOTAVAILABLE)))
+ if (!pMat || (nGlobalError != FormulaError::NONE && (!bNAonly || nGlobalError == FormulaError::NotAvailable)))
{
bError = true;
break; // switch
@@ -320,8 +320,8 @@ void ScInterpreter::ScIfError( bool bNAonly )
{
for (SCSIZE nR=0; nR < nRows && !bError; ++nR)
{
- sal_uInt16 nErr = pMat->GetError( nC, nR );
- if (nErr && (!bNAonly || nErr == NOTAVAILABLE))
+ FormulaError nErr = pMat->GetError( nC, nR );
+ if (nErr != FormulaError::NONE && (!bNAonly || nErr == FormulaError::NotAvailable))
{
bError = true;
nErrorCol = nC;
@@ -344,7 +344,7 @@ void ScInterpreter::ScIfError( bool bNAonly )
ScJumpMatrix* pJumpMat = new ScJumpMatrix( nCols, nRows );
// Init all jumps to no error to save single calls. Error
// is the exceptional condition.
- const double fFlagResult = CreateDoubleError( errJumpMatHasResult);
+ const double fFlagResult = CreateDoubleError( FormulaError::JumpMatHasResult);
pJumpMat->SetAllJumps( fFlagResult, pJump[ nJumpCount ], pJump[ nJumpCount ] );
// Up to first error position simply store results, no need
// to evaluate error conditions again.
@@ -363,8 +363,8 @@ void ScInterpreter::ScIfError( bool bNAonly )
{
for ( ; nR < nRows; ++nR)
{
- sal_uInt16 nErr = pMat->GetError( nC, nR );
- if (nErr && (!bNAonly || nErr == NOTAVAILABLE))
+ FormulaError nErr = pMat->GetError( nC, nR );
+ if (nErr != FormulaError::NONE && (!bNAonly || nErr == FormulaError::NotAvailable))
{ // TRUE, THEN path
pJumpMat->SetJump( nC, nR, 1.0, pJump[ 1 ], pJump[ nJumpCount ] );
}
@@ -387,10 +387,10 @@ void ScInterpreter::ScIfError( bool bNAonly )
break;
}
- if (bError && (!bNAonly || nGlobalError == NOTAVAILABLE))
+ if (bError && (!bNAonly || nGlobalError == FormulaError::NotAvailable))
{
// error, calculate 2nd argument
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
aCode.Jump( pJump[ 1 ], pJump[ nJumpCount ] );
}
else
@@ -450,13 +450,13 @@ void ScInterpreter::ScChooseJump()
{
bIsValue = false;
fVal = CreateDoubleError(
- errIllegalArgument);
+ FormulaError::IllegalArgument);
}
}
}
else
{
- fVal = CreateDoubleError( errNoValue);
+ fVal = CreateDoubleError( FormulaError::NoValue);
}
if ( bIsValue )
{
@@ -489,7 +489,7 @@ void ScInterpreter::ScChooseJump()
default:
{
sal_Int16 nJumpIndex = GetInt16();
- if (!nGlobalError && (nJumpIndex >= 1) && (nJumpIndex < nJumpCount))
+ if (nGlobalError == FormulaError::NONE && (nJumpIndex >= 1) && (nJumpIndex < nJumpCount))
{
aCode.Jump( pJump[ (short) nJumpIndex ], pJump[ nJumpCount ] );
bHaveJump = true;
@@ -548,7 +548,7 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
if ( !bHasResMat )
{
Pop();
- SetError( errUnknownStackVariable );
+ SetError( FormulaError::UnknownStackVariable );
}
else
{
@@ -558,10 +558,10 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
case svDouble:
{
double fVal = GetDouble();
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
fVal = CreateDoubleError( nGlobalError );
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
pJumpMatrix->PutResultDouble( fVal, nC, nR );
}
@@ -569,11 +569,11 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
case svString:
{
svl::SharedString aStr = GetString();
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
pJumpMatrix->PutResultDouble( CreateDoubleError( nGlobalError),
nC, nR);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
else
pJumpMatrix->PutResultString(aStr, nC, nR);
@@ -583,11 +583,11 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
pJumpMatrix->PutResultDouble( CreateDoubleError( nGlobalError),
nC, nR);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
else
{
@@ -597,11 +597,11 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
else if (aCell.hasNumeric())
{
double fVal = GetCellValue(aAdr, aCell);
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
fVal = CreateDoubleError(
nGlobalError);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
pJumpMatrix->PutResultDouble( fVal, nC, nR );
}
@@ -609,11 +609,11 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
{
svl::SharedString aStr;
GetCellString(aStr, aCell);
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
pJumpMatrix->PutResultDouble( CreateDoubleError(
nGlobalError), nC, nR);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
else
pJumpMatrix->PutResultString(aStr, nC, nR);
@@ -626,10 +626,10 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
double fVal;
ScRange aRange;
PopDoubleRef( aRange );
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
fVal = CreateDoubleError( nGlobalError );
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
pJumpMatrix->PutResultDouble( fVal, nC, nR );
}
else
@@ -644,7 +644,7 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
|| (nRow > static_cast<sal_uLong>(aRange.aEnd.Row()) &&
aRange.aEnd.Row() != aRange.aStart.Row()))
{
- fVal = CreateDoubleError( NOTAVAILABLE );
+ fVal = CreateDoubleError( FormulaError::NotAvailable );
pJumpMatrix->PutResultDouble( fVal, nC, nR );
}
else
@@ -664,11 +664,11 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
else if (aCell.hasNumeric())
{
double fCellVal = GetCellValue(aAdr, aCell);
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
fCellVal = CreateDoubleError(
nGlobalError);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
pJumpMatrix->PutResultDouble( fCellVal, nC, nR );
}
@@ -676,11 +676,11 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
{
svl::SharedString aStr;
GetCellString(aStr, aCell);
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
pJumpMatrix->PutResultDouble( CreateDoubleError(
nGlobalError), nC, nR);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
else
pJumpMatrix->PutResultString(aStr, nC, nR);
@@ -696,15 +696,15 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
{ // match matrix offsets
double fVal;
ScMatrixRef pMat = PopMatrix();
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
fVal = CreateDoubleError( nGlobalError );
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
pJumpMatrix->PutResultDouble( fVal, nC, nR );
}
else if ( !pMat )
{
- fVal = CreateDoubleError( errUnknownVariable );
+ fVal = CreateDoubleError( FormulaError::UnknownVariable );
pJumpMatrix->PutResultDouble( fVal, nC, nR );
}
else
@@ -714,7 +714,7 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
if ((nCols <= nC && nCols != 1) ||
(nRows <= nR && nRows != 1))
{
- fVal = CreateDoubleError( NOTAVAILABLE );
+ fVal = CreateDoubleError( FormulaError::NotAvailable );
pJumpMatrix->PutResultDouble( fVal, nC, nR );
}
else
@@ -729,14 +729,14 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
{
PopError();
double fVal = CreateDoubleError( nGlobalError);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
pJumpMatrix->PutResultDouble( fVal, nC, nR );
}
break;
default:
{
Pop();
- double fVal = CreateDoubleError( errIllegalArgument);
+ double fVal = CreateDoubleError( FormulaError::IllegalArgument);
pJumpMatrix->PutResultDouble( fVal, nC, nR );
}
}
@@ -750,7 +750,7 @@ bool ScInterpreter::JumpMatrix( short nStackLevel )
pJumpMatrix->GetJump( nC, nR, fBool, nStart, nNext, nStop );
while ( bCont && nStart == nNext )
{ // push all results that have no jump path
- if ( bHasResMat && (GetDoubleErrorValue( fBool) != errJumpMatHasResult) )
+ if ( bHasResMat && (GetDoubleErrorValue( fBool) != FormulaError::JumpMatHasResult) )
{
// a false without path results in an empty path value
if ( fBool == 0.0 )
@@ -849,7 +849,7 @@ double ScInterpreter::Compare( ScQueryOp eOp )
ScMatrixRef pMat = GetMatrix();
if (!pMat)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
break;
}
@@ -857,7 +857,7 @@ double ScInterpreter::Compare( ScQueryOp eOp )
pMat->GetDimensions(nC, nR);
if (!nC || !nR)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
break;
}
if (pMat->IsEmpty(0, 0))
@@ -884,11 +884,11 @@ double ScInterpreter::Compare( ScQueryOp eOp )
// it currently is handled along with svMatrix.
default:
PopError();
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
break;
}
}
- if( nGlobalError )
+ if( nGlobalError != FormulaError::NONE )
return 0;
nCurFmtType = nFuncFmtType = css::util::NumberFormat::LOGICAL;
return sc::CompareFunc(aComp);
@@ -946,21 +946,21 @@ sc::RangeMatrix ScInterpreter::CompareMat( ScQueryOp eOp, sc::CompareOptions* pO
case svMatrix:
aMat[i] = GetRangeMatrix();
if (!aMat[i].mpMat)
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
else
aMat[i].mpMat->SetErrorInterpreter(nullptr);
// errors are transported as DoubleError inside matrix
break;
default:
PopError();
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
break;
}
}
sc::RangeMatrix aRes;
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
nCurFmtType = nFuncFmtType = css::util::NumberFormat::LOGICAL;
return aRes;
@@ -1005,7 +1005,7 @@ sc::RangeMatrix ScInterpreter::CompareMat( ScQueryOp eOp, sc::CompareOptions* pO
aRes.mpMat->PutDouble( sc::CompareFunc( aComp, pOptions), j, k);
}
else
- aRes.mpMat->PutError( errNoValue, j, k);
+ aRes.mpMat->PutError( FormulaError::NoValue, j, k);
}
}
@@ -1069,9 +1069,9 @@ ScMatrixRef ScInterpreter::QueryMat( const ScMatrixRef& pMat, sc::CompareOptions
ScMatrixRef pResultMatrix = CompareMat(rOptions.aQueryEntry.eOp, &rOptions).mpMat;
nCurFmtType = nSaveCurFmtType;
nFuncFmtType = nSaveFuncFmtType;
- if (nGlobalError || !pResultMatrix)
+ if (nGlobalError != FormulaError::NONE || !pResultMatrix)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return pResultMatrix;
}
@@ -1191,7 +1191,7 @@ void ScInterpreter::ScAnd()
size_t nRefInList = 0;
while( nParamCount-- > 0)
{
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
switch ( GetStackType() )
{
@@ -1201,13 +1201,13 @@ void ScInterpreter::ScAnd()
break;
case svString :
Pop();
- SetError( errNoValue );
+ SetError( FormulaError::NoValue );
break;
case svSingleRef :
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
ScRefCellValue aCell(*pDok, aAdr);
if (aCell.hasNumeric())
@@ -1224,18 +1224,18 @@ void ScInterpreter::ScAnd()
{
ScRange aRange;
PopDoubleRef( aRange, nParamCount, nRefInList);
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
double fVal;
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
ScValueIterator aValIter( pDok, aRange );
- if ( aValIter.GetFirst( fVal, nErr ) && nErr == 0 )
+ if ( aValIter.GetFirst( fVal, nErr ) && nErr == FormulaError::NONE )
{
bHaveValue = true;
do
{
bRes &= ( fVal != 0.0 );
- } while ( (nErr == 0) &&
+ } while ( (nErr == FormulaError::NONE) &&
aValIter.GetNext( fVal, nErr ) );
}
SetError( nErr );
@@ -1251,8 +1251,8 @@ void ScInterpreter::ScAnd()
{
bHaveValue = true;
double fVal = pMat->And();
- sal_uInt16 nErr = GetDoubleErrorValue( fVal );
- if ( nErr )
+ FormulaError nErr = GetDoubleErrorValue( fVal );
+ if ( nErr != FormulaError::NONE )
{
SetError( nErr );
bRes = false;
@@ -1260,12 +1260,12 @@ void ScInterpreter::ScAnd()
else
bRes &= (fVal != 0.0);
}
- // else: GetMatrix did set errIllegalParameter
+ // else: GetMatrix did set FormulaError::IllegalParameter
}
break;
default:
Pop();
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
}
else
@@ -1289,7 +1289,7 @@ void ScInterpreter::ScOr()
size_t nRefInList = 0;
while( nParamCount-- > 0)
{
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
switch ( GetStackType() )
{
@@ -1299,13 +1299,13 @@ void ScInterpreter::ScOr()
break;
case svString :
Pop();
- SetError( errNoValue );
+ SetError( FormulaError::NoValue );
break;
case svSingleRef :
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
ScRefCellValue aCell(*pDok, aAdr);
if (aCell.hasNumeric())
@@ -1322,10 +1322,10 @@ void ScInterpreter::ScOr()
{
ScRange aRange;
PopDoubleRef( aRange, nParamCount, nRefInList);
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
double fVal;
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
ScValueIterator aValIter( pDok, aRange );
if ( aValIter.GetFirst( fVal, nErr ) )
{
@@ -1333,7 +1333,7 @@ void ScInterpreter::ScOr()
do
{
bRes |= ( fVal != 0.0 );
- } while ( (nErr == 0) &&
+ } while ( (nErr == FormulaError::NONE) &&
aValIter.GetNext( fVal, nErr ) );
}
SetError( nErr );
@@ -1350,8 +1350,8 @@ void ScInterpreter::ScOr()
{
bHaveValue = true;
double fVal = pMat->Or();
- sal_uInt16 nErr = GetDoubleErrorValue( fVal );
- if ( nErr )
+ FormulaError nErr = GetDoubleErrorValue( fVal );
+ if ( nErr != FormulaError::NONE )
{
SetError( nErr );
bRes = false;
@@ -1359,12 +1359,12 @@ void ScInterpreter::ScOr()
else
bRes |= (fVal != 0.0);
}
- // else: GetMatrix did set errIllegalParameter
+ // else: GetMatrix did set FormulaError::IllegalParameter
}
break;
default:
Pop();
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
}
else
@@ -1389,7 +1389,7 @@ void ScInterpreter::ScXor()
size_t nRefInList = 0;
while( nParamCount-- > 0)
{
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
switch ( GetStackType() )
{
@@ -1399,13 +1399,13 @@ void ScInterpreter::ScXor()
break;
case svString :
Pop();
- SetError( errNoValue );
+ SetError( FormulaError::NoValue );
break;
case svSingleRef :
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
ScRefCellValue aCell(*pDok, aAdr);
if (aCell.hasNumeric())
@@ -1424,10 +1424,10 @@ void ScInterpreter::ScXor()
{
ScRange aRange;
PopDoubleRef( aRange, nParamCount, nRefInList);
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
double fVal;
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
ScValueIterator aValIter( pDok, aRange );
if ( aValIter.GetFirst( fVal, nErr ) )
{
@@ -1435,7 +1435,7 @@ void ScInterpreter::ScXor()
do
{
bRes ^= ( fVal != 0.0 );
- } while ( (nErr == 0) &&
+ } while ( (nErr == FormulaError::NONE) &&
aValIter.GetNext( fVal, nErr ) );
}
SetError( nErr );
@@ -1452,8 +1452,8 @@ void ScInterpreter::ScXor()
{
bHaveValue = true;
double fVal = pMat->Xor();
- sal_uInt16 nErr = GetDoubleErrorValue( fVal );
- if ( nErr )
+ FormulaError nErr = GetDoubleErrorValue( fVal );
+ if ( nErr != FormulaError::NONE )
{
SetError( nErr );
bRes = false;
@@ -1461,12 +1461,12 @@ void ScInterpreter::ScXor()
else
bRes ^= ( fVal != 0.0 );
}
- // else: GetMatrix did set errIllegalParameter
+ // else: GetMatrix did set FormulaError::IllegalParameter
}
break;
default:
Pop();
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
}
else
@@ -1854,7 +1854,7 @@ void ScInterpreter::ScIsEmpty()
default:
Pop();
}
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushInt( nRes );
}
@@ -1876,7 +1876,7 @@ bool ScInterpreter::IsString()
break;
ScRefCellValue aCell(*pDok, aAdr);
- if (GetCellErrCode(aCell) == 0)
+ if (GetCellErrCode(aCell) == FormulaError::NONE)
{
switch (aCell.meType)
{
@@ -1897,7 +1897,7 @@ bool ScInterpreter::IsString()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (!nGlobalError && pToken->GetType() == svString)
+ if (nGlobalError == FormulaError::NONE && pToken->GetType() == svString)
bRes = true;
}
break;
@@ -1922,7 +1922,7 @@ bool ScInterpreter::IsString()
default:
Pop();
}
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
return bRes;
}
@@ -1949,7 +1949,7 @@ void ScInterpreter::ScIsLogical()
break;
ScRefCellValue aCell(*pDok, aAdr);
- if (GetCellErrCode(aCell) == 0)
+ if (GetCellErrCode(aCell) == FormulaError::NONE)
{
if (aCell.hasNumeric())
{
@@ -1969,11 +1969,11 @@ void ScInterpreter::ScIsLogical()
break;
default:
PopError();
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
bRes = ( nCurFmtType == css::util::NumberFormat::LOGICAL );
}
nCurFmtType = nFuncFmtType = css::util::NumberFormat::LOGICAL;
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushInt( int(bRes) );
}
@@ -1990,7 +1990,7 @@ void ScInterpreter::ScType()
break;
ScRefCellValue aCell(*pDok, aAdr);
- if (GetCellErrCode(aCell) == 0)
+ if (GetCellErrCode(aCell) == FormulaError::NONE)
{
switch (aCell.meType)
{
@@ -2021,20 +2021,20 @@ void ScInterpreter::ScType()
break;
case svString:
PopError();
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
nType = 16;
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
else
nType = 2;
break;
case svMatrix:
PopMatrix();
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
nType = 16;
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
else
nType = 64;
@@ -2043,10 +2043,10 @@ void ScInterpreter::ScType()
break;
default:
PopError();
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
nType = 16;
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
else
nType = 1;
@@ -2149,7 +2149,7 @@ void ScInterpreter::ScCell()
bError = !PopDoubleRefOrSingleRef( aCellPos );
}
OUString aInfoType = GetString().getString();
- if( bError || nGlobalError )
+ if( bError || nGlobalError != FormulaError::NONE )
PushIllegalParameter();
else
{
@@ -2314,14 +2314,14 @@ void ScInterpreter::ScCellExternal()
ScExternalRefCache::TokenRef pToken;
ScExternalRefCache::CellFormat aFmt;
PopExternalSingleRef(nFileId, aTabName, aRef, pToken, &aFmt);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
}
OUString aInfoType = GetString().getString();
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -2332,7 +2332,7 @@ void ScInterpreter::ScCellExternal()
SCTAB nTab;
aRef.SetAbsTab(0); // external ref has a tab index of -1, which SingleRefToVars() don't like.
SingleRefToVars(aRef, nCol, nRow, nTab);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushIllegalParameter();
return;
@@ -2354,7 +2354,7 @@ void ScInterpreter::ScCellExternal()
if (pRefMgr->getCacheTable(nFileId, aTabName, false).get())
PushInt(1);
else
- SetError(errNoName);
+ SetError(FormulaError::NoName);
}
else if ( aInfoType == "ADDRESS" )
{
@@ -2375,7 +2375,7 @@ void ScInterpreter::ScCellExternal()
if (!p)
{
// In theory this should never happen...
- SetError(errNoName);
+ SetError(FormulaError::NoName);
return;
}
@@ -2462,7 +2462,7 @@ void ScInterpreter::ScIsRef()
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
bRes = true;
}
break;
@@ -2470,14 +2470,14 @@ void ScInterpreter::ScIsRef()
{
ScRange aRange;
PopDoubleRef( aRange );
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
bRes = true;
}
break;
case svRefList :
{
FormulaConstTokenRef x = PopToken();
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
bRes = !x.get()->GetRefList()->empty();
}
break;
@@ -2485,7 +2485,7 @@ void ScInterpreter::ScIsRef()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
bRes = true;
}
break;
@@ -2493,14 +2493,14 @@ void ScInterpreter::ScIsRef()
{
ScExternalRefCache::TokenArrayRef pArray;
PopExternalDoubleRef(pArray);
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
bRes = true;
}
break;
default:
Pop();
}
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushInt( int(bRes) );
}
@@ -2522,7 +2522,7 @@ void ScInterpreter::ScIsValue()
break;
ScRefCellValue aCell(*pDok, aAdr);
- if (GetCellErrCode(aCell) == 0)
+ if (GetCellErrCode(aCell) == FormulaError::NONE)
{
switch (aCell.meType)
{
@@ -2542,7 +2542,7 @@ void ScInterpreter::ScIsValue()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (!nGlobalError && pToken->GetType() == svDouble)
+ if (nGlobalError == FormulaError::NONE && pToken->GetType() == svDouble)
bRes = true;
}
break;
@@ -2554,7 +2554,7 @@ void ScInterpreter::ScIsValue()
; // nothing
else if ( !pJumpMatrix )
{
- if (pMat->GetErrorIfNotString( 0, 0) == 0)
+ if (pMat->GetErrorIfNotString( 0, 0) == FormulaError::NONE)
bRes = pMat->IsValue( 0, 0);
}
else
@@ -2563,7 +2563,7 @@ void ScInterpreter::ScIsValue()
pMat->GetDimensions( nCols, nRows);
pJumpMatrix->GetPos( nC, nR);
if ( nC < nCols && nR < nRows )
- if (pMat->GetErrorIfNotString( nC, nR) == 0)
+ if (pMat->GetErrorIfNotString( nC, nR) == FormulaError::NONE)
bRes = pMat->IsValue( nC, nR);
}
}
@@ -2571,7 +2571,7 @@ void ScInterpreter::ScIsValue()
default:
Pop();
}
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushInt( int(bRes) );
}
@@ -2594,7 +2594,7 @@ void ScInterpreter::ScIsFormula()
default:
Pop();
}
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushInt( int(bRes) );
}
@@ -2610,12 +2610,12 @@ void ScInterpreter::ScFormula()
SCROW nRow1, nRow2;
SCTAB nTab1, nTab2;
PopDoubleRef( nCol1, nRow1, nTab1, nCol2, nRow2, nTab2);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
break;
if (nTab1 != nTab2)
{
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
break;
}
@@ -2640,7 +2640,7 @@ void ScInterpreter::ScFormula()
pResMat->PutString( mrStrPool.intern( aFormula), i,j);
break;
default:
- pResMat->PutError( NOTAVAILABLE, i,j);
+ pResMat->PutError( FormulaError::NotAvailable, i,j);
}
++j;
}
@@ -2665,13 +2665,13 @@ void ScInterpreter::ScFormula()
aCell.mpFormula->GetFormula(aFormula);
break;
default:
- SetError( NOTAVAILABLE );
+ SetError( FormulaError::NotAvailable );
}
}
break;
default:
Pop();
- SetError( NOTAVAILABLE );
+ SetError( FormulaError::NotAvailable );
}
PushString( aFormula );
}
@@ -2687,13 +2687,13 @@ void ScInterpreter::ScIsNV()
{
ScAddress aAdr;
bool bOk = PopDoubleRefOrSingleRef( aAdr );
- if ( nGlobalError == NOTAVAILABLE )
+ if ( nGlobalError == FormulaError::NotAvailable )
bRes = true;
else if (bOk)
{
ScRefCellValue aCell(*pDok, aAdr);
- sal_uInt16 nErr = GetCellErrCode(aCell);
- bRes = (nErr == NOTAVAILABLE);
+ FormulaError nErr = GetCellErrCode(aCell);
+ bRes = (nErr == FormulaError::NotAvailable);
}
}
break;
@@ -2701,8 +2701,8 @@ void ScInterpreter::ScIsNV()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (nGlobalError == NOTAVAILABLE ||
- (pToken && pToken->GetType() == svError && pToken->GetError() == NOTAVAILABLE))
+ if (nGlobalError == FormulaError::NotAvailable ||
+ (pToken && pToken->GetType() == svError && pToken->GetError() == FormulaError::NotAvailable))
bRes = true;
}
break;
@@ -2713,23 +2713,23 @@ void ScInterpreter::ScIsNV()
if ( !pMat )
; // nothing
else if ( !pJumpMatrix )
- bRes = (pMat->GetErrorIfNotString( 0, 0) == NOTAVAILABLE);
+ bRes = (pMat->GetErrorIfNotString( 0, 0) == FormulaError::NotAvailable);
else
{
SCSIZE nCols, nRows, nC, nR;
pMat->GetDimensions( nCols, nRows);
pJumpMatrix->GetPos( nC, nR);
if ( nC < nCols && nR < nRows )
- bRes = (pMat->GetErrorIfNotString( nC, nR) == NOTAVAILABLE);
+ bRes = (pMat->GetErrorIfNotString( nC, nR) == FormulaError::NotAvailable);
}
}
break;
default:
PopError();
- if ( nGlobalError == NOTAVAILABLE )
+ if ( nGlobalError == FormulaError::NotAvailable )
bRes = true;
}
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushInt( int(bRes) );
}
@@ -2744,13 +2744,13 @@ void ScInterpreter::ScIsErr()
{
ScAddress aAdr;
bool bOk = PopDoubleRefOrSingleRef( aAdr );
- if ( !bOk || (nGlobalError && nGlobalError != NOTAVAILABLE) )
+ if ( !bOk || (nGlobalError != FormulaError::NONE && nGlobalError != FormulaError::NotAvailable) )
bRes = true;
else
{
ScRefCellValue aCell(*pDok, aAdr);
- sal_uInt16 nErr = GetCellErrCode(aCell);
- bRes = (nErr && nErr != NOTAVAILABLE);
+ FormulaError nErr = GetCellErrCode(aCell);
+ bRes = (nErr != FormulaError::NONE && nErr != FormulaError::NotAvailable);
}
}
break;
@@ -2758,8 +2758,8 @@ void ScInterpreter::ScIsErr()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if ((nGlobalError && nGlobalError != NOTAVAILABLE) || !pToken ||
- (pToken->GetType() == svError && pToken->GetError() != NOTAVAILABLE))
+ if ((nGlobalError != FormulaError::NONE && nGlobalError != FormulaError::NotAvailable) || !pToken ||
+ (pToken->GetType() == svError && pToken->GetError() != FormulaError::NotAvailable))
bRes = true;
}
break;
@@ -2767,12 +2767,12 @@ void ScInterpreter::ScIsErr()
case svMatrix:
{
ScMatrixRef pMat = GetMatrix();
- if ( nGlobalError || !pMat )
- bRes = ((nGlobalError && nGlobalError != NOTAVAILABLE) || !pMat);
+ if ( nGlobalError != FormulaError::NONE || !pMat )
+ bRes = ((nGlobalError != FormulaError::NONE && nGlobalError != FormulaError::NotAvailable) || !pMat);
else if ( !pJumpMatrix )
{
- sal_uInt16 nErr = pMat->GetErrorIfNotString( 0, 0);
- bRes = (nErr && nErr != NOTAVAILABLE);
+ FormulaError nErr = pMat->GetErrorIfNotString( 0, 0);
+ bRes = (nErr != FormulaError::NONE && nErr != FormulaError::NotAvailable);
}
else
{
@@ -2781,18 +2781,18 @@ void ScInterpreter::ScIsErr()
pJumpMatrix->GetPos( nC, nR);
if ( nC < nCols && nR < nRows )
{
- sal_uInt16 nErr = pMat->GetErrorIfNotString( nC, nR);
- bRes = (nErr && nErr != NOTAVAILABLE);
+ FormulaError nErr = pMat->GetErrorIfNotString( nC, nR);
+ bRes = (nErr != FormulaError::NONE && nErr != FormulaError::NotAvailable);
}
}
}
break;
default:
PopError();
- if ( nGlobalError && nGlobalError != NOTAVAILABLE )
+ if ( nGlobalError != FormulaError::NONE && nGlobalError != FormulaError::NotAvailable )
bRes = true;
}
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushInt( int(bRes) );
}
@@ -2811,12 +2811,12 @@ void ScInterpreter::ScIsError()
bRes = true;
break;
}
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
bRes = true;
else
{
ScRefCellValue aCell(*pDok, aAdr);
- bRes = (GetCellErrCode(aCell) != 0);
+ bRes = (GetCellErrCode(aCell) != FormulaError::NONE);
}
}
break;
@@ -2824,7 +2824,7 @@ void ScInterpreter::ScIsError()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (nGlobalError || pToken->GetType() == svError)
+ if (nGlobalError != FormulaError::NONE || pToken->GetType() == svError)
bRes = true;
}
break;
@@ -2832,26 +2832,26 @@ void ScInterpreter::ScIsError()
case svMatrix:
{
ScMatrixRef pMat = GetMatrix();
- if ( nGlobalError || !pMat )
+ if ( nGlobalError != FormulaError::NONE || !pMat )
bRes = true;
else if ( !pJumpMatrix )
- bRes = (pMat->GetErrorIfNotString( 0, 0) != 0);
+ bRes = (pMat->GetErrorIfNotString( 0, 0) != FormulaError::NONE);
else
{
SCSIZE nCols, nRows, nC, nR;
pMat->GetDimensions( nCols, nRows);
pJumpMatrix->GetPos( nC, nR);
if ( nC < nCols && nR < nRows )
- bRes = (pMat->GetErrorIfNotString( nC, nR) != 0);
+ bRes = (pMat->GetErrorIfNotString( nC, nR) != FormulaError::NONE);
}
}
break;
default:
PopError();
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
bRes = true;
}
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushInt( int(bRes) );
}
@@ -2870,8 +2870,8 @@ bool ScInterpreter::IsEven()
break;
ScRefCellValue aCell(*pDok, aAdr);
- sal_uInt16 nErr = GetCellErrCode(aCell);
- if (nErr != 0)
+ FormulaError nErr = GetCellErrCode(aCell);
+ if (nErr != FormulaError::NONE)
SetError(nErr);
else
{
@@ -2904,7 +2904,7 @@ bool ScInterpreter::IsEven()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (!nGlobalError && pToken->GetType() == svDouble)
+ if (nGlobalError == FormulaError::NONE && pToken->GetType() == svDouble)
{
fVal = pToken->GetDouble();
bRes = true;
@@ -2935,7 +2935,7 @@ bool ScInterpreter::IsEven()
fVal = pMat->GetDouble( nC, nR);
}
else
- SetError( errNoValue);
+ SetError( FormulaError::NoValue);
}
}
break;
@@ -2943,7 +2943,7 @@ bool ScInterpreter::IsEven()
; // nothing
}
if ( !bRes )
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
else
bRes = ( fmod( ::rtl::math::approxFloor( fabs( fVal ) ), 2.0 ) < 0.5 );
return bRes;
@@ -2961,18 +2961,18 @@ void ScInterpreter::ScIsOdd()
void ScInterpreter::ScN()
{
- sal_uInt16 nErr = nGlobalError;
- nGlobalError = 0;
+ FormulaError nErr = nGlobalError;
+ nGlobalError = FormulaError::NONE;
// Temporarily override the ConvertStringToValue() error for
// GetCellValue() / GetCellValueOrZero()
- sal_uInt16 nSErr = mnStringNoValueError;
- mnStringNoValueError = errCellNoValue;
+ FormulaError nSErr = mnStringNoValueError;
+ mnStringNoValueError = FormulaError::CellNoValue;
double fVal = GetDouble();
mnStringNoValueError = nSErr;
- if (nErr)
+ if (nErr != FormulaError::NONE)
nGlobalError = nErr; // preserve previous error if any
- else if (nGlobalError == errCellNoValue)
- nGlobalError = 0; // reset temporary detection error
+ else if (nGlobalError == FormulaError::CellNoValue)
+ nGlobalError = FormulaError::NONE; // reset temporary detection error
PushDouble(fVal);
}
@@ -3048,7 +3048,7 @@ void ScInterpreter::ScT()
}
bool bValue = false;
ScRefCellValue aCell(*pDok, aAdr);
- if (GetCellErrCode(aCell) == 0)
+ if (GetCellErrCode(aCell) == FormulaError::NONE)
{
switch (aCell.meType)
{
@@ -3096,7 +3096,7 @@ void ScInterpreter::ScT()
; // leave on stack
break;
default :
- PushError( errUnknownOpCode);
+ PushError( FormulaError::UnknownOpCode);
}
}
@@ -3218,7 +3218,7 @@ void ScInterpreter::ScNumberValue()
default:
aInputString = GetString().getString();
}
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
PushError( nGlobalError );
return;
@@ -3411,7 +3411,7 @@ void ScInterpreter::ScUnichar()
if ( MustHaveParamCount( GetByte(), 1 ) )
{
sal_uInt32 nCodePoint = GetUInt32();
- if (nGlobalError || !rtl::isUnicodeCodePoint(nCodePoint))
+ if (nGlobalError != FormulaError::NONE || !rtl::isUnicodeCodePoint(nCodePoint))
PushIllegalArgument();
else
{
@@ -3462,7 +3462,7 @@ void ScInterpreter::ScMin( bool bTextAsZero )
case svDoubleRef :
case svRefList :
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
PopDoubleRef( aRange, nParamCount, nRefInList);
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags, bTextAsZero );
if (aValIter.GetFirst(nVal, nErr))
@@ -3470,7 +3470,7 @@ void ScInterpreter::ScMin( bool bTextAsZero )
if (nMin > nVal)
nMin = nVal;
aValIter.GetCurNumFmtInfo( nFuncFmtType, nFuncFmtIndex );
- while ((nErr == 0) && aValIter.GetNext(nVal, nErr))
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext(nVal, nErr))
{
if (nMin > nVal)
nMin = nVal;
@@ -3502,12 +3502,12 @@ void ScInterpreter::ScMin( bool bTextAsZero )
nMin = 0.0;
}
else
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
default :
Pop();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
}
if ( nVal < nMin )
@@ -3557,7 +3557,7 @@ void ScInterpreter::ScMax( bool bTextAsZero )
case svDoubleRef :
case svRefList :
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
PopDoubleRef( aRange, nParamCount, nRefInList);
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags, bTextAsZero );
if (aValIter.GetFirst(nVal, nErr))
@@ -3565,7 +3565,7 @@ void ScInterpreter::ScMax( bool bTextAsZero )
if (nMax < nVal)
nMax = nVal;
aValIter.GetCurNumFmtInfo( nFuncFmtType, nFuncFmtIndex );
- while ((nErr == 0) && aValIter.GetNext(nVal, nErr))
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext(nVal, nErr))
{
if (nMax < nVal)
nMax = nVal;
@@ -3597,12 +3597,12 @@ void ScInterpreter::ScMax( bool bTextAsZero )
nMax = 0.0;
}
else
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
default :
Pop();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
}
if ( nVal > nMax )
@@ -3623,14 +3623,14 @@ void ScInterpreter::GetStVarParams( double& rVal, double& rValCount, bool bTextA
ScAddress aAdr;
ScRange aRange;
size_t nRefInList = 0;
- while (!nGlobalError && nParamCount-- > 0)
+ while (nGlobalError == FormulaError::NONE && nParamCount-- > 0)
{
switch (GetStackType())
{
case svDouble :
{
fVal = GetDouble();
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
{
values.push_back(fVal);
fSum += fVal;
@@ -3644,7 +3644,7 @@ void ScInterpreter::GetStVarParams( double& rVal, double& rValCount, bool bTextA
if (aCell.hasNumeric())
{
fVal = GetCellValue(aAdr, aCell);
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
{
values.push_back(fVal);
fSum += fVal;
@@ -3659,7 +3659,7 @@ void ScInterpreter::GetStVarParams( double& rVal, double& rValCount, bool bTextA
case svDoubleRef :
case svRefList :
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
PopDoubleRef( aRange, nParamCount, nRefInList);
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags, bTextAsZero );
if (aValIter.GetFirst(fVal, nErr))
@@ -3669,9 +3669,9 @@ void ScInterpreter::GetStVarParams( double& rVal, double& rValCount, bool bTextA
values.push_back(fVal);
fSum += fVal;
}
- while ((nErr == 0) && aValIter.GetNext(fVal, nErr));
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext(fVal, nErr));
}
- if ( nErr )
+ if ( nErr != FormulaError::NONE )
{
SetError(nErr);
}
@@ -3691,7 +3691,7 @@ void ScInterpreter::GetStVarParams( double& rVal, double& rValCount, bool bTextA
if (!pMat->IsString(nMatCol,nMatRow))
{
fVal= pMat->GetDouble(nMatCol,nMatRow);
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
{
values.push_back(fVal);
fSum += fVal;
@@ -3714,20 +3714,20 @@ void ScInterpreter::GetStVarParams( double& rVal, double& rValCount, bool bTextA
values.push_back(0.0);
}
else
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
default :
Pop();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
}
::std::vector<double>::size_type n = values.size();
rValCount = n;
if (!n)
- SetError( errDivisionByZero);
- if (!nGlobalError)
+ SetError( FormulaError::DivisionByZero);
+ if (nGlobalError == FormulaError::NONE)
{
const double vMean = fSum / n;
for (::std::vector<double>::size_type i = 0; i < n; i++)
@@ -3743,7 +3743,7 @@ void ScInterpreter::ScVar( bool bTextAsZero )
GetStVarParams( nVal, nValCount, bTextAsZero );
if (nValCount <= 1.0)
- PushError( errDivisionByZero );
+ PushError( FormulaError::DivisionByZero );
else
PushDouble( nVal / (nValCount - 1.0));
}
@@ -3763,7 +3763,7 @@ void ScInterpreter::ScStDev( bool bTextAsZero )
double nValCount;
GetStVarParams( nVal, nValCount, bTextAsZero );
if (nValCount <= 1.0)
- PushError( errDivisionByZero );
+ PushError( FormulaError::DivisionByZero );
else
PushDouble( sqrt( nVal / (nValCount - 1.0)));
}
@@ -3774,7 +3774,7 @@ void ScInterpreter::ScStDevP( bool bTextAsZero )
double nValCount;
GetStVarParams( nVal, nValCount, bTextAsZero );
if (nValCount == 0.0)
- PushError( errDivisionByZero );
+ PushError( FormulaError::DivisionByZero );
else
PushDouble( sqrt( nVal / nValCount));
@@ -3847,7 +3847,7 @@ void ScInterpreter::ScColumns()
break;
default:
PopError();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
}
PushDouble((double)nVal);
@@ -3904,7 +3904,7 @@ void ScInterpreter::ScRows()
break;
default:
PopError();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
}
PushDouble((double)nVal);
@@ -3957,7 +3957,7 @@ void ScInterpreter::ScSheets()
break;
default:
PopError();
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
}
}
}
@@ -4037,7 +4037,7 @@ void ScInterpreter::ScColumn()
}
break;
default:
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
nVal = 0.0;
}
}
@@ -4118,7 +4118,7 @@ void ScInterpreter::ScRow()
}
break;
default:
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
nVal = 0.0;
}
}
@@ -4144,7 +4144,7 @@ void ScInterpreter::ScSheet()
if ( pDok->GetTable(aStr.getString(), nVal))
++nVal;
else
- SetError( errIllegalArgument );
+ SetError( FormulaError::IllegalArgument );
}
break;
case svSingleRef :
@@ -4169,9 +4169,9 @@ void ScInterpreter::ScSheet()
}
break;
default:
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
}
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
nVal = 0;
}
PushDouble( (double) nVal );
@@ -4379,7 +4379,7 @@ void ScInterpreter::ScMatch()
return;
}
- if (nGlobalError == 0)
+ if (nGlobalError == FormulaError::NONE)
{
double fVal;
ScQueryParam rParam;
@@ -4437,7 +4437,7 @@ void ScInterpreter::ScMatch()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -4702,7 +4702,7 @@ void ScInterpreter::ScCountEmptyCells()
}
}
break;
- default : SetError(errIllegalParameter); break;
+ default : SetError(FormulaError::IllegalParameter); break;
}
PushDouble(nMaxCount - nCount);
}
@@ -4735,7 +4735,7 @@ double ScInterpreter::IterateParametersIf( ScIterFuncIf eFunc )
PopDoubleRef( nCol3, nRow3, nTab3, nColJunk, nRowJunk, nTabJunk );
if ( nTabJunk != nTab3 )
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return 0;
}
}
@@ -4752,7 +4752,7 @@ double ScInterpreter::IterateParametersIf( ScIterFuncIf eFunc )
pSumExtraMatrix = GetNewMat(1,1);
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return 0;
if (pToken->GetType() == svDouble)
@@ -4765,7 +4765,7 @@ double ScInterpreter::IterateParametersIf( ScIterFuncIf eFunc )
PopExternalDoubleRef(pSumExtraMatrix);
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return 0;
}
}
@@ -4822,7 +4822,7 @@ double ScInterpreter::IterateParametersIf( ScIterFuncIf eFunc )
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
{
if (pToken->GetType() == svDouble)
{
@@ -4862,7 +4862,7 @@ double ScInterpreter::IterateParametersIf( ScIterFuncIf eFunc )
case svRefList :
if (bSumExtraRange)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
else
{
@@ -4887,7 +4887,7 @@ double ScInterpreter::IterateParametersIf( ScIterFuncIf eFunc )
pQueryMatrix = GetMatrix();
if (!pQueryMatrix)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return 0;
}
nCol1 = 0;
@@ -4901,11 +4901,11 @@ double ScInterpreter::IterateParametersIf( ScIterFuncIf eFunc )
}
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
if ( nTab1 != nTab2 )
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
if (bSumExtraRange)
@@ -4953,7 +4953,7 @@ double ScInterpreter::IterateParametersIf( ScIterFuncIf eFunc )
nTab3 = nTab1;
}
- if (nGlobalError == 0)
+ if (nGlobalError == FormulaError::NONE)
{
ScQueryParam rParam;
rParam.nRow1 = nRow1;
@@ -4986,9 +4986,9 @@ double ScInterpreter::IterateParametersIf( ScIterFuncIf eFunc )
// Never case-sensitive.
sc::CompareOptions aOptions( pDok, rEntry, rParam.eSearchType);
ScMatrixRef pResultMatrix = QueryMat( pQueryMatrix, aOptions);
- if (nGlobalError || !pResultMatrix)
+ if (nGlobalError != FormulaError::NONE || !pResultMatrix)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
if (pSumExtraMatrix)
@@ -5099,7 +5099,7 @@ double ScInterpreter::IterateParametersIf( ScIterFuncIf eFunc )
}
else
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return 0;
}
}
@@ -5245,7 +5245,7 @@ void ScInterpreter::ScCountIf()
PushIllegalParameter();
return;
}
- if (nGlobalError == 0)
+ if (nGlobalError == FormulaError::NONE)
{
ScQueryParam rParam;
rParam.nRow1 = nRow1;
@@ -5274,7 +5274,7 @@ void ScInterpreter::ScCountIf()
// Never case-sensitive.
sc::CompareOptions aOptions( pDok, rEntry, rParam.eSearchType);
ScMatrixRef pResultMatrix = QueryMat( pQueryMatrix, aOptions);
- if (nGlobalError || !pResultMatrix)
+ if (nGlobalError != FormulaError::NONE || !pResultMatrix)
{
PushIllegalParameter();
return;
@@ -5325,7 +5325,7 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
if ( !bCheck )
{
- SetError( errParameterExpected);
+ SetError( FormulaError::ParameterExpected);
}
else
{
@@ -5344,7 +5344,7 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
SCCOL nDimensionCols = 0;
SCROW nDimensionRows = 0;
- while (nParamCount > 1 && !nGlobalError)
+ while (nParamCount > 1 && nGlobalError == FormulaError::NONE)
{
// take criteria
svl::SharedString aString;
@@ -5399,7 +5399,7 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
{
if (pToken->GetType() == svDouble)
{
@@ -5418,7 +5418,7 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
}
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return 0; // and bail out, no need to evaluate other arguments
// take range
@@ -5456,7 +5456,7 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
pQueryMatrix = PopMatrix();
if (!pQueryMatrix)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return 0;
}
nCol1 = 0;
@@ -5470,12 +5470,12 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
}
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return 0;
}
if ( nTab1 != nTab2 )
{
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
return 0;
}
@@ -5486,12 +5486,12 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
nDimensionRows = nRow2 - nRow1 + 1;
if ((nDimensionCols != (nCol2 - nCol1 + 1)) || (nDimensionRows != (nRow2 - nRow1 + 1)))
{
- SetError ( errIllegalArgument);
+ SetError ( FormulaError::IllegalArgument);
return 0;
}
// recalculate matrix values
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return 0;
// initialize temporary result matrix
@@ -5533,9 +5533,9 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
// Never case-sensitive.
sc::CompareOptions aOptions( pDok, rEntry, rParam.eSearchType);
ScMatrixRef pResultMatrix = QueryMat( pQueryMatrix, aOptions);
- if (nGlobalError || !pResultMatrix)
+ if (nGlobalError != FormulaError::NONE || !pResultMatrix)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return 0;
}
@@ -5544,7 +5544,7 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
pResultMatrix->GetDoubleArray(aResValues);
if (aResArray.size() != aResValues.size())
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return 0;
}
@@ -5571,7 +5571,7 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
nParamCount -= 2;
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return 0; // bail out
// main range - only for AVERAGEIFS, SUMIFS, MINIFS and MAXIFS
@@ -5612,7 +5612,7 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
pMainMatrix = PopMatrix();
if (!pMainMatrix)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return 0;
}
nMainCol1 = 0;
@@ -5626,23 +5626,23 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
}
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return 0;
}
if ( nMainTab1 != nMainTab2 )
{
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
return 0;
}
// All reference ranges must be of same dimension and size.
if ((nDimensionCols != (nMainCol2 - nMainCol1 + 1)) || (nDimensionRows != (nMainRow2 - nMainRow1 + 1)))
{
- SetError ( errIllegalArgument);
+ SetError ( FormulaError::IllegalArgument);
return 0;
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return 0; // bail out
// end-result calculation
@@ -5654,7 +5654,7 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
pMainMatrix->GetDoubleArray(aMainValues, false); // Map empty values to NaN's.
if (aResArray.size() != aMainValues.size())
{
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
return 0;
}
@@ -5666,7 +5666,7 @@ double ScInterpreter::IterateParametersIfs( ScIterFuncIfs eFunc )
continue;
fVal = *itMain;
- if (GetDoubleErrorValue(fVal) == errElementNaN)
+ if (GetDoubleErrorValue(fVal) == FormulaError::ElementNaN)
continue;
++fCount;
@@ -5897,7 +5897,7 @@ void ScInterpreter::ScLookup()
if (aCell.hasEmptyValue())
{
// Empty cells aren't found anywhere, bail out early.
- SetError( NOTAVAILABLE);
+ SetError( FormulaError::NotAvailable);
}
else if (aCell.hasNumeric())
{
@@ -5909,10 +5909,10 @@ void ScInterpreter::ScLookup()
}
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -6395,7 +6395,7 @@ void ScInterpreter::CalculateLookup(bool bHLookup)
nSpIndex = sal::static_int_cast<SCCOL>( nSpIndex + nCol1 ); // value column
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushIllegalParameter();
return;
@@ -6655,7 +6655,7 @@ void ScInterpreter::ScSubTotal()
nFunc -= 100;
}
- if ( nGlobalError || nFunc < 1 || nFunc > 11 )
+ if ( nGlobalError != FormulaError::NONE || nFunc < 1 || nFunc > 11 )
PushIllegalArgument(); // simulate return on stack, not SetError(...)
else
{
@@ -6698,7 +6698,7 @@ void ScInterpreter::ScAggregate()
PushWithoutError( *p2 );
sal_Int32 nOption = GetInt32();
- if ( nGlobalError || nFunc < 1 || nFunc > 19 )
+ if ( nGlobalError != FormulaError::NONE || nFunc < 1 || nFunc > 19 )
PushIllegalArgument();
else
{
@@ -6821,7 +6821,7 @@ std::unique_ptr<ScDBQueryParamBase> ScInterpreter::GetDBParams( bool& rMissingFi
else
{
PopError();
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
}
break;
case svMissing :
@@ -6829,19 +6829,19 @@ std::unique_ptr<ScDBQueryParamBase> ScInterpreter::GetDBParams( bool& rMissingFi
if ( bAllowMissingField )
rMissingField = true;
else
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
break;
default:
PopError();
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return nullptr;
unique_ptr<ScDBRangeBase> pDBRef( PopDBDoubleRef() );
- if (nGlobalError || !pDBRef.get())
+ if (nGlobalError != FormulaError::NONE || !pDBRef.get())
return nullptr;
if ( bRangeFake )
@@ -6850,10 +6850,10 @@ std::unique_ptr<ScDBQueryParamBase> ScInterpreter::GetDBParams( bool& rMissingFi
if (pDBRef->isRangeEqual(aMissingRange))
rMissingField = true;
else
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return nullptr;
SCCOL nField = pDBRef->getFirstFieldColumn();
@@ -6863,7 +6863,7 @@ std::unique_ptr<ScDBQueryParamBase> ScInterpreter::GetDBParams( bool& rMissingFi
nField = pDBRef->findFieldColumn(static_cast<SCCOL>(nVal));
else
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
nField = pDBRef->findFieldColumn(aStr.getString(), &nErr);
SetError(nErr);
}
@@ -6916,12 +6916,12 @@ void ScInterpreter::DBIterator( ScIterFunc eFunc )
{
if (!pQueryParam->IsValidFieldIndex())
{
- SetError(errNoValue);
+ SetError(FormulaError::NoValue);
return;
}
ScDBQueryDataIterator aValIter(pDok, pQueryParam.release());
ScDBQueryDataIterator::Value aValue;
- if ( aValIter.GetFirst(aValue) && !aValue.mnError )
+ if ( aValIter.GetFirst(aValue) && aValue.mnError == FormulaError::NONE )
{
switch( eFunc )
{
@@ -6962,12 +6962,12 @@ void ScInterpreter::DBIterator( ScIterFunc eFunc )
default: ; // nothing
}
}
- while ( aValIter.GetNext(aValue) && !aValue.mnError );
+ while ( aValIter.GetNext(aValue) && aValue.mnError == FormulaError::NONE );
}
SetError(aValue.mnError);
}
else
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
switch( eFunc )
{
case ifCOUNT: nErg = nCount; break;
@@ -7020,18 +7020,18 @@ void ScInterpreter::ScDBCount()
{ // count only matching records with a value in the "result" field
if (!pQueryParam->IsValidFieldIndex())
{
- SetError(errNoValue);
+ SetError(FormulaError::NoValue);
return;
}
ScDBQueryDataIterator aValIter( pDok, pQueryParam.release());
ScDBQueryDataIterator::Value aValue;
- if ( aValIter.GetFirst(aValue) && !aValue.mnError )
+ if ( aValIter.GetFirst(aValue) && aValue.mnError == FormulaError::NONE )
{
do
{
nCount++;
}
- while ( aValIter.GetNext(aValue) && !aValue.mnError );
+ while ( aValIter.GetNext(aValue) && aValue.mnError == FormulaError::NONE );
}
SetError(aValue.mnError);
}
@@ -7049,20 +7049,20 @@ void ScInterpreter::ScDBCount2()
{
if (!pQueryParam->IsValidFieldIndex())
{
- SetError(errNoValue);
+ SetError(FormulaError::NoValue);
return;
}
sal_uLong nCount = 0;
pQueryParam->mbSkipString = false;
ScDBQueryDataIterator aValIter( pDok, pQueryParam.release());
ScDBQueryDataIterator::Value aValue;
- if ( aValIter.GetFirst(aValue) && !aValue.mnError )
+ if ( aValIter.GetFirst(aValue) && aValue.mnError == FormulaError::NONE )
{
do
{
nCount++;
}
- while ( aValIter.GetNext(aValue) && !aValue.mnError );
+ while ( aValIter.GetNext(aValue) && aValue.mnError == FormulaError::NONE );
}
SetError(aValue.mnError);
PushDouble( nCount );
@@ -7105,12 +7105,12 @@ void ScInterpreter::GetDBStVarParams( double& rVal, double& rValCount )
{
if (!pQueryParam->IsValidFieldIndex())
{
- SetError(errNoValue);
+ SetError(FormulaError::NoValue);
return;
}
ScDBQueryDataIterator aValIter(pDok, pQueryParam.release());
ScDBQueryDataIterator::Value aValue;
- if (aValIter.GetFirst(aValue) && !aValue.mnError)
+ if (aValIter.GetFirst(aValue) && aValue.mnError == FormulaError::NONE)
{
do
{
@@ -7118,12 +7118,12 @@ void ScInterpreter::GetDBStVarParams( double& rVal, double& rValCount )
values.push_back(aValue.mfValue);
fSum += aValue.mfValue;
}
- while ((aValue.mnError == 0) && aValIter.GetNext(aValue));
+ while ((aValue.mnError == FormulaError::NONE) && aValIter.GetNext(aValue));
}
SetError(aValue.mnError);
}
else
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
vMean = fSum / values.size();
@@ -7327,7 +7327,7 @@ void ScInterpreter::ScIndirect()
while (false);
}
- PushError( errNoRef);
+ PushError( FormulaError::NoRef);
}
}
}
@@ -7383,7 +7383,7 @@ void ScInterpreter::ScAddressFunc()
--nCol;
--nRow;
- if (nGlobalError || !ValidCol( nCol) || !ValidRow( nRow))
+ if (nGlobalError != FormulaError::NONE || !ValidCol( nCol) || !ValidRow( nRow))
{
PushIllegalArgument();
return;
@@ -7434,7 +7434,7 @@ void ScInterpreter::ScOffset()
nRowNew = GetInt32WithDefault(-1);
nColPlus = GetInt32();
nRowPlus = GetInt32();
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -7599,9 +7599,9 @@ void ScInterpreter::ScIndex()
nAreaCount = (sp ? pStack[sp-1]->GetRefList()->size() : 0);
else
nAreaCount = 1; // one reference or array or whatever
- if (nGlobalError || nAreaCount == 0 || (size_t)nArea > nAreaCount)
+ if (nGlobalError != FormulaError::NONE || nAreaCount == 0 || (size_t)nArea > nAreaCount)
{
- PushError( errNoRef);
+ PushError( FormulaError::NoRef);
return;
}
else if (nArea < 1 || nCol < 0 || nRow < 0)
@@ -7616,7 +7616,7 @@ void ScInterpreter::ScIndex()
case svExternalDoubleRef:
{
if (nArea != 1)
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
sal_uInt16 nOldSp = sp;
ScMatrixRef pMat = GetMatrix();
if (pMat)
@@ -7718,7 +7718,7 @@ void ScInterpreter::ScIndex()
if (GetStackType() == svRefList)
{
FormulaConstTokenRef xRef = PopToken();
- if (nGlobalError || !xRef)
+ if (nGlobalError != FormulaError::NONE || !xRef)
{
PushIllegalParameter();
return;
@@ -7785,7 +7785,7 @@ void ScInterpreter::ScMultiArea()
sal_uInt8 nParamCount = GetByte();
if (MustHaveParamCountMin( nParamCount, 1))
{
- while (!nGlobalError && nParamCount-- > 1)
+ while (nGlobalError == FormulaError::NONE && nParamCount-- > 1)
{
ScUnionFunc();
}
@@ -7822,7 +7822,7 @@ void ScInterpreter::ScAreas()
}
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
PushDouble( double(nCount));
}
@@ -7875,7 +7875,7 @@ void ScInterpreter::ScCurrency()
aStr,
&pColor,
ScGlobal::eLnge))
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
}
else
{
@@ -8314,19 +8314,19 @@ void ScInterpreter::ScText()
default:
{
FormulaConstTokenRef xTok( PopToken());
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
{
PushTokenRef( xTok);
// Temporarily override the ConvertStringToValue()
// error for GetCellValue() / GetCellValueOrZero()
- sal_uInt16 nSErr = mnStringNoValueError;
- mnStringNoValueError = errNotNumericString;
+ FormulaError nSErr = mnStringNoValueError;
+ mnStringNoValueError = FormulaError::NotNumericString;
fVal = GetDouble();
mnStringNoValueError = nSErr;
- if (nGlobalError == errNotNumericString)
+ if (nGlobalError == FormulaError::NotNumericString)
{
// Not numeric.
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushTokenRef( xTok);
aStr = GetString();
bString = true;
@@ -8334,7 +8334,7 @@ void ScInterpreter::ScText()
}
}
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
PushError( nGlobalError);
else
{
@@ -8431,7 +8431,7 @@ void ScInterpreter::ScRept()
PushIllegalArgument();
else if ( fAnz * aStr.getLength() > SAL_MAX_UINT16 )
{
- PushError( errStringOverflow );
+ PushError( FormulaError::StringOverflow );
}
else if ( fAnz == 0.0 )
PushString( EMPTY_OUSTRING );
@@ -8459,31 +8459,31 @@ void ScInterpreter::ScConcat()
PushString( aRes );
}
-sal_uInt16 ScInterpreter::GetErrorType()
+FormulaError ScInterpreter::GetErrorType()
{
- sal_uInt16 nErr;
- sal_uInt16 nOldError = nGlobalError;
- nGlobalError = 0;
+ FormulaError nErr;
+ FormulaError nOldError = nGlobalError;
+ nGlobalError = FormulaError::NONE;
switch ( GetStackType() )
{
case svRefList :
{
FormulaConstTokenRef x = PopToken();
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
nErr = nGlobalError;
else
{
const ScRefList* pRefList = x.get()->GetRefList();
size_t n = pRefList->size();
if (!n)
- nErr = errNoRef;
+ nErr = FormulaError::NoRef;
else if (n > 1)
- nErr = errNoValue;
+ nErr = FormulaError::NoValue;
else
{
ScRange aRange;
DoubleRefToRange( (*pRefList)[0], aRange);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
nErr = nGlobalError;
else
{
@@ -8501,7 +8501,7 @@ sal_uInt16 ScInterpreter::GetErrorType()
{
ScRange aRange;
PopDoubleRef( aRange );
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
nErr = nGlobalError;
else
{
@@ -8517,7 +8517,7 @@ sal_uInt16 ScInterpreter::GetErrorType()
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
nErr = nGlobalError;
else
nErr = pDok->GetErrCode( aAdr );
@@ -8533,11 +8533,11 @@ sal_uInt16 ScInterpreter::GetErrorType()
void ScInterpreter::ScErrorType()
{
- sal_uInt16 nErr = GetErrorType();
- if ( nErr )
+ FormulaError nErr = GetErrorType();
+ if ( nErr != FormulaError::NONE )
{
- nGlobalError = 0;
- PushDouble( nErr );
+ nGlobalError = FormulaError::NONE;
+ PushDouble( static_cast<double>(nErr) );
}
else
{
@@ -8547,30 +8547,30 @@ void ScInterpreter::ScErrorType()
void ScInterpreter::ScErrorType_ODF()
{
- sal_uInt16 nErr = GetErrorType();
+ FormulaError nErr = GetErrorType();
sal_uInt16 nErrType;
switch ( nErr )
{
- case errParameterExpected : // #NULL!
+ case FormulaError::ParameterExpected : // #NULL!
nErrType = 1;
break;
- case errDivisionByZero : // #DIV/0!
+ case FormulaError::DivisionByZero : // #DIV/0!
nErrType = 2;
break;
- case errNoValue : // #VALUE!
+ case FormulaError::NoValue : // #VALUE!
nErrType = 3;
break;
- case errNoRef : // #REF!
+ case FormulaError::NoRef : // #REF!
nErrType = 4;
break;
- case errNoName : // #NAME?
+ case FormulaError::NoName : // #NAME?
nErrType = 5;
break;
- case errIllegalFPOperation : // #NUM!
+ case FormulaError::IllegalFPOperation : // #NUM!
nErrType = 6;
break;
- case NOTAVAILABLE : // #N/A
+ case FormulaError::NotAvailable : // #N/A
nErrType = 7;
break;
/*
@@ -8594,7 +8594,7 @@ void ScInterpreter::ScErrorType_ODF()
if ( nErrType )
{
- nGlobalError = 0;
+ nGlobalError =FormulaError::NONE;
PushDouble( nErrType );
}
else
diff --git a/sc/source/core/tool/interpr2.cxx b/sc/source/core/tool/interpr2.cxx
index 0d02066482ed..826796f80b4a 100644
--- a/sc/source/core/tool/interpr2.cxx
+++ b/sc/source/core/tool/interpr2.cxx
@@ -97,7 +97,7 @@ double ScInterpreter::GetDateSerial( sal_Int16 nYear, sal_Int16 nMonth, sal_Int1
return (double) (aDate - *(pFormatter->GetNullDate()));
else
{
- SetError(errNoValue);
+ SetError(FormulaError::NoValue);
return 0;
}
}
@@ -226,7 +226,7 @@ void ScInterpreter::ScGetDayOfWeek()
nVal -= nFlag - 12; // nVal -= ((nFlag - 11) - 1 = x - 1 = -1,0,1,2,3,4,5)
break;
default:
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
PushInt( nVal );
}
@@ -311,7 +311,7 @@ void ScInterpreter::ScEasterSunday()
{
sal_Int16 nDay, nMonth, nYear;
nYear = GetInt16();
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -345,7 +345,7 @@ void ScInterpreter::ScEasterSunday()
}
}
-sal_uInt16 ScInterpreter::GetWeekendAndHolidayMasks(
+FormulaError ScInterpreter::GetWeekendAndHolidayMasks(
const sal_uInt8 nParamCount, const sal_uInt32 nNullDate, vector< double >& rSortArray,
bool bWeekendMask[ 7 ] )
{
@@ -353,12 +353,12 @@ sal_uInt16 ScInterpreter::GetWeekendAndHolidayMasks(
{
vector< double > nWeekendDays;
GetNumberSequenceArray( 1, nWeekendDays, false );
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
return nGlobalError;
else
{
if ( nWeekendDays.size() != 7 )
- return errIllegalArgument;
+ return FormulaError::IllegalArgument;
// Weekend days defined by string, Sunday...Saturday
for ( int i = 0; i < 7; i++ )
@@ -385,11 +385,11 @@ sal_uInt16 ScInterpreter::GetWeekendAndHolidayMasks(
return nGlobalError;
}
-sal_uInt16 ScInterpreter::GetWeekendAndHolidayMasks_MS(
+FormulaError ScInterpreter::GetWeekendAndHolidayMasks_MS(
const sal_uInt8 nParamCount, const sal_uInt32 nNullDate, vector< double >& rSortArray,
bool bWeekendMask[ 7 ], bool bWorkdayFunction )
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
OUString aWeekendDays;
if ( nParamCount == 4 )
{
@@ -409,7 +409,7 @@ sal_uInt16 ScInterpreter::GetWeekendAndHolidayMasks_MS(
{
case svDoubleRef :
case svExternalDoubleRef :
- return errNoValue;
+ return FormulaError::NoValue;
break;
default :
@@ -422,13 +422,13 @@ sal_uInt16 ScInterpreter::GetWeekendAndHolidayMasks_MS(
if ( fDouble >= 1.0 && fDouble <= 17 )
aWeekendDays = OUString::number( fDouble );
else
- return errNoValue;
+ return FormulaError::NoValue;
}
else
{
if ( aSharedString.isEmpty() || aSharedString.getLength() != 7 ||
( bWorkdayFunction && aSharedString.getString() == "1111111" ) )
- return errNoValue;
+ return FormulaError::NoValue;
else
aWeekendDays = aSharedString.getString();
}
@@ -461,7 +461,7 @@ sal_uInt16 ScInterpreter::GetWeekendAndHolidayMasks_MS(
case '5' : bWeekendMask[ WEDNESDAY ] = true; bWeekendMask[ THURSDAY ] = true; break;
case '6' : bWeekendMask[ THURSDAY ] = true; bWeekendMask[ FRIDAY ] = true; break;
case '7' : bWeekendMask[ FRIDAY ] = true; bWeekendMask[ SATURDAY ] = true; break;
- default : nErr = errIllegalArgument; break;
+ default : nErr = FormulaError::IllegalArgument; break;
}
break;
case 2 :
@@ -477,26 +477,26 @@ sal_uInt16 ScInterpreter::GetWeekendAndHolidayMasks_MS(
case '5' : bWeekendMask[ THURSDAY ] = true; break;
case '6' : bWeekendMask[ FRIDAY ] = true; break;
case '7' : bWeekendMask[ SATURDAY ] = true; break;
- default : nErr = errIllegalArgument; break;
+ default : nErr = FormulaError::IllegalArgument; break;
}
}
else
- nErr = errIllegalArgument;
+ nErr = FormulaError::IllegalArgument;
break;
case 7 :
// Weekend days defined by string
- for ( int i = 0; i < 7 && !nErr; i++ )
+ for ( int i = 0; i < 7 && nErr == FormulaError::NONE; i++ )
{
switch ( aWeekendDays[ i ] )
{
case '0' : bWeekendMask[ i ] = false; break;
case '1' : bWeekendMask[ i ] = true; break;
- default : nErr = errIllegalArgument; break;
+ default : nErr = FormulaError::IllegalArgument; break;
}
}
break;
default :
- nErr = errIllegalArgument;
+ nErr = FormulaError::IllegalArgument;
break;
}
}
@@ -512,7 +512,7 @@ void ScInterpreter::ScNetWorkdays( bool bOOXML_Version )
bool bWeekendMask[ 7 ];
Date aNullDate = *( pFormatter->GetNullDate() );
sal_uInt32 nNullDate = Date::DateToDays( aNullDate.GetDay(), aNullDate.GetMonth(), aNullDate.GetYear() );
- sal_uInt16 nErr;
+ FormulaError nErr;
if ( bOOXML_Version )
{
nErr = GetWeekendAndHolidayMasks_MS( nParamCount, nNullDate,
@@ -523,13 +523,13 @@ void ScInterpreter::ScNetWorkdays( bool bOOXML_Version )
nErr = GetWeekendAndHolidayMasks( nParamCount, nNullDate,
nSortArray, bWeekendMask );
}
- if ( nErr )
+ if ( nErr != FormulaError::NONE )
PushError( nErr );
else
{
sal_uInt32 nDate2 = GetUInt32();
sal_uInt32 nDate1 = GetUInt32();
- if (nGlobalError || (nDate1 > SAL_MAX_UINT32 - nNullDate) || nDate2 > (SAL_MAX_UINT32 - nNullDate))
+ if (nGlobalError != FormulaError::NONE || (nDate1 > SAL_MAX_UINT32 - nNullDate) || nDate2 > (SAL_MAX_UINT32 - nNullDate))
{
PushIllegalArgument();
return;
@@ -573,15 +573,15 @@ void ScInterpreter::ScWorkday_MS()
bool bWeekendMask[ 7 ];
Date aNullDate = *( pFormatter->GetNullDate() );
sal_uInt32 nNullDate = Date::DateToDays( aNullDate.GetDay(), aNullDate.GetMonth(), aNullDate.GetYear() );
- sal_uInt16 nErr = GetWeekendAndHolidayMasks_MS( nParamCount, nNullDate,
+ FormulaError nErr = GetWeekendAndHolidayMasks_MS( nParamCount, nNullDate,
nSortArray, bWeekendMask, true );
- if ( nErr )
+ if ( nErr != FormulaError::NONE )
PushError( nErr );
else
{
sal_Int32 nDays = GetInt32();
sal_uInt32 nDate = GetUInt32();
- if (nGlobalError || (nDate > SAL_MAX_UINT32 - nNullDate))
+ if (nGlobalError != FormulaError::NONE || (nDate > SAL_MAX_UINT32 - nNullDate))
{
PushIllegalArgument();
return;
@@ -643,9 +643,9 @@ void ScInterpreter::ScGetDate()
sal_Int16 nDay = GetInt16();
sal_Int16 nMonth = GetInt16();
if (IsMissing())
- SetError( errParameterExpected); // Year must be given.
+ SetError( FormulaError::ParameterExpected); // Year must be given.
sal_Int16 nYear = GetInt16();
- if (nGlobalError || nYear < 0)
+ if (nGlobalError != FormulaError::NONE || nYear < 0)
PushIllegalArgument();
else
{
@@ -717,7 +717,7 @@ void ScInterpreter::ScGetDiffDate360()
bFlag = false;
double nDate2 = GetDouble();
double nDate1 = GetDouble();
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
PushError( nGlobalError);
else
{
@@ -783,7 +783,7 @@ void ScInterpreter::ScGetDateDif()
double nDate2 = GetDouble();
double nDate1 = GetDouble();
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -980,7 +980,7 @@ void ScInterpreter::RoundNumber( rtl_math_RoundingMode eMode )
else
{
sal_Int16 nDec = GetInt16();
- if ( nGlobalError || nDec < -20 || nDec > 20 )
+ if ( nGlobalError != FormulaError::NONE || nDec < -20 || nDec > 20 )
PushIllegalArgument();
else
fVal = ::rtl::math::round( GetDouble(), nDec, eMode );
@@ -1268,7 +1268,7 @@ void ScInterpreter::ScNPV()
for( short i = 0; i < nParamCount; i++ )
pTemp[ i ] = pStack[ sp - i - 1 ];
memcpy( &pStack[ sp - nParamCount ], pTemp, nParamCount * sizeof( FormulaToken* ) );
- if (nGlobalError == 0)
+ if (nGlobalError == FormulaError::NONE)
{
double nCount = 1.0;
double nInterest = GetDouble();
@@ -1301,16 +1301,16 @@ void ScInterpreter::ScNPV()
case svDoubleRef :
case svRefList :
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
double nCellVal;
PopDoubleRef( aRange, nParamCount, nRefInList);
ScHorizontalValueIterator aValIter( pDok, aRange );
- while ((nErr == 0) && aValIter.GetNext(nCellVal, nErr))
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext(nCellVal, nErr))
{
nVal += (nCellVal / pow(1.0 + nInterest, (double)nCount));
nCount++;
}
- if ( nErr != 0 )
+ if ( nErr != FormulaError::NONE )
SetError(nErr);
}
break;
@@ -1349,7 +1349,7 @@ void ScInterpreter::ScNPV()
}
}
break;
- default : SetError(errIllegalParameter); break;
+ default : SetError(FormulaError::IllegalParameter); break;
}
}
}
@@ -1393,7 +1393,7 @@ void ScInterpreter::ScIRR()
sp = sPos; // reset stack
double fNom = 0.0;
double fDenom = 0.0;
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
PopDoubleRef( aRange );
ScValueIterator aValIter(pDok, aRange, mnSubTotalFlags);
if (aValIter.GetFirst(fValue, nErr))
@@ -1402,7 +1402,7 @@ void ScInterpreter::ScIRR()
fNom += fValue / pow(1.0+x,(double)nCount);
fDenom += -nCount * fValue / pow(1.0+x,nCount+1.0);
nCount++;
- while ((nErr == 0) && aValIter.GetNext(fValue, nErr))
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext(fValue, nErr))
{
fNom += fValue / pow(1.0+x,(double)nCount);
fDenom += -nCount * fValue / pow(1.0+x,nCount+1.0);
@@ -1420,7 +1420,7 @@ void ScInterpreter::ScIRR()
if (fEps < SCdEpsilon)
PushDouble(x);
else
- PushError( errNoConvergence);
+ PushError( FormulaError::NoConvergence);
}
void ScInterpreter::ScMIRR()
@@ -1450,19 +1450,19 @@ void ScInterpreter::ScMIRR()
{
pMat->GetDimensions( nC, nR );
if ( nC == 0 || nR == 0 )
- SetError( errIllegalArgument );
+ SetError( FormulaError::IllegalArgument );
bIsMatrix = true;
}
else
- SetError( errIllegalArgument );
+ SetError( FormulaError::IllegalArgument );
}
break;
default :
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
break;
}
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
PushError( nGlobalError );
else
{
@@ -1484,7 +1484,7 @@ void ScInterpreter::ScMIRR()
if ( !pMat->IsValue( j, k ) )
continue;
fX = pMat->GetDouble( j, k );
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
break;
if ( fX > 0.0 )
@@ -1507,7 +1507,7 @@ void ScInterpreter::ScMIRR()
{
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags );
double fCellValue;
- sal_uInt16 nIterError = 0;
+ FormulaError nIterError = FormulaError::NONE;
bool bLoop = aValIter.GetFirst( fCellValue, nIterError );
while( bLoop )
@@ -1529,13 +1529,13 @@ void ScInterpreter::ScMIRR()
bLoop = aValIter.GetNext( fCellValue, nIterError );
}
- if ( nIterError )
+ if ( nIterError != FormulaError::NONE )
SetError( nIterError );
}
if ( !( bHasPosValue && bHasNegValue ) )
- SetError( errIllegalArgument );
+ SetError( FormulaError::IllegalArgument );
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
PushError( nGlobalError );
else
{
@@ -1557,7 +1557,7 @@ void ScInterpreter::ScISPMT()
double fPeriod = GetDouble();
double fRate = GetDouble();
- if( nGlobalError )
+ if( nGlobalError != FormulaError::NONE )
PushError( nGlobalError);
else
PushDouble( fInvest * fRate * (fPeriod / fTotal - 1.0) );
@@ -2131,7 +2131,7 @@ void ScInterpreter::ScRate()
}
}
if (!bValid)
- SetError(errNoConvergence);
+ SetError(FormulaError::NoConvergence);
}
PushDouble(fGuess);
}
@@ -2356,7 +2356,7 @@ void ScInterpreter::ScIntersect()
formula::FormulaConstTokenRef p2nd = PopToken();
formula::FormulaConstTokenRef p1st = PopToken();
- if (nGlobalError || !p2nd || !p1st)
+ if (nGlobalError != FormulaError::NONE || !p2nd || !p1st)
{
PushIllegalArgument();
return;
@@ -2433,7 +2433,7 @@ void ScInterpreter::ScIntersect()
}
size_t n = pRefList->size();
if (!n)
- PushError( errNoRef);
+ PushError( FormulaError::NoRef);
else if (n == 1)
{
const ScComplexRefData& rRef = (*pRefList)[0];
@@ -2491,7 +2491,7 @@ void ScInterpreter::ScIntersect()
SCROW nRow2 = ::std::min( nR2[0], nR2[1]);
SCTAB nTab2 = ::std::min( nT2[0], nT2[1]);
if (nCol2 < nCol1 || nRow2 < nRow1 || nTab2 < nTab1)
- PushError( errNoRef);
+ PushError( FormulaError::NoRef);
else if (nCol2 == nCol1 && nRow2 == nRow1 && nTab2 == nTab1)
PushSingleRef( nCol1, nRow1, nTab1);
else
@@ -2504,7 +2504,7 @@ void ScInterpreter::ScRangeFunc()
formula::FormulaConstTokenRef x2 = PopToken();
formula::FormulaConstTokenRef x1 = PopToken();
- if (nGlobalError || !x2 || !x1)
+ if (nGlobalError != FormulaError::NONE || !x2 || !x1)
{
PushIllegalArgument();
return;
@@ -2524,7 +2524,7 @@ void ScInterpreter::ScUnionFunc()
formula::FormulaConstTokenRef p2nd = PopToken();
formula::FormulaConstTokenRef p1st = PopToken();
- if (nGlobalError || !p2nd || !p1st)
+ if (nGlobalError != FormulaError::NONE || !p2nd || !p1st)
{
PushIllegalArgument();
return;
@@ -2603,7 +2603,7 @@ void ScInterpreter::ScCurrent()
PushTokenRef( xTok);
}
else
- PushError( errUnknownStackVariable);
+ PushError( FormulaError::UnknownStackVariable);
}
void ScInterpreter::ScStyle()
@@ -2685,7 +2685,7 @@ void ScInterpreter::ScDde()
if (nParamCount == 4)
{
sal_uInt32 nTmp = GetUInt32();
- if (nGlobalError || nTmp > SAL_MAX_UINT8)
+ if (nGlobalError != FormulaError::NONE || nTmp > SAL_MAX_UINT8)
{
PushIllegalArgument();
return;
@@ -2726,7 +2726,7 @@ void ScInterpreter::ScDde()
//TODO: Save Dde-links (in addition) more efficient at document !!!!!
// ScDdeLink* pLink = pDok->GetDdeLink( aAppl, aTopic, aItem );
- bool bWasError = ( pMyFormulaCell && pMyFormulaCell->GetRawError() != 0 );
+ bool bWasError = ( pMyFormulaCell && pMyFormulaCell->GetRawError() != FormulaError::NONE );
if (!pLink)
{
@@ -2757,8 +2757,8 @@ void ScInterpreter::ScDde()
// If an new Error from Reschedule appears when the link is executed then reset the errorflag
- if ( pMyFormulaCell && pMyFormulaCell->GetRawError() && !bWasError )
- pMyFormulaCell->SetErrCode(0);
+ if ( pMyFormulaCell && pMyFormulaCell->GetRawError() != FormulaError::NONE && !bWasError )
+ pMyFormulaCell->SetErrCode(FormulaError::NONE);
// check the value
@@ -2817,7 +2817,7 @@ void ScInterpreter::ScBase()
if ( fChars >= SAL_MAX_UINT16 )
nMinLen = 0; // Error
- if ( !nGlobalError && nMinLen && 2 <= fBase && fBase <= nDigits && 0 <= fVal )
+ if ( nGlobalError == FormulaError::NONE && nMinLen && 2 <= fBase && fBase <= nDigits && 0 <= fVal )
{
const sal_Int32 nConstBuf = 128;
sal_Unicode aBuf[nConstBuf];
@@ -2895,7 +2895,7 @@ void ScInterpreter::ScBase()
}
}
if ( fVal )
- PushError( errStringOverflow );
+ PushError( FormulaError::StringOverflow );
else
{
if ( nBuf - (p - pBuf) <= nMinLen )
@@ -2916,7 +2916,7 @@ void ScInterpreter::ScDecimal()
{
double fBase = ::rtl::math::approxFloor( GetDouble() );
OUString aStr = GetString().getString();
- if ( !nGlobalError && 2 <= fBase && fBase <= 36 )
+ if ( nGlobalError == FormulaError::NONE && 2 <= fBase && fBase <= 36 )
{
double fVal = 0.0;
int nBase = (int) fBase;
@@ -2973,7 +2973,7 @@ void ScInterpreter::ScConvertOOo()
OUString aToUnit = GetString().getString();
OUString aFromUnit = GetString().getString();
double fVal = GetDouble();
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
PushError( nGlobalError);
else
{
@@ -2996,7 +2996,7 @@ void ScInterpreter::ScRoman()
{
double fMode = (nParamCount == 2) ? ::rtl::math::approxFloor( GetDouble() ) : 0.0;
double fVal = ::rtl::math::approxFloor( GetDouble() );
- if( nGlobalError )
+ if( nGlobalError != FormulaError::NONE )
PushError( nGlobalError);
else if( (fMode >= 0.0) && (fMode < 5.0) && (fVal >= 0.0) && (fVal < 4000.0) )
{
@@ -3079,7 +3079,7 @@ static bool lcl_GetArabicValue( sal_Unicode cChar, sal_uInt16& rnValue, bool& rb
void ScInterpreter::ScArabic()
{
OUString aRoman = GetString().getString();
- if( nGlobalError )
+ if( nGlobalError != FormulaError::NONE )
PushError( nGlobalError);
else
{
@@ -3165,8 +3165,8 @@ void ScInterpreter::ScHyperLink()
nResultType = SC_MATVAL_EMPTY;
else
{
- sal_uInt16 nErr = GetCellErrCode(aCell);
- if (nErr)
+ FormulaError nErr = GetCellErrCode(aCell);
+ if (nErr != FormulaError::NONE)
SetError( nErr);
else if (aCell.hasNumeric())
{
@@ -3190,17 +3190,17 @@ void ScInterpreter::ScHyperLink()
break;
default:
PopError();
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
}
svl::SharedString aUrl = GetString();
ScMatrixRef pResMat = GetNewMat( 1, 2);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
fVal = CreateDoubleError( nGlobalError);
nResultType = SC_MATVAL_VALUE;
}
- if (nParamCount == 2 || nGlobalError)
+ if (nParamCount == 2 || nGlobalError != FormulaError::NONE)
{
if (ScMatrix::IsValueType( nResultType))
pResMat->PutDouble( fVal, 0);
@@ -3283,7 +3283,7 @@ void ScInterpreter::ScEuroConvert()
OUString aToUnit = GetString().getString();
OUString aFromUnit = GetString().getString();
double fVal = GetDouble();
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
PushError( nGlobalError);
else
{
@@ -3441,7 +3441,7 @@ void ScInterpreter::ScBahtText()
if ( MustHaveParamCount( nParamCount, 1 ) )
{
double fValue = GetDouble();
- if( nGlobalError )
+ if( nGlobalError != FormulaError::NONE )
{
PushError( nGlobalError);
return;
@@ -3508,7 +3508,7 @@ void ScInterpreter::ScGetPivotData()
if (!MustHaveParamCount(nParamCount, 2, 30) || (nParamCount % 2) == 1)
{
- PushError(errNoRef);
+ PushError(FormulaError::NoRef);
return;
}
@@ -3542,7 +3542,7 @@ void ScInterpreter::ScGetPivotData()
}
break;
default:
- PushError(errNoRef);
+ PushError(FormulaError::NoRef);
return;
}
}
@@ -3574,7 +3574,7 @@ void ScInterpreter::ScGetPivotData()
double fDouble;
svl::SharedString aSharedString;
bool bDouble = GetDoubleOrString( fDouble, aSharedString);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -3628,7 +3628,7 @@ void ScInterpreter::ScGetPivotData()
}
break;
default:
- PushError(errNoRef);
+ PushError(FormulaError::NoRef);
return;
}
@@ -3636,7 +3636,7 @@ void ScInterpreter::ScGetPivotData()
}
// Early bail-out, don't grind through data pilot cache and all.
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -3648,7 +3648,7 @@ void ScInterpreter::ScGetPivotData()
ScDPObject* pDPObj = pDok->GetDPAtBlock(aBlock);
if (!pDPObj)
{
- PushError(errNoRef);
+ PushError(FormulaError::NoRef);
return;
}
@@ -3658,7 +3658,7 @@ void ScInterpreter::ScGetPivotData()
std::vector<sheet::GeneralFunction> aFilterFuncs;
if (!pDPObj->ParseFilters(aDataFieldName, aFilters, aFilterFuncs, aFilterStr))
{
- PushError(errNoRef);
+ PushError(FormulaError::NoRef);
return;
}
@@ -3670,7 +3670,7 @@ void ScInterpreter::ScGetPivotData()
double fVal = pDPObj->GetPivotData(aDataFieldName, aFilters);
if (rtl::math::isNan(fVal))
{
- PushError(errNoRef);
+ PushError(FormulaError::NoRef);
return;
}
PushDouble(fVal);
diff --git a/sc/source/core/tool/interpr3.cxx b/sc/source/core/tool/interpr3.cxx
index 5d51bade3c0d..9dcbbcf5fff8 100644
--- a/sc/source/core/tool/interpr3.cxx
+++ b/sc/source/core/tool/interpr3.cxx
@@ -166,7 +166,7 @@ static double lcl_IterateInverse( const ScDistFunc& rFunction, double fAx, doubl
void ScInterpreter::ScNoName()
{
- PushError(errNoName);
+ PushError(FormulaError::NoName);
}
void ScInterpreter::ScBadName()
@@ -176,7 +176,7 @@ void ScInterpreter::ScBadName()
{
PopError();
}
- PushError( errNoName);
+ PushError( FormulaError::NoName);
}
double ScInterpreter::phi(double x)
@@ -440,7 +440,7 @@ double ScInterpreter::Fakultaet(double x)
}
}
else
- SetError(errNoValue);
+ SetError(FormulaError::NoValue);
return x;
}
@@ -576,7 +576,7 @@ double ScInterpreter::GetGamma(double fZ)
if (fZ > fMaxGammaArgument)
{
- SetError(errIllegalFPOperation);
+ SetError(FormulaError::IllegalFPOperation);
return HUGE_VAL;
}
@@ -591,7 +591,7 @@ double ScInterpreter::GetGamma(double fZ)
double fLogTest = lcl_GetLogGammaHelper(fZ+2) - boost::math::log1p(fZ) - log( fabs(fZ));
if (fLogTest >= fLogDblMax)
{
- SetError( errIllegalFPOperation);
+ SetError( FormulaError::IllegalFPOperation);
return HUGE_VAL;
}
return lcl_GetGammaHelper(fZ+2) / (fZ+1) / fZ;
@@ -605,7 +605,7 @@ double ScInterpreter::GetGamma(double fZ)
if (fLogDivisor<0.0)
if (fLogPi - fLogDivisor > fLogDblMax) // overflow
{
- SetError(errIllegalFPOperation);
+ SetError(FormulaError::IllegalFPOperation);
return HUGE_VAL;
}
@@ -647,7 +647,7 @@ double ScInterpreter::GetTDist( double T, double fDF, int nType )
double R = 0.5 * GetBetaDist( X, 0.5 * fDF, 0.5 );
return ( T < 0 ? R : 1 - R );
}
- SetError( errIllegalArgument );
+ SetError( FormulaError::IllegalArgument );
return HUGE_VAL;
}
@@ -766,7 +766,7 @@ void ScInterpreter::ScGamma()
else
{
double fResult = GetGamma(x);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -857,7 +857,7 @@ double ScInterpreter::GetBetaDistPDF(double fX, double fA, double fB)
return -2.0*fX + 2.0;
if (fX == 1.0 && fB < 1.0)
{
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
return HUGE_VAL;
}
if (fX <= 0.01)
@@ -871,7 +871,7 @@ double ScInterpreter::GetBetaDistPDF(double fX, double fA, double fB)
return fA * fX;
if (fX == 0.0 && fA < 1.0)
{
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
return HUGE_VAL;
}
return fA * pow(fX,fA-1);
@@ -880,7 +880,7 @@ double ScInterpreter::GetBetaDistPDF(double fX, double fA, double fB)
{
if (fA < 1.0 && fX == 0.0)
{
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
return HUGE_VAL;
}
else
@@ -890,7 +890,7 @@ double ScInterpreter::GetBetaDistPDF(double fX, double fA, double fB)
{
if (fB < 1.0 && fX == 1.0)
{
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
return HUGE_VAL;
}
else
@@ -1431,7 +1431,7 @@ void ScInterpreter::ScCritBinom()
for (i = 0; i < max && fSum < alpha; i++)
{
const double x = GetBetaDistPDF( p, ( i + 1 ), ( n - i + 1 ) )/( n + 1 );
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
fSum += x;
}
@@ -1468,7 +1468,7 @@ void ScInterpreter::ScCritBinom()
for (i = 0; i < max && fSum < alpha; i++)
{
const double x = GetBetaDistPDF( q, ( i + 1 ), ( n - i + 1 ) )/( n + 1 );
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
fSum += x;
}
@@ -1735,7 +1735,7 @@ void ScInterpreter::ScChiDist()
return;
}
fResult = GetChiDist( fChi, fDF);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -1888,7 +1888,7 @@ void ScInterpreter::ScHypGeomDist_MS()
{
double fVal = 0.0;
- for ( int i = 0; i <= x && !nGlobalError; i++ )
+ for ( int i = 0; i <= x && nGlobalError == FormulaError::NONE; i++ )
fVal += GetHypGeomDist( i, n, M, N );
PushDouble( fVal );
@@ -2207,7 +2207,7 @@ void ScInterpreter::ScGammaInv()
double fStart = fAlpha * fBeta;
double fVal = lcl_IterateInverse( aFunc, fStart*0.5, fStart, bConvError );
if (bConvError)
- SetError(errNoConvergence);
+ SetError(FormulaError::NoConvergence);
PushDouble(fVal);
}
}
@@ -2257,7 +2257,7 @@ void ScInterpreter::ScBetaInv()
// 0..1 as range for iteration so it isn't extended beyond the valid range
double fVal = lcl_IterateInverse( aFunc, 0.0, 1.0, bConvError );
if (bConvError)
- PushError( errNoConvergence);
+ PushError( FormulaError::NoConvergence);
else
PushDouble(fA + fVal*(fB-fA)); // scale to (A,B)
}
@@ -2310,7 +2310,7 @@ double ScInterpreter::GetTInv( double fAlpha, double fSize, int nType )
ScTDistFunction aFunc( *this, fAlpha, fSize, nType );
double fVal = lcl_IterateInverse( aFunc, fSize * 0.5, fSize, bConvError );
if (bConvError)
- SetError(errNoConvergence);
+ SetError(FormulaError::NoConvergence);
return fVal;
}
@@ -2345,7 +2345,7 @@ void ScInterpreter::ScFInv()
ScFDistFunction aFunc( *this, fP, fF1, fF2 );
double fVal = lcl_IterateInverse( aFunc, fF1*0.5, fF1, bConvError );
if (bConvError)
- SetError(errNoConvergence);
+ SetError(FormulaError::NoConvergence);
PushDouble(fVal);
}
@@ -2366,7 +2366,7 @@ void ScInterpreter::ScFInv_LT()
ScFDistFunction aFunc( *this, ( 1.0 - fP ), fF1, fF2 );
double fVal = lcl_IterateInverse( aFunc, fF1*0.5, fF1, bConvError );
if (bConvError)
- SetError(errNoConvergence);
+ SetError(FormulaError::NoConvergence);
PushDouble(fVal);
}
@@ -2400,7 +2400,7 @@ void ScInterpreter::ScChiInv()
ScChiDistFunction aFunc( *this, fP, fDF );
double fVal = lcl_IterateInverse( aFunc, fDF*0.5, fDF, bConvError );
if (bConvError)
- SetError(errNoConvergence);
+ SetError(FormulaError::NoConvergence);
PushDouble(fVal);
}
@@ -2435,7 +2435,7 @@ void ScInterpreter::ScChiSqInv()
ScChiSqDistFunction aFunc( *this, fP, fDF );
double fVal = lcl_IterateInverse( aFunc, fDF*0.5, fDF, bConvError );
if (bConvError)
- SetError(errNoConvergence);
+ SetError(FormulaError::NoConvergence);
PushDouble(fVal);
}
@@ -2520,7 +2520,7 @@ void ScInterpreter::ScZTest()
while (nParam-- > 0)
{
ScRange aRange;
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
PopDoubleRef( aRange, nParam, nRefInList);
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags );
if (aValIter.GetFirst(fVal, nErr))
@@ -2528,7 +2528,7 @@ void ScInterpreter::ScZTest()
fSum += fVal;
fSumSqr += fVal*fVal;
rValCount++;
- while ((nErr == 0) && aValIter.GetNext(fVal, nErr))
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext(fVal, nErr))
{
fSum += fVal;
fSumSqr += fVal*fVal;
@@ -2571,10 +2571,10 @@ void ScInterpreter::ScZTest()
}
}
break;
- default : SetError(errIllegalParameter); break;
+ default : SetError(FormulaError::IllegalParameter); break;
}
if (rValCount <= 1.0)
- PushError( errDivisionByZero);
+ PushError( FormulaError::DivisionByZero);
else
{
double mue = fSum/rValCount;
@@ -2859,7 +2859,7 @@ void ScInterpreter::ScKurt()
if (fCount == 0.0)
{
- PushError( errDivisionByZero);
+ PushError( FormulaError::DivisionByZero);
return;
}
@@ -2873,7 +2873,7 @@ void ScInterpreter::ScKurt()
if (fStdDev == 0.0)
{
- PushError( errDivisionByZero);
+ PushError( FormulaError::DivisionByZero);
return;
}
@@ -2898,7 +2898,7 @@ void ScInterpreter::ScHarMean()
ScAddress aAdr;
ScRange aRange;
size_t nRefInList = 0;
- while ((nGlobalError == 0) && (nParamCount-- > 0))
+ while ((nGlobalError == FormulaError::NONE) && (nParamCount-- > 0))
{
switch (GetStackType())
{
@@ -2911,7 +2911,7 @@ void ScInterpreter::ScHarMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
break;
}
case svSingleRef :
@@ -2927,14 +2927,14 @@ void ScInterpreter::ScHarMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
break;
}
case formula::svDoubleRef :
case svRefList :
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
PopDoubleRef( aRange, nParamCount, nRefInList);
double nCellVal;
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags );
@@ -2946,9 +2946,9 @@ void ScInterpreter::ScHarMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
SetError(nErr);
- while ((nErr == 0) && aValIter.GetNext(nCellVal, nErr))
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext(nCellVal, nErr))
{
if (nCellVal > 0.0)
{
@@ -2956,7 +2956,7 @@ void ScInterpreter::ScHarMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
SetError(nErr);
}
@@ -2981,7 +2981,7 @@ void ScInterpreter::ScHarMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
}
else
@@ -2996,16 +2996,16 @@ void ScInterpreter::ScHarMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
}
}
}
break;
- default : SetError(errIllegalParameter); break;
+ default : SetError(FormulaError::IllegalParameter); break;
}
}
- if (nGlobalError == 0)
+ if (nGlobalError == FormulaError::NONE)
PushDouble((double)nValCount/nVal);
else
PushError( nGlobalError);
@@ -3020,7 +3020,7 @@ void ScInterpreter::ScGeoMean()
ScRange aRange;
size_t nRefInList = 0;
- while ((nGlobalError == 0) && (nParamCount-- > 0))
+ while ((nGlobalError == FormulaError::NONE) && (nParamCount-- > 0))
{
switch (GetStackType())
{
@@ -3033,7 +3033,7 @@ void ScInterpreter::ScGeoMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
break;
}
case svSingleRef :
@@ -3049,14 +3049,14 @@ void ScInterpreter::ScGeoMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
break;
}
case formula::svDoubleRef :
case svRefList :
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
PopDoubleRef( aRange, nParamCount, nRefInList);
double nCellVal;
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags );
@@ -3068,9 +3068,9 @@ void ScInterpreter::ScGeoMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
SetError(nErr);
- while ((nErr == 0) && aValIter.GetNext(nCellVal, nErr))
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext(nCellVal, nErr))
{
if (nCellVal > 0.0)
{
@@ -3078,7 +3078,7 @@ void ScInterpreter::ScGeoMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
SetError(nErr);
}
@@ -3103,7 +3103,7 @@ void ScInterpreter::ScGeoMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
}
else
@@ -3118,16 +3118,16 @@ void ScInterpreter::ScGeoMean()
nValCount++;
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
}
}
}
break;
- default : SetError(errIllegalParameter); break;
+ default : SetError(FormulaError::IllegalParameter); break;
}
}
- if (nGlobalError == 0)
+ if (nGlobalError == FormulaError::NONE)
PushDouble(exp(nVal / nValCount));
else
PushError( nGlobalError);
@@ -3141,9 +3141,9 @@ void ScInterpreter::ScStandard()
double mue = GetDouble();
double x = GetDouble();
if (sigma < 0.0)
- PushError( errIllegalArgument);
+ PushError( FormulaError::IllegalArgument);
else if (sigma == 0.0)
- PushError( errDivisionByZero);
+ PushError( FormulaError::DivisionByZero);
else
PushDouble((x-mue)/sigma);
}
@@ -3190,7 +3190,7 @@ bool ScInterpreter::CalculateSkew(double& fSum,double& fCount,double& vSum,std::
case svRefList :
{
PopDoubleRef( aRange, nParamCount, nRefInList);
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags );
if (aValIter.GetFirst(fVal, nErr))
{
@@ -3198,7 +3198,7 @@ bool ScInterpreter::CalculateSkew(double& fSum,double& fCount,double& vSum,std::
values.push_back(fVal);
fCount++;
SetError(nErr);
- while ((nErr == 0) && aValIter.GetNext(fVal, nErr))
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext(fVal, nErr))
{
fSum += fVal;
values.push_back(fVal);
@@ -3241,16 +3241,16 @@ bool ScInterpreter::CalculateSkew(double& fSum,double& fCount,double& vSum,std::
}
break;
default :
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
break;
}
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return false;
- } // if (nGlobalError)
+ } // if (nGlobalError != FormulaError::NONE)
return true;
}
@@ -3300,9 +3300,9 @@ void ScInterpreter::ScSkewp()
double ScInterpreter::GetMedian( vector<double> & rArray )
{
size_t nSize = rArray.size();
- if (rArray.empty() || nSize == 0 || nGlobalError)
+ if (rArray.empty() || nSize == 0 || nGlobalError != FormulaError::NONE)
{
- SetError( errNoValue);
+ SetError( FormulaError::NoValue);
return 0.0;
}
@@ -3360,14 +3360,14 @@ double ScInterpreter::GetPercentile( vector<double> & rArray, double fPercentile
double ScInterpreter::GetPercentileExclusive( vector<double> & rArray, double fPercentile )
{
size_t nSize1 = rArray.size() + 1;
- if ( rArray.empty() || nSize1 == 1 || nGlobalError )
+ if ( rArray.empty() || nSize1 == 1 || nGlobalError != FormulaError::NONE)
{
- SetError( errNoValue );
+ SetError( FormulaError::NoValue );
return 0.0;
}
if ( fPercentile * nSize1 < 1.0 || fPercentile * nSize1 > (double) ( nSize1 - 1 ) )
{
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
return 0.0;
}
@@ -3400,9 +3400,9 @@ void ScInterpreter::ScPercentile( bool bInclusive )
}
vector<double> aArray;
GetNumberSequenceArray( 1, aArray, false );
- if ( aArray.empty() || aArray.size() == 0 || nGlobalError )
+ if ( aArray.empty() || aArray.size() == 0 || nGlobalError != FormulaError::NONE )
{
- SetError( errNoValue );
+ SetError( FormulaError::NoValue );
return;
}
if ( bInclusive )
@@ -3423,9 +3423,9 @@ void ScInterpreter::ScQuartile( bool bInclusive )
}
vector<double> aArray;
GetNumberSequenceArray( 1, aArray, false );
- if ( aArray.empty() || aArray.size() == 0 || nGlobalError )
+ if ( aArray.empty() || aArray.size() == 0 || nGlobalError != FormulaError::NONE )
{
- SetError( errNoValue );
+ SetError( FormulaError::NoValue );
return;
}
if ( bInclusive )
@@ -3442,7 +3442,7 @@ void ScInterpreter::ScModalValue()
vector<double> aSortArray;
GetSortArray( nParamCount, aSortArray, nullptr, false, false );
SCSIZE nSize = aSortArray.size();
- if (aSortArray.empty() || nSize == 0 || nGlobalError)
+ if (aSortArray.empty() || nSize == 0 || nGlobalError != FormulaError::NONE)
PushNoValue();
else
{
@@ -3497,7 +3497,7 @@ void ScInterpreter::CalculateSmallLarge(bool bSmall)
* we may or will need a real sorted array again, see #i32345. */
GetNumberSequenceArray(1, aSortArray, false );
SCSIZE nSize = aSortArray.size();
- if (aSortArray.empty() || nSize == 0 || nGlobalError || nSize < k)
+ if (aSortArray.empty() || nSize == 0 || nGlobalError != FormulaError::NONE || nSize < k)
PushNoValue();
else
{
@@ -3528,7 +3528,7 @@ void ScInterpreter::ScPercentrank( bool bInclusive )
vector<double> aSortArray;
GetSortArray( 1, aSortArray, nullptr, false, false );
SCSIZE nSize = aSortArray.size();
- if ( aSortArray.empty() || nSize == 0 || nGlobalError )
+ if ( aSortArray.empty() || nSize == 0 || nGlobalError != FormulaError::NONE )
PushNoValue();
else
{
@@ -3621,7 +3621,7 @@ void ScInterpreter::ScTrimMean()
vector<double> aSortArray;
GetSortArray( 1, aSortArray, nullptr, false, false );
SCSIZE nSize = aSortArray.size();
- if (aSortArray.empty() || nSize == 0 || nGlobalError)
+ if (aSortArray.empty() || nSize == 0 || nGlobalError != FormulaError::NONE)
PushNoValue();
else
{
@@ -3663,7 +3663,7 @@ void ScInterpreter::GetNumberSequenceArray( sal_uInt8 nParamCount, vector<double
case svRefList :
{
PopDoubleRef( aRange, nParam, nRefInList);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
break;
aRange.PutInOrder();
@@ -3671,14 +3671,14 @@ void ScInterpreter::GetNumberSequenceArray( sal_uInt8 nParamCount, vector<double
nCellCount *= aRange.aEnd.Row() - aRange.aStart.Row() + 1;
rArray.reserve( rArray.size() + nCellCount);
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
double fCellVal;
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags );
if (aValIter.GetFirst( fCellVal, nErr))
{
rArray.push_back( fCellVal);
SetError(nErr);
- while ((nErr == 0) && aValIter.GetNext( fCellVal, nErr))
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext( fCellVal, nErr))
rArray.push_back( fCellVal);
SetError(nErr);
}
@@ -3711,23 +3711,23 @@ void ScInterpreter::GetNumberSequenceArray( sal_uInt8 nParamCount, vector<double
OUString aStr = pMat->GetString( i ).getString();
if ( aStr.getLength() > 0 )
{
- sal_uInt16 nErr = nGlobalError;
- nGlobalError = 0;
+ FormulaError nErr = nGlobalError;
+ nGlobalError = FormulaError::NONE;
double fVal = ConvertStringToValue( aStr );
- if ( !nGlobalError )
+ if ( nGlobalError == FormulaError::NONE )
{
rArray.push_back( fVal );
nGlobalError = nErr;
}
else
{
- rArray.push_back( CreateDoubleError( errNoValue));
+ rArray.push_back( CreateDoubleError( FormulaError::NoValue));
// Propagate previous error if any, else
// the current #VALUE! error.
- if (nErr)
+ if (nErr != FormulaError::NONE)
nGlobalError = nErr;
else
- nGlobalError = errNoValue;
+ nGlobalError = FormulaError::NoValue;
}
}
}
@@ -3745,10 +3745,10 @@ void ScInterpreter::GetNumberSequenceArray( sal_uInt8 nParamCount, vector<double
break;
default :
PopError();
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
break;
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
break; // while
}
// nParam > 0 in case of error, clean stack environment and obtain earlier
@@ -3761,15 +3761,15 @@ void ScInterpreter::GetSortArray( sal_uInt8 nParamCount, vector<double>& rSortAr
{
GetNumberSequenceArray( nParamCount, rSortArray, bConvertTextInArray );
if (rSortArray.size() > MAX_ANZ_DOUBLE_FOR_SORT)
- SetError( errMatrixSize);
+ SetError( FormulaError::MatrixSize);
else if ( rSortArray.empty() )
{
if ( bAllowEmptyArray )
return;
- SetError( errNoValue);
+ SetError( FormulaError::NoValue);
}
- if (nGlobalError == 0)
+ if (nGlobalError == FormulaError::NONE)
QuickSort( rSortArray, pIndexOrder);
}
@@ -3866,7 +3866,7 @@ void ScInterpreter::ScRank( bool bAverage )
GetSortArray( 1, aSortArray, nullptr, false, false );
double fVal = GetDouble();
SCSIZE nSize = aSortArray.size();
- if ( aSortArray.empty() || nSize == 0 || nGlobalError )
+ if ( aSortArray.empty() || nSize == 0 || nGlobalError != FormulaError::NONE )
PushNoValue();
else
{
@@ -3878,7 +3878,7 @@ void ScInterpreter::ScRank( bool bAverage )
double fFirstPos = -1.0;
bool bFinished = false;
SCSIZE i;
- for ( i = 0; i < nSize && !bFinished && !nGlobalError; i++ )
+ for ( i = 0; i < nSize && !bFinished && nGlobalError == FormulaError::NONE; i++ )
{
if ( aSortArray[ i ] == fVal )
{
@@ -3949,7 +3949,7 @@ void ScInterpreter::ScAveDev()
case formula::svDoubleRef :
case svRefList :
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
double nCellVal;
PopDoubleRef( aRange, nParam, nRefInList);
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags );
@@ -3958,7 +3958,7 @@ void ScInterpreter::ScAveDev()
rVal += nCellVal;
rValCount++;
SetError(nErr);
- while ((nErr == 0) && aValIter.GetNext(nCellVal, nErr))
+ while ((nErr == FormulaError::NONE) && aValIter.GetNext(nCellVal, nErr))
{
rVal += nCellVal;
rValCount++;
@@ -3996,11 +3996,11 @@ void ScInterpreter::ScAveDev()
}
break;
default :
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
break;
}
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -4028,7 +4028,7 @@ void ScInterpreter::ScAveDev()
case formula::svDoubleRef :
case svRefList :
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
double nCellVal;
PopDoubleRef( aRange, nParam, nRefInList);
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags );
@@ -4066,7 +4066,7 @@ void ScInterpreter::ScAveDev()
}
}
break;
- default : SetError(errIllegalParameter); break;
+ default : SetError(FormulaError::IllegalParameter); break;
}
}
PushDouble(rVal / rValCount);
@@ -4134,7 +4134,7 @@ void ScInterpreter::ScProbability()
}
}
else
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
}
if (bStop || fabs(fSum -1.0) > 1.0E-7)
@@ -4238,7 +4238,7 @@ void ScInterpreter::CalculatePearsonCovar( bool _bPearson, bool _bStexy, bool _b
if ( _bPearson )
{
if (fSumSqrDeltaX == 0.0 || ( !_bStexy && fSumSqrDeltaY == 0.0) )
- PushError( errDivisionByZero);
+ PushError( FormulaError::DivisionByZero);
else if ( _bStexy )
PushDouble( sqrt( (fSumSqrDeltaY - fSumDeltaXDeltaY *
fSumDeltaXDeltaY / fSumSqrDeltaX) / (fCount-2)));
@@ -4259,7 +4259,7 @@ void ScInterpreter::ScRSQ()
{
// Same as ScPearson()*ScPearson()
ScPearson();
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
{
switch (GetStackType())
{
@@ -4341,7 +4341,7 @@ void ScInterpreter::CalculateSlopeIntercept(bool bSlope)
}
}
if (fSumSqrDeltaX == 0.0)
- PushError( errDivisionByZero);
+ PushError( FormulaError::DivisionByZero);
else
{
if ( bSlope )
@@ -4424,7 +4424,7 @@ void ScInterpreter::ScForecast()
}
}
if (fSumSqrDeltaX == 0.0)
- PushError( errDivisionByZero);
+ PushError( FormulaError::DivisionByZero);
else
PushDouble( fMeanY + fSumDeltaXDeltaY / fSumSqrDeltaX * (fVal - fMeanX));
}
diff --git a/sc/source/core/tool/interpr4.cxx b/sc/source/core/tool/interpr4.cxx
index 174eeb039ecc..2f1740c3a4bd 100644
--- a/sc/source/core/tool/interpr4.cxx
+++ b/sc/source/core/tool/interpr4.cxx
@@ -151,18 +151,18 @@ bool ScInterpreter::IsTableOpInRange( const ScRange& rRange )
sal_uLong ScInterpreter::GetCellNumberFormat( const ScAddress& rPos, ScRefCellValue& rCell )
{
sal_uLong nFormat;
- sal_uInt16 nErr;
+ FormulaError nErr;
if (rCell.isEmpty())
{
nFormat = pDok->GetNumberFormat( rPos );
- nErr = 0;
+ nErr = FormulaError::NONE;
}
else
{
if (rCell.meType == CELLTYPE_FORMULA)
nErr = rCell.mpFormula->GetErrCode();
else
- nErr = 0;
+ nErr = FormulaError::NONE;
nFormat = pDok->GetNumberFormat( rPos );
}
@@ -181,32 +181,32 @@ double ScInterpreter::GetValueCellValue( const ScAddress& rPos, double fOrig )
return fOrig;
}
-sal_uInt16 ScInterpreter::GetCellErrCode( const ScRefCellValue& rCell )
+FormulaError ScInterpreter::GetCellErrCode( const ScRefCellValue& rCell )
{
- return rCell.meType == CELLTYPE_FORMULA ? rCell.mpFormula->GetErrCode() : 0;
+ return rCell.meType == CELLTYPE_FORMULA ? rCell.mpFormula->GetErrCode() : FormulaError::NONE;
}
double ScInterpreter::ConvertStringToValue( const OUString& rStr )
{
- sal_uInt16 nError = 0;
+ FormulaError nError = FormulaError::NONE;
double fValue = ScGlobal::ConvertStringToValue( rStr, maCalcConfig, nError, mnStringNoValueError,
pFormatter, nCurFmtType);
- if (nError)
+ if (nError != FormulaError::NONE)
SetError(nError);
return fValue;
}
-double ScInterpreter::ConvertStringToValue( const OUString& rStr, sal_uInt16& rError, short& rCurFmtType )
+double ScInterpreter::ConvertStringToValue( const OUString& rStr, FormulaError& rError, short& rCurFmtType )
{
return ScGlobal::ConvertStringToValue( rStr, maCalcConfig, rError, mnStringNoValueError, pFormatter, rCurFmtType);
}
double ScInterpreter::GetCellValue( const ScAddress& rPos, ScRefCellValue& rCell )
{
- sal_uInt16 nErr = nGlobalError;
- nGlobalError = 0;
+ FormulaError nErr = nGlobalError;
+ nGlobalError = FormulaError::NONE;
double nVal = GetCellValueOrZero(rPos, rCell);
- if ( !nGlobalError || nGlobalError == errCellNoValue )
+ if ( nGlobalError == FormulaError::NONE || nGlobalError == FormulaError::CellNoValue )
nGlobalError = nErr;
return nVal;
}
@@ -221,8 +221,8 @@ double ScInterpreter::GetCellValueOrZero( const ScAddress& rPos, ScRefCellValue&
case CELLTYPE_FORMULA:
{
ScFormulaCell* pFCell = rCell.mpFormula;
- sal_uInt16 nErr = pFCell->GetErrCode();
- if( !nErr )
+ FormulaError nErr = pFCell->GetErrCode();
+ if( nErr == FormulaError::NONE )
{
if (pFCell->IsValue())
{
@@ -270,7 +270,7 @@ double ScInterpreter::GetCellValueOrZero( const ScAddress& rPos, ScRefCellValue&
void ScInterpreter::GetCellString( svl::SharedString& rStr, ScRefCellValue& rCell )
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
switch (rCell.meType)
{
@@ -354,7 +354,7 @@ bool ScInterpreter::CreateDoubleArr(SCCOL nCol1, SCROW nRow1, SCTAB nTab1,
ScRefCellValue aCell(*pDok, aAdr);
if (!aCell.isEmpty())
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
double nVal = 0.0;
bool bOk = true;
switch (aCell.meType)
@@ -382,7 +382,7 @@ bool ScInterpreter::CreateDoubleArr(SCCOL nCol1, SCROW nRow1, SCTAB nTab1,
*p++ = static_cast<sal_uInt16>(nCol);
*p++ = static_cast<sal_uInt16>(nRow);
*p++ = static_cast<sal_uInt16>(nTab);
- *p++ = nErr;
+ *p++ = static_cast<sal_uInt16>(nErr);
memcpy( p, &nVal, sizeof(double));
nPos += 8 + sizeof(double);
p = reinterpret_cast<sal_uInt16*>( pCellArr + nPos );
@@ -435,7 +435,7 @@ bool ScInterpreter::CreateStringArr(SCCOL nCol1, SCROW nRow1, SCTAB nTab1,
if (!aCell.isEmpty())
{
OUString aStr;
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
bool bOk = true;
switch (aCell.meType)
{
@@ -474,7 +474,7 @@ bool ScInterpreter::CreateStringArr(SCCOL nCol1, SCROW nRow1, SCTAB nTab1,
*p++ = static_cast<sal_uInt16>(nCol);
*p++ = static_cast<sal_uInt16>(nRow);
*p++ = static_cast<sal_uInt16>(nTab);
- *p++ = nErr;
+ *p++ = static_cast<sal_uInt16>(nErr);
*p++ = nLen;
memcpy( p, aTmp.getStr(), nStrLen + 1);
nPos += 10 + nStrLen + 1;
@@ -537,7 +537,7 @@ bool ScInterpreter::CreateCellArr(SCCOL nCol1, SCROW nRow1, SCTAB nTab1,
ScRefCellValue aCell(*pDok, aAdr);
if (!aCell.isEmpty())
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
sal_uInt16 nType = 0; // 0 = Zahl; 1 = String
double nVal = 0.0;
OUString aStr;
@@ -570,7 +570,7 @@ bool ScInterpreter::CreateCellArr(SCCOL nCol1, SCROW nRow1, SCTAB nTab1,
*p++ = static_cast<sal_uInt16>(nCol);
*p++ = static_cast<sal_uInt16>(nRow);
*p++ = static_cast<sal_uInt16>(nTab);
- *p++ = nErr;
+ *p++ = static_cast<sal_uInt16>(nErr);
*p++ = nType;
nPos += 10;
if (nType == 0)
@@ -625,7 +625,7 @@ bool ScInterpreter::CreateCellArr(SCCOL nCol1, SCROW nRow1, SCTAB nTab1,
void ScInterpreter::PushWithoutError( const FormulaToken& r )
{
if ( sp >= MAXSTACK )
- SetError( errStackOverflow );
+ SetError( FormulaError::StackOverflow );
else
{
r.IncRef();
@@ -641,10 +641,10 @@ void ScInterpreter::PushWithoutError( const FormulaToken& r )
void ScInterpreter::Push( const FormulaToken& r )
{
if ( sp >= MAXSTACK )
- SetError( errStackOverflow );
+ SetError( FormulaError::StackOverflow );
else
{
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
if (r.GetType() == svError)
PushWithoutError( r);
@@ -660,13 +660,13 @@ void ScInterpreter::PushTempToken( FormulaToken* p )
{
if ( sp >= MAXSTACK )
{
- SetError( errStackOverflow );
+ SetError( FormulaError::StackOverflow );
// p may be a dangling pointer hereafter!
p->DeleteIfZeroRef();
}
else
{
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
if (p->GetType() == svError)
{
@@ -690,7 +690,7 @@ void ScInterpreter::PushTempTokenWithoutError( const FormulaToken* p )
p->IncRef();
if ( sp >= MAXSTACK )
{
- SetError( errStackOverflow );
+ SetError( FormulaError::StackOverflow );
// p may be a dangling pointer hereafter!
p->DecRef();
}
@@ -709,11 +709,11 @@ void ScInterpreter::PushTokenRef( const formula::FormulaConstTokenRef& x )
{
if ( sp >= MAXSTACK )
{
- SetError( errStackOverflow );
+ SetError( FormulaError::StackOverflow );
}
else
{
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
if (x->GetType() == svError && x->GetError() == nGlobalError)
PushTempTokenWithoutError( x.get());
@@ -738,11 +738,11 @@ void ScInterpreter::PushCellResultToken( bool bDisplayEmptyAsString,
return;
}
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
if (aCell.meType == CELLTYPE_FORMULA)
nErr = aCell.mpFormula->GetErrCode();
- if (nErr)
+ if (nErr != FormulaError::NONE)
{
PushError( nErr);
if (pRetTypeExpr)
@@ -787,7 +787,7 @@ void ScInterpreter::Pop()
if( sp )
sp--;
else
- SetError(errUnknownStackVariable);
+ SetError(FormulaError::UnknownStackVariable);
}
// Simply throw away TOS and set error code, used with ocIsError et al.
@@ -801,7 +801,7 @@ void ScInterpreter::PopError()
nGlobalError = pStack[sp]->GetError();
}
else
- SetError(errUnknownStackVariable);
+ SetError(FormulaError::UnknownStackVariable);
}
FormulaConstTokenRef ScInterpreter::PopToken()
@@ -815,7 +815,7 @@ FormulaConstTokenRef ScInterpreter::PopToken()
return p;
}
else
- SetError(errUnknownStackVariable);
+ SetError(FormulaError::UnknownStackVariable);
return nullptr;
}
@@ -843,11 +843,11 @@ double ScInterpreter::PopDouble()
case svMissing:
return 0.0;
default:
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
}
else
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
return 0.0;
}
@@ -870,11 +870,11 @@ svl::SharedString ScInterpreter::PopString()
case svMissing:
return svl::SharedString::getEmptyString();
default:
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
}
else
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
return svl::SharedString::getEmptyString();
}
@@ -923,17 +923,17 @@ void ScInterpreter::SingleRefToVars( const ScSingleRefData & rRef,
if( !ValidCol( rCol) || rRef.IsColDeleted() )
{
- SetError( errNoRef );
+ SetError( FormulaError::NoRef );
rCol = 0;
}
if( !ValidRow( rRow) || rRef.IsRowDeleted() )
{
- SetError( errNoRef );
+ SetError( FormulaError::NoRef );
rRow = 0;
}
if( !ValidTab( rTab, pDok->GetTableCount() - 1) || rRef.IsTabDeleted() )
{
- SetError( errNoRef );
+ SetError( FormulaError::NoRef );
rTab = 0;
}
}
@@ -955,11 +955,11 @@ void ScInterpreter::PopSingleRef(SCCOL& rCol, SCROW &rRow, SCTAB& rTab)
ReplaceCell( rCol, rRow, rTab );
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
}
else
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
}
void ScInterpreter::PopSingleRef( ScAddress& rAdr )
@@ -985,11 +985,11 @@ void ScInterpreter::PopSingleRef( ScAddress& rAdr )
}
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
}
else
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
}
void ScInterpreter::DoubleRefToVars( const formula::FormulaToken* p,
@@ -1003,7 +1003,7 @@ void ScInterpreter::DoubleRefToVars( const formula::FormulaToken* p,
{
ScRange aRange( rCol1, rRow1, rTab1, rCol2, rRow2, rTab2 );
if ( IsTableOpInRange( aRange ) )
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
}
}
@@ -1013,7 +1013,7 @@ ScDBRangeBase* ScInterpreter::PopDBDoubleRef()
switch (eType)
{
case svUnknown:
- SetError(errUnknownStackVariable);
+ SetError(FormulaError::UnknownStackVariable);
break;
case svError:
PopError();
@@ -1024,7 +1024,7 @@ ScDBRangeBase* ScInterpreter::PopDBDoubleRef()
SCROW nRow1, nRow2;
SCTAB nTab1, nTab2;
PopDoubleRef(nCol1, nRow1, nTab1, nCol2, nRow2, nTab2);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
break;
return new ScDBInternalRange(pDok,
ScRange(nCol1, nRow1, nTab1, nCol2, nRow2, nTab2));
@@ -1037,12 +1037,12 @@ ScDBRangeBase* ScInterpreter::PopDBDoubleRef()
pMat = PopMatrix();
else
PopExternalDoubleRef(pMat);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
break;
return new ScDBExternalRange(pDok, pMat);
}
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
return nullptr;
@@ -1064,11 +1064,11 @@ void ScInterpreter::PopDoubleRef(SCCOL& rCol1, SCROW &rRow1, SCTAB& rTab1,
DoubleRefToVars( p, rCol1, rRow1, rTab1, rCol2, rRow2, rTab2);
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
}
else
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
}
void ScInterpreter::DoubleRefToRange( const ScComplexRefData & rCRef,
@@ -1085,7 +1085,7 @@ void ScInterpreter::DoubleRefToRange( const ScComplexRefData & rCRef,
if (!pDok->m_TableOpList.empty() && !bDontCheckForTableOp)
{
if ( IsTableOpInRange( rRange ) )
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
}
}
@@ -1121,16 +1121,16 @@ void ScInterpreter::PopDoubleRef( ScRange & rRange, short & rParam, size_t & rRe
{
--sp;
rRefInList = 0;
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
}
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
}
else
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
}
void ScInterpreter::PopDoubleRef( ScRange& rRange, bool bDontCheckForTableOp )
@@ -1148,18 +1148,18 @@ void ScInterpreter::PopDoubleRef( ScRange& rRange, bool bDontCheckForTableOp )
DoubleRefToRange( *p->GetDoubleRef(), rRange, bDontCheckForTableOp);
break;
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
}
else
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
}
void ScInterpreter::PopExternalSingleRef(sal_uInt16& rFileId, OUString& rTabName, ScSingleRefData& rRef)
{
if (!sp)
{
- SetError(errUnknownStackVariable);
+ SetError(FormulaError::UnknownStackVariable);
return;
}
@@ -1175,7 +1175,7 @@ void ScInterpreter::PopExternalSingleRef(sal_uInt16& rFileId, OUString& rTabName
if (eType != svExternalSingleRef)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return;
}
@@ -1197,21 +1197,21 @@ void ScInterpreter::PopExternalSingleRef(
ScExternalRefCache::TokenRef& rToken, ScExternalRefCache::CellFormat* pFmt)
{
PopExternalSingleRef(rFileId, rTabName, rRef);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return;
ScExternalRefManager* pRefMgr = pDok->GetExternalRefManager();
const OUString* pFile = pRefMgr->getExternalFileName(rFileId);
if (!pFile)
{
- SetError(errNoName);
+ SetError(FormulaError::NoName);
return;
}
if (rRef.IsTabRel())
{
OSL_FAIL("ScCompiler::GetToken: external single reference must have an absolute table reference!");
- SetError(errNoRef);
+ SetError(FormulaError::NoRef);
return;
}
@@ -1222,7 +1222,7 @@ void ScInterpreter::PopExternalSingleRef(
if (!xNew)
{
- SetError(errNoRef);
+ SetError(FormulaError::NoRef);
return;
}
@@ -1238,7 +1238,7 @@ void ScInterpreter::PopExternalDoubleRef(sal_uInt16& rFileId, OUString& rTabName
{
if (!sp)
{
- SetError(errUnknownStackVariable);
+ SetError(FormulaError::UnknownStackVariable);
return;
}
@@ -1254,7 +1254,7 @@ void ScInterpreter::PopExternalDoubleRef(sal_uInt16& rFileId, OUString& rTabName
if (eType != svExternalDoubleRef)
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return;
}
@@ -1269,11 +1269,11 @@ void ScInterpreter::PopExternalDoubleRef(ScExternalRefCache::TokenArrayRef& rArr
OUString aTabName;
ScComplexRefData aData;
PopExternalDoubleRef(nFileId, aTabName, aData);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return;
GetExternalDoubleRef(nFileId, aTabName, aData, rArray);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return;
}
@@ -1281,7 +1281,7 @@ void ScInterpreter::PopExternalDoubleRef(ScMatrixRef& rMat)
{
ScExternalRefCache::TokenArrayRef pArray;
PopExternalDoubleRef(pArray);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return;
// For now, we only support single range data for external
@@ -1289,12 +1289,12 @@ void ScInterpreter::PopExternalDoubleRef(ScMatrixRef& rMat)
// single matrix token.
formula::FormulaToken* p = pArray->First();
if (!p || p->GetType() != svMatrix)
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
else
{
rMat = p->GetMatrix();
if (!rMat)
- SetError( errUnknownVariable);
+ SetError( FormulaError::UnknownVariable);
}
}
@@ -1305,13 +1305,13 @@ void ScInterpreter::GetExternalDoubleRef(
const OUString* pFile = pRefMgr->getExternalFileName(nFileId);
if (!pFile)
{
- SetError(errNoName);
+ SetError(FormulaError::NoName);
return;
}
if (rData.Ref1.IsTabRel() || rData.Ref2.IsTabRel())
{
OSL_FAIL("ScCompiler::GetToken: external double reference must have an absolute table reference!");
- SetError(errNoRef);
+ SetError(FormulaError::NoRef);
return;
}
@@ -1322,7 +1322,7 @@ void ScInterpreter::GetExternalDoubleRef(
if (!pArray)
{
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
return;
}
@@ -1334,14 +1334,14 @@ void ScInterpreter::GetExternalDoubleRef(
}
if (pToken->GetType() != svMatrix)
{
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
return;
}
if (pArray->Next())
{
// Can't handle more than one matrix per parameter.
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
return;
}
@@ -1365,7 +1365,7 @@ bool ScInterpreter::PopDoubleRefOrSingleRef( ScAddress& rAdr )
}
default:
PopError();
- SetError( errNoRef );
+ SetError( FormulaError::NoRef );
}
return false;
}
@@ -1381,7 +1381,7 @@ void ScInterpreter::PopDoubleRefPushMatrix()
PushIllegalParameter();
}
else
- SetError( errNoRef );
+ SetError( FormulaError::NoRef );
}
void ScInterpreter::ConvertMatrixJumpConditionToMatrix()
@@ -1440,7 +1440,7 @@ bool ScInterpreter::ConvertMatrixParameters()
{ // only if single value expected
ScConstMatrixRef pMat = p->GetMatrix();
if ( !pMat )
- SetError( errUnknownVariable);
+ SetError( FormulaError::UnknownVariable);
else
{
SCSIZE nCols, nRows;
@@ -1502,7 +1502,7 @@ bool ScInterpreter::ConvertMatrixParameters()
const ScComplexRefData& rRef = *p->GetDoubleRef();
ScExternalRefCache::TokenArrayRef pArray;
GetExternalDoubleRef(nFileId, aTabName, rRef, pArray);
- if (nGlobalError || !pArray)
+ if (nGlobalError != FormulaError::NONE || !pArray)
break;
formula::FormulaToken* pTemp = pArray->First();
if (!pTemp)
@@ -1527,7 +1527,7 @@ bool ScInterpreter::ConvertMatrixParameters()
eType != ScParameterClassification::ReferenceOrForceArray)
{
// can't convert to matrix
- SetError( errNoValue);
+ SetError( FormulaError::NoValue);
}
}
break;
@@ -1591,15 +1591,15 @@ ScMatrixRef ScInterpreter::PopMatrix()
if ( pMat )
pMat->SetErrorInterpreter( this);
else
- SetError( errUnknownVariable);
+ SetError( FormulaError::UnknownVariable);
return pMat;
}
default:
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
}
}
else
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
return nullptr;
}
@@ -1633,7 +1633,7 @@ sc::RangeMatrix ScInterpreter::PopRangeMatrix()
}
}
else
- SetError( errUnknownVariable);
+ SetError( FormulaError::UnknownVariable);
}
break;
default:
@@ -1679,9 +1679,9 @@ void ScInterpreter::QueryMatrixType(ScMatrixRef& xMat, short& rRetTypeExpr, sal_
}
else
{
- sal_uInt16 nErr = GetDoubleErrorValue( nMatVal.fVal);
+ FormulaError nErr = GetDoubleErrorValue( nMatVal.fVal);
FormulaTokenRef xRes;
- if (nErr)
+ if (nErr != FormulaError::NONE)
xRes = new FormulaErrorToken( nErr);
else
xRes = new FormulaDoubleToken( nMatVal.fVal);
@@ -1693,7 +1693,7 @@ void ScInterpreter::QueryMatrixType(ScMatrixRef& xMat, short& rRetTypeExpr, sal_
xMat->SetErrorInterpreter( nullptr);
}
else
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
}
formula::FormulaToken* ScInterpreter::CreateDoubleOrTypedToken( double fVal )
@@ -1817,7 +1817,7 @@ void ScInterpreter::PushMatrix( const sc::RangeMatrix& rMat )
}
rMat.mpMat->SetErrorInterpreter(nullptr);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushTempTokenWithoutError(new ScMatrixRangeToken(rMat));
}
@@ -1828,11 +1828,11 @@ void ScInterpreter::PushMatrix(const ScMatrixRef& pMat)
// but with notifying ScInterpreter via nGlobalError, substituting it would
// mean to inherit the error on all array elements in all following
// operations.
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
PushTempTokenWithoutError( new ScMatrixToken( pMat ) );
}
-void ScInterpreter::PushError( sal_uInt16 nError )
+void ScInterpreter::PushError( FormulaError nError )
{
SetError( nError ); // only sets error if not already set
PushTempTokenWithoutError( new FormulaErrorToken( nGlobalError));
@@ -1840,27 +1840,27 @@ void ScInterpreter::PushError( sal_uInt16 nError )
void ScInterpreter::PushParameterExpected()
{
- PushError( errParameterExpected);
+ PushError( FormulaError::ParameterExpected);
}
void ScInterpreter::PushIllegalParameter()
{
- PushError( errIllegalParameter);
+ PushError( FormulaError::IllegalParameter);
}
void ScInterpreter::PushIllegalArgument()
{
- PushError( errIllegalArgument);
+ PushError( FormulaError::IllegalArgument);
}
void ScInterpreter::PushNA()
{
- PushError( NOTAVAILABLE);
+ PushError( FormulaError::NotAvailable);
}
void ScInterpreter::PushNoValue()
{
- PushError( errNoValue);
+ PushError( FormulaError::NoValue);
}
bool ScInterpreter::IsMissing()
@@ -1877,7 +1877,7 @@ StackVar ScInterpreter::GetRawStackType()
}
else
{
- SetError(errUnknownStackVariable);
+ SetError(FormulaError::UnknownStackVariable);
eRes = svUnknown;
}
return eRes;
@@ -1894,7 +1894,7 @@ StackVar ScInterpreter::GetStackType()
}
else
{
- SetError(errUnknownStackVariable);
+ SetError(FormulaError::UnknownStackVariable);
eRes = svUnknown;
}
return eRes;
@@ -1943,7 +1943,7 @@ bool ScInterpreter::DoubleRefToPosSingleRef( const ScRange& rRange, ScAddress& r
{
bOk = rRange.aStart.Tab() == rRange.aEnd.Tab();
if ( !bOk )
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
else
{
SCSIZE nC, nR;
@@ -1955,7 +1955,7 @@ bool ScInterpreter::DoubleRefToPosSingleRef( const ScRange& rRange, ScAddress& r
rRange.aEnd.Col() && rRange.aStart.Row() <= rAdr.Row() &&
rAdr.Row() <= rRange.aEnd.Row();
if ( !bOk )
- SetError( errNoValue);
+ SetError( FormulaError::NoValue);
}
return bOk;
}
@@ -2011,7 +2011,7 @@ bool ScInterpreter::DoubleRefToPosSingleRef( const ScRange& rRange, ScAddress& r
rAdr.Set( nCol, nRow, nTab );
}
if ( !bOk )
- SetError( errNoValue );
+ SetError( FormulaError::NoValue );
return bOk;
}
@@ -2023,8 +2023,8 @@ double ScInterpreter::GetDoubleFromMatrix(const ScMatrixRef& pMat)
if ( !pJumpMatrix )
{
double fVal = pMat->GetDoubleWithStringConversion( 0, 0);
- sal_uInt16 nErr = GetDoubleErrorValue( fVal);
- if (nErr)
+ FormulaError nErr = GetDoubleErrorValue( fVal);
+ if (nErr != FormulaError::NONE)
{
// Do not propagate the coded double error, but set nGlobalError in
// case the matrix did not have an error interpreter set.
@@ -2041,8 +2041,8 @@ double ScInterpreter::GetDoubleFromMatrix(const ScMatrixRef& pMat)
if ( (nC < nCols || nCols == 1) && (nR < nRows || nRows == 1) )
{
double fVal = pMat->GetDoubleWithStringConversion( nC, nR);
- sal_uInt16 nErr = GetDoubleErrorValue( fVal);
- if (nErr)
+ FormulaError nErr = GetDoubleErrorValue( fVal);
+ if (nErr != FormulaError::NONE)
{
// Do not propagate the coded double error, but set nGlobalError in
// case the matrix did not have an error interpreter set.
@@ -2052,7 +2052,7 @@ double ScInterpreter::GetDoubleFromMatrix(const ScMatrixRef& pMat)
return fVal;
}
- SetError( errNoValue);
+ SetError( FormulaError::NoValue);
return 0.0;
}
@@ -2080,7 +2080,7 @@ double ScInterpreter::GetDouble()
ScRange aRange;
PopDoubleRef( aRange );
ScAddress aAdr;
- if ( !nGlobalError && DoubleRefToPosSingleRef( aRange, aAdr ) )
+ if ( nGlobalError == FormulaError::NONE && DoubleRefToPosSingleRef( aRange, aAdr ) )
{
ScRefCellValue aCell(*pDok, aAdr);
nVal = GetCellValue(aAdr, aCell);
@@ -2093,7 +2093,7 @@ double ScInterpreter::GetDouble()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
{
if (pToken->GetType() == svDouble || pToken->GetType() == svEmptyCell)
nVal = pToken->GetDouble();
@@ -2106,7 +2106,7 @@ double ScInterpreter::GetDouble()
{
ScMatrixRef pMat;
PopExternalDoubleRef(pMat);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
break;
nVal = GetDoubleFromMatrix(pMat);
@@ -2129,7 +2129,7 @@ double ScInterpreter::GetDouble()
break;
default:
PopError();
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
nVal = 0.0;
}
if ( nFuncFmtType == nCurFmtType )
@@ -2158,7 +2158,7 @@ sal_Int32 ScInterpreter::double_to_int32(double fVal)
fVal = rtl::math::approxFloor( fVal);
if (fVal > SAL_MAX_INT32)
{
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
return SAL_MAX_INT32;
}
}
@@ -2167,7 +2167,7 @@ sal_Int32 ScInterpreter::double_to_int32(double fVal)
fVal = rtl::math::approxCeil( fVal);
if (fVal < SAL_MIN_INT32)
{
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
return SAL_MAX_INT32;
}
}
@@ -2201,7 +2201,7 @@ sal_Int16 ScInterpreter::GetInt16()
fVal = rtl::math::approxFloor( fVal);
if (fVal > SAL_MAX_INT16)
{
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
return SAL_MAX_INT16;
}
}
@@ -2210,7 +2210,7 @@ sal_Int16 ScInterpreter::GetInt16()
fVal = rtl::math::approxCeil( fVal);
if (fVal < SAL_MIN_INT16)
{
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
return SAL_MAX_INT16;
}
}
@@ -2227,7 +2227,7 @@ sal_uInt32 ScInterpreter::GetUInt32()
}
if (fVal < 0.0 || fVal > SAL_MAX_UINT32)
{
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
return SAL_MAX_UINT32;
}
return static_cast<sal_uInt32>(fVal);
@@ -2285,7 +2285,7 @@ bool ScInterpreter::GetDoubleOrString( double& rDouble, svl::SharedString& rStri
break;
default:
PopError();
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
rDouble = 0.0;
}
if ( nFuncFmtType == nCurFmtType )
@@ -2320,7 +2320,7 @@ svl::SharedString ScInterpreter::GetString()
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if (nGlobalError == 0)
+ if (nGlobalError == FormulaError::NONE)
{
ScRefCellValue aCell(*pDok, aAdr);
svl::SharedString aSS;
@@ -2335,7 +2335,7 @@ svl::SharedString ScInterpreter::GetString()
ScRange aRange;
PopDoubleRef( aRange );
ScAddress aAdr;
- if ( !nGlobalError && DoubleRefToPosSingleRef( aRange, aAdr ) )
+ if ( nGlobalError == FormulaError::NONE && DoubleRefToPosSingleRef( aRange, aAdr ) )
{
ScRefCellValue aCell(*pDok, aAdr);
svl::SharedString aSS;
@@ -2349,7 +2349,7 @@ svl::SharedString ScInterpreter::GetString()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
return svl::SharedString::getEmptyString();
return pToken->GetString();
@@ -2368,7 +2368,7 @@ svl::SharedString ScInterpreter::GetString()
break;
default:
PopError();
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
return svl::SharedString::getEmptyString();
}
@@ -2390,7 +2390,7 @@ svl::SharedString ScInterpreter::GetStringFromMatrix(const ScMatrixRef& pMat)
if ( (nC < nCols || nCols == 1) && (nR < nRows || nRows == 1) )
return pMat->GetString( *pFormatter, nC, nR);
- SetError( errNoValue);
+ SetError( FormulaError::NoValue);
}
return svl::SharedString::getEmptyString();
}
@@ -2412,7 +2412,7 @@ ScMatValType ScInterpreter::GetDoubleOrStringFromMatrix(
else
{
PopError();
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
return nMatValType;
}
@@ -2438,14 +2438,14 @@ ScMatValType ScInterpreter::GetDoubleOrStringFromMatrix(
nMatValType = nMatVal.nType;
}
else
- SetError( errNoValue);
+ SetError( FormulaError::NoValue);
}
if (ScMatrix::IsValueType( nMatValType))
{
rDouble = nMatVal.fVal;
- sal_uInt16 nError = nMatVal.GetError();
- if (nError)
+ FormulaError nError = nMatVal.GetError();
+ if (nError != FormulaError::NONE)
SetError( nError);
}
else
@@ -2470,7 +2470,7 @@ void ScInterpreter::ScDBGet()
pQueryParam->mbSkipString = false;
ScDBQueryDataIterator aValIter(pDok, pQueryParam.release());
ScDBQueryDataIterator::Value aValue;
- if (!aValIter.GetFirst(aValue) || aValue.mnError)
+ if (!aValIter.GetFirst(aValue) || aValue.mnError != FormulaError::NONE)
{
// No match found.
PushNoValue();
@@ -2478,7 +2478,7 @@ void ScInterpreter::ScDBGet()
}
ScDBQueryDataIterator::Value aValNext;
- if (aValIter.GetNext(aValNext) && !aValNext.mnError)
+ if (aValIter.GetNext(aValNext) && aValNext.mnError == FormulaError::NONE)
{
// There should be only one unique match.
PushIllegalArgument();
@@ -2520,14 +2520,14 @@ void ScInterpreter::ScExternal()
pCellArr[i] = nullptr;
}
- for (i = nParamCount; (i > 0) && (nGlobalError == 0); i--)
+ for (i = nParamCount; (i > 0) && (nGlobalError == FormulaError::NONE); i--)
{
if (IsMissing())
{
// Old binary Add-In can't distinguish between missing
// omitted argument and 0 (or any other value). Force
// error.
- SetError( errParameterExpected);
+ SetError( FormulaError::ParameterExpected);
break; // for
}
switch (eParamType[i])
@@ -2543,7 +2543,7 @@ void ScInterpreter::ScExternal()
OString aStr(OUStringToOString(GetString().getString(),
osl_getThreadTextEncoding()));
if ( aStr.getLength() >= ADDIN_MAXSTRLEN )
- SetError( errStringOverflow );
+ SetError( FormulaError::StringOverflow );
else
{
pStr[i-1] = new sal_Char[ADDIN_MAXSTRLEN];
@@ -2564,7 +2564,7 @@ void ScInterpreter::ScExternal()
PopDoubleRef(nCol1, nRow1, nTab1, nCol2, nRow2, nTab2);
pCellArr[i-1] = new sal_uInt8[MAXARRSIZE];
if (!CreateDoubleArr(nCol1, nRow1, nTab1, nCol2, nRow2, nTab2, pCellArr[i-1]))
- SetError(errCodeOverflow);
+ SetError(FormulaError::CodeOverflow);
else
ppParam[i] = pCellArr[i-1];
}
@@ -2580,7 +2580,7 @@ void ScInterpreter::ScExternal()
PopDoubleRef(nCol1, nRow1, nTab1, nCol2, nRow2, nTab2);
pCellArr[i-1] = new sal_uInt8[MAXARRSIZE];
if (!CreateStringArr(nCol1, nRow1, nTab1, nCol2, nRow2, nTab2, pCellArr[i-1]))
- SetError(errCodeOverflow);
+ SetError(FormulaError::CodeOverflow);
else
ppParam[i] = pCellArr[i-1];
}
@@ -2596,20 +2596,20 @@ void ScInterpreter::ScExternal()
PopDoubleRef(nCol1, nRow1, nTab1, nCol2, nRow2, nTab2);
pCellArr[i-1] = new sal_uInt8[MAXARRSIZE];
if (!CreateCellArr(nCol1, nRow1, nTab1, nCol2, nRow2, nTab2, pCellArr[i-1]))
- SetError(errCodeOverflow);
+ SetError(FormulaError::CodeOverflow);
else
ppParam[i] = pCellArr[i-1];
}
break;
default :
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
break;
}
}
while ( i-- )
Pop(); // In case of error (otherwise i==0) pop all parameters
- if (nGlobalError == 0)
+ if (nGlobalError == FormulaError::NONE)
{
if ( pLegacyFuncData->GetAsyncType() == ParamType::NONE )
{
@@ -2633,7 +2633,7 @@ void ScInterpreter::ScExternal()
}
break;
default:
- PushError( errUnknownState );
+ PushError( FormulaError::UnknownState );
}
}
else
@@ -2671,7 +2671,7 @@ void ScInterpreter::ScExternal()
PushString( pAs->GetString() );
break;
default:
- PushError( errUnknownState );
+ PushError( FormulaError::UnknownState );
}
}
else
@@ -2703,9 +2703,9 @@ void ScInterpreter::ScExternal()
ScUnoAddInCall aCall( *ScGlobal::GetAddInCollection(), aUnoName, nParamCount );
if ( !aCall.ValidParamCount() )
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
- if ( aCall.NeedsCaller() && !GetError() )
+ if ( aCall.NeedsCaller() && GetError() == FormulaError::NONE )
{
SfxObjectShell* pShell = pDok->GetDocumentShell();
if (pShell)
@@ -2719,7 +2719,7 @@ void ScInterpreter::ScExternal()
}
short nPar = nParamCount;
- while ( nPar > 0 && !GetError() )
+ while ( nPar > 0 && GetError() == FormulaError::NONE )
{
--nPar; // 0 .. (nParamCount-1)
@@ -2741,7 +2741,7 @@ void ScInterpreter::ScExternal()
case SC_ADDINARG_INTEGER:
{
sal_Int32 nVal = GetInt32();
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
aParam <<= nVal;
}
break;
@@ -2762,7 +2762,7 @@ void ScInterpreter::ScExternal()
case svSingleRef:
{
sal_Int32 nVal = GetInt32();
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
{
uno::Sequence<sal_Int32> aInner( &nVal, 1 );
uno::Sequence< uno::Sequence<sal_Int32> > aOuter( &aInner, 1 );
@@ -2775,16 +2775,16 @@ void ScInterpreter::ScExternal()
ScRange aRange;
PopDoubleRef( aRange );
if (!ScRangeToSequence::FillLongArray( aParam, pDok, aRange ))
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
case svMatrix:
if (!ScRangeToSequence::FillLongArray( aParam, PopMatrix().get() ))
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
break;
default:
PopError();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
@@ -2806,16 +2806,16 @@ void ScInterpreter::ScExternal()
ScRange aRange;
PopDoubleRef( aRange );
if (!ScRangeToSequence::FillDoubleArray( aParam, pDok, aRange ))
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
case svMatrix:
if (!ScRangeToSequence::FillDoubleArray( aParam, PopMatrix().get() ))
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
break;
default:
PopError();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
@@ -2837,16 +2837,16 @@ void ScInterpreter::ScExternal()
ScRange aRange;
PopDoubleRef( aRange );
if (!ScRangeToSequence::FillStringArray( aParam, pDok, aRange ))
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
case svMatrix:
if (!ScRangeToSequence::FillStringArray( aParam, PopMatrix().get(), pFormatter ))
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
break;
default:
PopError();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
@@ -2888,16 +2888,16 @@ void ScInterpreter::ScExternal()
ScRange aRange;
PopDoubleRef( aRange );
if (!ScRangeToSequence::FillMixedArray( aParam, pDok, aRange ))
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
case svMatrix:
if (!ScRangeToSequence::FillMixedArray( aParam, PopMatrix().get() ))
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
break;
default:
PopError();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
@@ -2932,16 +2932,16 @@ void ScInterpreter::ScExternal()
ScRange aRange;
PopDoubleRef( aRange );
if (!ScRangeToSequence::FillMixedArray( aParam, pDok, aRange ))
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
case svMatrix:
if (!ScRangeToSequence::FillMixedArray( aParam, PopMatrix().get() ))
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
break;
default:
PopError();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
@@ -2958,7 +2958,7 @@ void ScInterpreter::ScExternal()
if (xObj.is())
aParam <<= xObj;
else
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
case svDoubleRef:
@@ -2973,19 +2973,19 @@ void ScInterpreter::ScExternal()
}
else
{
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
}
break;
default:
PopError();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
break;
default:
PopError();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
aCall.SetParam( nPar, aParam );
}
@@ -2994,7 +2994,7 @@ void ScInterpreter::ScExternal()
{
Pop(); // in case of error, remove remaining args
}
- if ( !GetError() )
+ if ( GetError() == FormulaError::NONE )
{
aCall.ExecuteCall();
@@ -3023,7 +3023,7 @@ void ScInterpreter::ScExternal()
aCall.SetResult( pLis->GetResult() ); // use result from async
}
- if ( aCall.GetErrCode() )
+ if ( aCall.GetErrCode() != FormulaError::NONE )
{
PushError( aCall.GetErrCode() );
}
@@ -3050,7 +3050,7 @@ void ScInterpreter::ScExternal()
{
Pop();
}
- PushError( errNoAddin );
+ PushError( FormulaError::NoAddin );
}
}
@@ -3166,7 +3166,7 @@ void ScInterpreter::ScMacro()
SbxVariable* pVar = pRoot ? pRoot->Find(aMacro, SbxClassType::Method) : nullptr;
if( !pVar || pVar->GetType() == SbxVOID || dynamic_cast<const SbMethod*>( pVar) == nullptr )
{
- PushError( errNoMacro );
+ PushError( FormulaError::NoMacro );
return;
}
@@ -3207,7 +3207,7 @@ void ScInterpreter::ScMacro()
{
ScExternalRefCache::TokenRef pToken;
PopExternalSingleRef(pToken);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
bOk = false;
else
{
@@ -3217,7 +3217,7 @@ void ScInterpreter::ScMacro()
pPar->PutDouble( pToken->GetDouble() );
else
{
- SetError( errIllegalArgument );
+ SetError( FormulaError::IllegalArgument );
bOk = false;
}
}
@@ -3249,7 +3249,7 @@ void ScInterpreter::ScMacro()
PopDoubleRef( nCol1, nRow1, nTab1, nCol2, nRow2, nTab2 );
if( nTab1 != nTab2 )
{
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
bOk = false;
}
else
@@ -3288,7 +3288,7 @@ void ScInterpreter::ScMacro()
{
ScMatrixRef pMat = GetMatrix();
SCSIZE nC, nR;
- if (pMat && !nGlobalError)
+ if (pMat && nGlobalError == FormulaError::NONE)
{
pMat->GetDimensions(nC, nR);
SbxDimArrayRef refArray = new SbxDimArray;
@@ -3316,12 +3316,12 @@ void ScInterpreter::ScMacro()
}
else
{
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
}
}
break;
default:
- SetError( errIllegalParameter );
+ SetError( FormulaError::IllegalParameter );
bOk = false;
}
}
@@ -3344,7 +3344,7 @@ void ScInterpreter::ScMacro()
SbxDataType eResType = refRes->GetType();
if( SbxBase::GetError() )
{
- SetError( errNoValue);
+ SetError( FormulaError::NoValue);
}
if ( eRet != ERRCODE_NONE )
{
@@ -3440,7 +3440,7 @@ bool ScInterpreter::SetSbxVariable( SbxVariable* pVar, const ScAddress& rPos )
ScRefCellValue aCell(*pDok, rPos);
if (!aCell.isEmpty())
{
- sal_uInt16 nErr;
+ FormulaError nErr;
double nVal;
switch (aCell.meType)
{
@@ -3454,7 +3454,7 @@ bool ScInterpreter::SetSbxVariable( SbxVariable* pVar, const ScAddress& rPos )
break;
case CELLTYPE_FORMULA :
nErr = aCell.mpFormula->GetErrCode();
- if( !nErr )
+ if( nErr == FormulaError::NONE )
{
if (aCell.mpFormula->IsValue())
{
@@ -3612,7 +3612,7 @@ void ScInterpreter::ScDBArea()
PushTempToken( new ScDoubleRefToken( aRefData ) );
}
else
- PushError( errNoName);
+ PushError( FormulaError::NoName);
}
void ScInterpreter::ScColRowNameAuto()
@@ -3621,7 +3621,7 @@ void ScInterpreter::ScColRowNameAuto()
ScRange aAbs = aRefData.toAbs(aPos);
if (!ValidRange(aAbs))
{
- PushError( errNoRef );
+ PushError( FormulaError::NoRef );
return;
}
@@ -3706,7 +3706,7 @@ void ScInterpreter::ScTTT()
// clean up Stack
while ( nParamCount-- > 0)
Pop();
- PushError(errNoValue);
+ PushError(FormulaError::NoValue);
}
ScInterpreter::ScInterpreter( ScFormulaCell* pCell, ScDocument* pDoc,
@@ -3722,7 +3722,7 @@ ScInterpreter::ScInterpreter( ScFormulaCell* pCell, ScDocument* pDoc,
, pMyFormulaCell(pCell)
, pFormatter(pDoc->GetFormatTable())
, pCur(nullptr)
- , nGlobalError(0)
+ , nGlobalError(FormulaError::NONE)
, sp(0)
, maxsp(0)
, nFuncFmtIndex(0)
@@ -3731,7 +3731,7 @@ ScInterpreter::ScInterpreter( ScFormulaCell* pCell, ScDocument* pDoc,
, nFuncFmtType(0)
, nCurFmtType(0)
, nRetFmtType(0)
- , mnStringNoValueError(errNoValue)
+ , mnStringNoValueError(FormulaError::NoValue)
, mnSubTotalFlags(0)
, cPar(0)
, bCalcAsShown(pDoc->GetDocOptions().IsCalcAsShown())
@@ -3862,7 +3862,7 @@ StackVar ScInterpreter::Interpret()
std::stack<sal_uInt16> aErrorFunctionStack;
sal_uInt16 nStackBase;
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
nStackBase = sp = maxsp = 0;
nRetFmtType = css::util::NumberFormat::UNDEFINED;
nFuncFmtType = css::util::NumberFormat::UNDEFINED;
@@ -3881,7 +3881,7 @@ StackVar ScInterpreter::Interpret()
aCode.Reset();
while( ( pCur = aCode.Next() ) != nullptr
- && (!nGlobalError || nErrorFunction <= nErrorFunctionCount) )
+ && (nGlobalError == FormulaError::NONE || nErrorFunction <= nErrorFunctionCount) )
{
OpCode eOp = pCur->GetOpCode();
cPar = pCur->GetByte();
@@ -3971,7 +3971,7 @@ StackVar ScInterpreter::Interpret()
case ocFalse : ScFalse(); break;
case ocGetActDate : ScGetActDate(); break;
case ocGetActTime : ScGetActTime(); break;
- case ocNotAvail : PushError( NOTAVAILABLE); break;
+ case ocNotAvail : PushError( FormulaError::NotAvailable); break;
case ocDeg : ScDeg(); break;
case ocRad : ScRad(); break;
case ocSin : ScSin(); break;
@@ -4355,7 +4355,7 @@ StackVar ScInterpreter::Interpret()
case ocTTT : ScTTT(); break;
case ocDebugVar : ScDebugVar(); break;
case ocNone : nFuncFmtType = css::util::NumberFormat::UNDEFINED; break;
- default : PushError( errUnknownOpCode); break;
+ default : PushError( FormulaError::UnknownOpCode); break;
}
// If the function pushed a subroutine as result, continue with
@@ -4394,7 +4394,7 @@ StackVar ScInterpreter::Interpret()
}
// Need a clean stack environment for the JumpMatrix to work.
- if (nGlobalError && eOp != ocPush && sp > nStackBase + 1)
+ if (nGlobalError != FormulaError::NONE && eOp != ocPush && sp > nStackBase + 1)
{
// Not all functions pop all parameters in case an error is
// generated. Clean up stack. Assumes that every function pushes a
@@ -4437,7 +4437,7 @@ StackVar ScInterpreter::Interpret()
if( IsErrFunc(eOp) )
++nErrorFunction;
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
if ( !nErrorFunctionCount )
{ // count of errorcode functions in formula
@@ -4496,13 +4496,13 @@ StackVar ScInterpreter::Interpret()
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if( !nGlobalError )
+ if( nGlobalError == FormulaError::NONE)
PushCellResultToken( false, aAdr, &nRetTypeExpr, &nRetIndexExpr, true);
}
break;
case svRefList :
PopError(); // maybe #REF! takes precedence over #VALUE!
- PushError( errNoValue);
+ PushError( FormulaError::NoValue);
break;
case svDoubleRef :
{
@@ -4517,7 +4517,7 @@ StackVar ScInterpreter::Interpret()
ScRange aRange;
PopDoubleRef( aRange );
ScAddress aAdr;
- if ( !nGlobalError && DoubleRefToPosSingleRef( aRange, aAdr))
+ if ( nGlobalError == FormulaError::NONE && DoubleRefToPosSingleRef( aRange, aAdr))
PushCellResultToken( false, aAdr, &nRetTypeExpr, &nRetIndexExpr, true);
}
}
@@ -4551,7 +4551,7 @@ StackVar ScInterpreter::Interpret()
FormulaTokenRef xToken;
ScExternalRefCache::CellFormat aFmt;
PopExternalSingleRef(xToken, &aFmt);
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
break;
PushTokenRef(xToken);
@@ -4564,14 +4564,14 @@ StackVar ScInterpreter::Interpret()
}
break;
default :
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
}
}
else
- SetError( errUnknownStackVariable);
+ SetError( FormulaError::UnknownStackVariable);
}
else
- SetError( errNoCode);
+ SetError( FormulaError::NoCode);
if( nRetTypeExpr != css::util::NumberFormat::UNDEFINED )
{
@@ -4586,13 +4586,13 @@ StackVar ScInterpreter::Interpret()
else
nRetFmtType = css::util::NumberFormat::NUMBER;
- if (nGlobalError && GetStackType() != svError )
+ if (nGlobalError != FormulaError::NONE && GetStackType() != svError )
PushError( nGlobalError);
// THE final result.
xResult = PopToken();
if (!xResult)
- xResult = new FormulaErrorToken( errUnknownStackVariable);
+ xResult = new FormulaErrorToken( FormulaError::UnknownStackVariable);
// release tokens in expression stack
const FormulaToken** p = pStack;
diff --git a/sc/source/core/tool/interpr5.cxx b/sc/source/core/tool/interpr5.cxx
index d5f09f7fc291..43a80861d612 100644
--- a/sc/source/core/tool/interpr5.cxx
+++ b/sc/source/core/tool/interpr5.cxx
@@ -134,7 +134,7 @@ void ScInterpreter::ScGCD()
double fx, fy = 0.0;
ScRange aRange;
size_t nRefInList = 0;
- while (!nGlobalError && nParamCount-- > 0)
+ while (nGlobalError == FormulaError::NONE && nParamCount-- > 0)
{
switch (GetStackType())
{
@@ -154,7 +154,7 @@ void ScInterpreter::ScGCD()
case svDoubleRef :
case svRefList :
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
PopDoubleRef( aRange, nParamCount, nRefInList);
double nCellVal;
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags );
@@ -169,7 +169,7 @@ void ScInterpreter::ScGCD()
return;
}
fy = ScGetGCD(fx, fy);
- } while (nErr == 0 && aValIter.GetNext(nCellVal, nErr));
+ } while (nErr == FormulaError::NONE && aValIter.GetNext(nCellVal, nErr));
}
SetError(nErr);
}
@@ -184,7 +184,7 @@ void ScInterpreter::ScGCD()
SCSIZE nC, nR;
pMat->GetDimensions(nC, nR);
if (nC == 0 || nR == 0)
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
else
{
for ( SCSIZE j = 0; j < nC; j++ )
@@ -209,7 +209,7 @@ void ScInterpreter::ScGCD()
}
}
break;
- default : SetError(errIllegalParameter); break;
+ default : SetError(FormulaError::IllegalParameter); break;
}
}
PushDouble(fy);
@@ -224,7 +224,7 @@ void ScInterpreter:: ScLCM()
double fx, fy = 1.0;
ScRange aRange;
size_t nRefInList = 0;
- while (!nGlobalError && nParamCount-- > 0)
+ while (nGlobalError == FormulaError::NONE && nParamCount-- > 0)
{
switch (GetStackType())
{
@@ -247,7 +247,7 @@ void ScInterpreter:: ScLCM()
case svDoubleRef :
case svRefList :
{
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
PopDoubleRef( aRange, nParamCount, nRefInList);
double nCellVal;
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags );
@@ -265,7 +265,7 @@ void ScInterpreter:: ScLCM()
fy = 0.0;
else
fy = fx * fy / ScGetGCD(fx, fy);
- } while (nErr == 0 && aValIter.GetNext(nCellVal, nErr));
+ } while (nErr == FormulaError::NONE && aValIter.GetNext(nCellVal, nErr));
}
SetError(nErr);
}
@@ -280,7 +280,7 @@ void ScInterpreter:: ScLCM()
SCSIZE nC, nR;
pMat->GetDimensions(nC, nR);
if (nC == 0 || nR == 0)
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
else
{
for ( SCSIZE j = 0; j < nC; j++ )
@@ -308,7 +308,7 @@ void ScInterpreter:: ScLCM()
}
}
break;
- default : SetError(errIllegalParameter); break;
+ default : SetError(FormulaError::IllegalParameter); break;
}
}
PushDouble(fy);
@@ -331,7 +331,7 @@ ScMatrixRef ScInterpreter::GetNewMat(SCSIZE nC, SCSIZE nR, bool bEmpty)
pMat->GetDimensions( nCols, nRows);
if ( nCols != nC || nRows != nR )
{ // arbitray limit of elements exceeded
- SetError( errMatrixSize);
+ SetError( FormulaError::MatrixSize);
pMat.reset();
}
return pMat;
@@ -341,10 +341,10 @@ ScMatrixRef ScInterpreter::CreateMatrixFromDoubleRef( const FormulaToken* pToken
SCCOL nCol1, SCROW nRow1, SCTAB nTab1,
SCCOL nCol2, SCROW nRow2, SCTAB nTab2 )
{
- if (nTab1 != nTab2 || nGlobalError)
+ if (nTab1 != nTab2 || nGlobalError != FormulaError::NONE)
{
// Not a 2D matrix.
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
return nullptr;
}
@@ -353,7 +353,7 @@ ScMatrixRef ScInterpreter::CreateMatrixFromDoubleRef( const FormulaToken* pToken
if (!ScMatrix::IsSizeAllocatable( nMatCols, nMatRows))
{
- SetError(errMatrixSize);
+ SetError(FormulaError::MatrixSize);
return nullptr;
}
@@ -370,7 +370,7 @@ ScMatrixRef ScInterpreter::CreateMatrixFromDoubleRef( const FormulaToken* pToken
}
ScMatrixRef pMat = GetNewMat( nMatCols, nMatRows, true);
- if (!pMat || nGlobalError)
+ if (!pMat || nGlobalError != FormulaError::NONE)
return nullptr;
pDok->FillMatrix(*pMat, nTab1, nCol1, nRow1, nCol2, nRow2);
@@ -429,10 +429,10 @@ ScMatrixRef ScInterpreter::GetMatrix()
pMat = GetNewMat( 1, 1);
if ( pMat )
{
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
fVal = CreateDoubleError( nGlobalError);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
pMat->PutDouble( fVal, 0);
}
@@ -444,11 +444,11 @@ ScMatrixRef ScInterpreter::GetMatrix()
pMat = GetNewMat( 1, 1);
if ( pMat )
{
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
double fVal = CreateDoubleError( nGlobalError);
pMat->PutDouble( fVal, 0);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
else
pMat->PutString(aStr, 0);
@@ -462,13 +462,13 @@ ScMatrixRef ScInterpreter::GetMatrix()
pMat = GetNewMat( 1, 1, true);
if (!pMat)
{
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
break;
}
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
pMat->PutError( nGlobalError, 0, 0);
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
break;
}
switch (pToken->GetType())
@@ -492,7 +492,7 @@ ScMatrixRef ScInterpreter::GetMatrix()
break;
default:
PopError();
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
break;
}
return pMat;
@@ -521,7 +521,7 @@ void ScInterpreter::ScMatValue()
// really, practically ...
SCSIZE nR = static_cast<SCSIZE>(GetUInt32());
SCSIZE nC = static_cast<SCSIZE>(GetUInt32());
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushError( nGlobalError);
return;
@@ -535,8 +535,8 @@ void ScInterpreter::ScMatValue()
ScRefCellValue aCell(*pDok, aAdr);
if (aCell.meType == CELLTYPE_FORMULA)
{
- sal_uInt16 nErrCode = aCell.mpFormula->GetErrCode();
- if (nErrCode != 0)
+ FormulaError nErrCode = aCell.mpFormula->GetErrCode();
+ if (nErrCode != FormulaError::NONE)
PushError( nErrCode);
else
{
@@ -618,10 +618,10 @@ void ScInterpreter::ScEMat()
if ( MustHaveParamCount( GetByte(), 1 ) )
{
SCSIZE nDim = static_cast<SCSIZE>(GetUInt32());
- if (nGlobalError || nDim == 0)
+ if (nGlobalError != FormulaError::NONE || nDim == 0)
PushIllegalArgument();
else if (!ScMatrix::IsSizeAllocatable( nDim, nDim))
- PushError( errMatrixSize);
+ PushError( FormulaError::MatrixSize);
else
{
ScMatrixRef pRMat = GetNewMat(nDim, nDim);
@@ -822,13 +822,13 @@ void ScInterpreter::ScMatDet()
if ( nC != nR || nC == 0 )
PushIllegalArgument();
else if (!ScMatrix::IsSizeAllocatable( nC, nR))
- PushError( errMatrixSize);
+ PushError( FormulaError::MatrixSize);
else
{
// LUP decomposition is done inplace, use copy.
ScMatrixRef xLU = pMat->Clone();
if (!xLU)
- PushError( errCodeOverflow);
+ PushError( FormulaError::CodeOverflow);
else
{
::std::vector< SCSIZE> P(nR);
@@ -857,7 +857,7 @@ void ScInterpreter::ScModalValue_Multi()
vector<double> aSortArray;
GetSortArray( nParamCount, aSortArray, nullptr, false, false );
SCSIZE nSize = aSortArray.size();
- if ( aSortArray.empty() || nSize == 0 || nGlobalError )
+ if ( aSortArray.empty() || nSize == 0 || nGlobalError != FormulaError::NONE )
PushNoValue();
else
{
@@ -947,7 +947,7 @@ void ScInterpreter::ScMatInv()
if ( nC != nR || nC == 0 )
PushIllegalArgument();
else if (!ScMatrix::IsSizeAllocatable( nC, nR))
- PushError( errMatrixSize);
+ PushError( FormulaError::MatrixSize);
else
{
// LUP decomposition is done inplace, use copy.
@@ -955,7 +955,7 @@ void ScInterpreter::ScMatInv()
// The result matrix.
ScMatrixRef xY = GetNewMat( nR, nR);
if (!xLU || !xY)
- PushError( errCodeOverflow);
+ PushError( FormulaError::CodeOverflow);
else
{
::std::vector< SCSIZE> P(nR);
@@ -1008,13 +1008,13 @@ void ScInterpreter::ScMatInv()
double fTmp = pR->GetDouble( j, i);
fprintf( stderr, "%8.2g ", fTmp);
if (fabs( fTmp - (i == j)) > fInvEpsilon)
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
}
fprintf( stderr, "\n%s\n", "");
}
}
#endif
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
PushError( nGlobalError);
else
PushMatrix( xY);
@@ -1135,32 +1135,32 @@ static ScMatrixRef lcl_MatrixCalculation(
{
bool bVal1 = rMat1.IsValueOrEmpty(i,j);
bool bVal2 = rMat2.IsValueOrEmpty(i,j);
- sal_uInt16 nErr;
+ FormulaError nErr;
if (bVal1 && bVal2)
{
double d = Op(rMat1.GetDouble(i,j), rMat2.GetDouble(i,j));
xResMat->PutDouble( d, i, j);
}
- else if (((nErr = rMat1.GetErrorIfNotString(i,j)) != 0) ||
- ((nErr = rMat2.GetErrorIfNotString(i,j)) != 0))
+ else if (((nErr = rMat1.GetErrorIfNotString(i,j)) != FormulaError::NONE) ||
+ ((nErr = rMat2.GetErrorIfNotString(i,j)) != FormulaError::NONE))
{
xResMat->PutError( nErr, i, j);
}
else if ((!bVal1 && rMat1.IsString(i,j)) || (!bVal2 && rMat2.IsString(i,j)))
{
- sal_uInt16 nError1 = 0;
+ FormulaError nError1 = FormulaError::NONE;
short nFmt1 = 0;
double fVal1 = (bVal1 ? rMat1.GetDouble(i,j) :
pInterpreter->ConvertStringToValue( rMat1.GetString(i,j).getString(), nError1, nFmt1));
- sal_uInt16 nError2 = 0;
+ FormulaError nError2 = FormulaError::NONE;
short nFmt2 = 0;
double fVal2 = (bVal2 ? rMat2.GetDouble(i,j) :
pInterpreter->ConvertStringToValue( rMat2.GetString(i,j).getString(), nError2, nFmt2));
- if (nError1)
+ if (nError1 != FormulaError::NONE)
xResMat->PutError( nError1, i, j);
- else if (nError2)
+ else if (nError2 != FormulaError::NONE)
xResMat->PutError( nError2, i, j);
else
{
@@ -1169,7 +1169,7 @@ static ScMatrixRef lcl_MatrixCalculation(
}
}
else
- xResMat->PutError( errNoValue, i, j);
+ xResMat->PutError( FormulaError::NoValue, i, j);
}
}
}
@@ -1394,7 +1394,7 @@ void ScInterpreter::ScAmpersand()
ScMatrixRef pResMat = GetNewMat(nC, nR);
if (pResMat)
{
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
for (SCSIZE i = 0; i < nC; ++i)
for (SCSIZE j = 0; j < nR; ++j)
@@ -1405,8 +1405,8 @@ void ScInterpreter::ScAmpersand()
for (SCSIZE i = 0; i < nC; ++i)
for (SCSIZE j = 0; j < nR; ++j)
{
- sal_uInt16 nErr = pMat->GetErrorIfNotString( i, j);
- if (nErr)
+ FormulaError nErr = pMat->GetErrorIfNotString( i, j);
+ if (nErr != FormulaError::NONE)
pResMat->PutError( nErr, i, j);
else
{
@@ -1421,8 +1421,8 @@ void ScInterpreter::ScAmpersand()
for (SCSIZE i = 0; i < nC; ++i)
for (SCSIZE j = 0; j < nR; ++j)
{
- sal_uInt16 nErr = pMat->GetErrorIfNotString( i, j);
- if (nErr)
+ FormulaError nErr = pMat->GetErrorIfNotString( i, j);
+ if (nErr != FormulaError::NONE)
pResMat->PutError( nErr, i, j);
else
{
@@ -1687,10 +1687,10 @@ public:
if (mbError)
return;
- sal_uInt16 nErr = GetDoubleErrorValue(f);
- if (!nErr)
+ FormulaError nErr = GetDoubleErrorValue(f);
+ if (nErr == FormulaError::NONE)
mfSum += f;
- else if (nErr != errElementNaN)
+ else if (nErr != FormulaError::ElementNaN)
{
// Propagate the first error encountered, ignore "this is not a
// number" elements.
@@ -1842,7 +1842,7 @@ void ScInterpreter::ScFrequency()
GetSortArray( 1, aBinArray, &aBinIndexOrder, false, false );
SCSIZE nBinSize = aBinArray.size();
- if (nGlobalError)
+ if (nGlobalError != FormulaError::NONE)
{
PushNoValue();
return;
@@ -1852,7 +1852,7 @@ void ScInterpreter::ScFrequency()
GetSortArray( 1, aDataArray, nullptr, false, false );
SCSIZE nDataSize = aDataArray.size();
- if (aDataArray.empty() || nGlobalError)
+ if (aDataArray.empty() || nGlobalError != FormulaError::NONE)
{
PushNoValue();
return;
@@ -2434,7 +2434,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
pResMat = GetNewMat(K+1,1);
if (!pResMat)
{
- PushError(errCodeOverflow);
+ PushError(FormulaError::CodeOverflow);
return;
}
// Fill unused cells in pResMat; order (column,row)
@@ -2442,9 +2442,9 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
{
for (SCSIZE i=2; i<K+1; i++)
{
- pResMat->PutError( NOTAVAILABLE, i, 2);
- pResMat->PutError( NOTAVAILABLE, i, 3);
- pResMat->PutError( NOTAVAILABLE, i, 4);
+ pResMat->PutError( FormulaError::NotAvailable, i, 2);
+ pResMat->PutError( FormulaError::NotAvailable, i, 3);
+ pResMat->PutError( FormulaError::NotAvailable, i, 4);
}
}
@@ -2457,7 +2457,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
ScMatrixRef pNewY = pMatY->CloneIfConst();
if (!pNewX || !pNewY)
{
- PushError(errCodeOverflow);
+ PushError(FormulaError::CodeOverflow);
return;
}
pMatX = pNewX;
@@ -2511,13 +2511,13 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
{ // exact fit; test SSreg too, because SSresid might be
// unequal zero due to round of errors
pResMat->PutDouble(0.0, 1, 4); // SSresid
- pResMat->PutError( NOTAVAILABLE, 0, 3); // F
+ pResMat->PutError( FormulaError::NotAvailable, 0, 3); // F
pResMat->PutDouble(0.0, 1, 2); // RMSE
pResMat->PutDouble(0.0, 0, 1); // SigmaSlope
if (bConstant)
pResMat->PutDouble(0.0, 1, 1); //SigmaIntercept
else
- pResMat->PutError( NOTAVAILABLE, 1, 1);
+ pResMat->PutError( FormulaError::NotAvailable, 1, 1);
pResMat->PutDouble(1.0, 0, 2); // R^2
}
else
@@ -2541,7 +2541,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
}
else
{
- pResMat->PutError( NOTAVAILABLE, 1, 1);
+ pResMat->PutError( FormulaError::NotAvailable, 1, 1);
}
double fR2 = fSSreg / (fSSreg + fSSresid);
@@ -2567,7 +2567,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
ScMatrixRef pSlopes = GetNewMat(1,K); // from b1 to bK
if (!pMeans || !pMatZ || !pSlopes)
{
- PushError(errCodeOverflow);
+ PushError(FormulaError::CodeOverflow);
return;
}
if (bConstant)
@@ -2639,7 +2639,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
{ // exact fit; incl. observed values Y are identical
pResMat->PutDouble(0.0, 1, 4); // SSresid
// F = (SSreg/K) / (SSresid/df) = #DIV/0!
- pResMat->PutError( NOTAVAILABLE, 0, 3); // F
+ pResMat->PutError( FormulaError::NotAvailable, 0, 3); // F
// RMSE = sqrt(SSresid / df) = sqrt(0 / df) = 0
pResMat->PutDouble(0.0, 1, 2); // RMSE
// SigmaSlope[i] = RMSE * sqrt(matrix[i,i]) = 0 * sqrt(...) = 0
@@ -2650,7 +2650,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
if (bConstant)
pResMat->PutDouble(0.0, K, 1); //SigmaIntercept
else
- pResMat->PutError( NOTAVAILABLE, K, 1);
+ pResMat->PutError( FormulaError::NotAvailable, K, 1);
// R^2 = SSreg / (SSreg + SSresid) = 1.0
pResMat->PutDouble(1.0, 0, 2); // R^2
@@ -2700,7 +2700,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
}
else
{
- pResMat->PutError( NOTAVAILABLE, K, 1);
+ pResMat->PutError( FormulaError::NotAvailable, K, 1);
}
double fR2 = fSSreg / (fSSreg + fSSresid);
@@ -2722,7 +2722,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
ScMatrixRef pSlopes = GetNewMat(K,1); // from b1 to bK
if (!pMeans || !pMatZ || !pSlopes)
{
- PushError(errCodeOverflow);
+ PushError(FormulaError::CodeOverflow);
return;
}
if (bConstant)
@@ -2796,7 +2796,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
{ // exact fit; incl. case observed values Y are identical
pResMat->PutDouble(0.0, 1, 4); // SSresid
// F = (SSreg/K) / (SSresid/df) = #DIV/0!
- pResMat->PutError( NOTAVAILABLE, 0, 3); // F
+ pResMat->PutError( FormulaError::NotAvailable, 0, 3); // F
// RMSE = sqrt(SSresid / df) = sqrt(0 / df) = 0
pResMat->PutDouble(0.0, 1, 2); // RMSE
// SigmaSlope[i] = RMSE * sqrt(matrix[i,i]) = 0 * sqrt(...) = 0
@@ -2807,7 +2807,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
if (bConstant)
pResMat->PutDouble(0.0, K, 1); //SigmaIntercept
else
- pResMat->PutError( NOTAVAILABLE, K, 1);
+ pResMat->PutError( FormulaError::NotAvailable, K, 1);
// R^2 = SSreg / (SSreg + SSresid) = 1.0
pResMat->PutDouble(1.0, 0, 2); // R^2
@@ -2857,7 +2857,7 @@ void ScInterpreter::CalculateRGPRKP(bool _bRKP)
}
else
{
- pResMat->PutError( NOTAVAILABLE, K, 1);
+ pResMat->PutError( FormulaError::NotAvailable, K, 1);
}
double fR2 = fSSreg / (fSSreg + fSSresid);
@@ -2991,7 +2991,7 @@ void ScInterpreter::CalculateTrendGrowth(bool _bGrowth)
}
if (!pResMat)
{
- PushError(errCodeOverflow);
+ PushError(FormulaError::CodeOverflow);
return;
}
// Uses sum(x-MeanX)^2 and not [sum x^2]-N * MeanX^2 in case bConstant.
@@ -3003,7 +3003,7 @@ void ScInterpreter::CalculateTrendGrowth(bool _bGrowth)
ScMatrixRef pCopyY = pMatY->CloneIfConst();
if (!pCopyX || !pCopyY)
{
- PushError(errMatrixSize);
+ PushError(FormulaError::MatrixSize);
return;
}
pMatX = pCopyX;
@@ -3065,7 +3065,7 @@ void ScInterpreter::CalculateTrendGrowth(bool _bGrowth)
ScMatrixRef pSlopes = GetNewMat(1,K); // from b1 to bK
if (!pMeans || !pSlopes)
{
- PushError(errCodeOverflow);
+ PushError(FormulaError::CodeOverflow);
return;
}
if (bConstant)
@@ -3124,7 +3124,7 @@ void ScInterpreter::CalculateTrendGrowth(bool _bGrowth)
ScMatrixRef pSlopes = GetNewMat(K,1); // row from b1 to bK
if (!pMeans || !pSlopes)
{
- PushError(errCodeOverflow);
+ PushError(FormulaError::CodeOverflow);
return;
}
if (bConstant)
@@ -3189,7 +3189,7 @@ void ScInterpreter::ScMatRef()
if (aCell.meType != CELLTYPE_FORMULA)
{
- PushError( errNoRef );
+ PushError( FormulaError::NoRef );
return;
}
@@ -3198,8 +3198,8 @@ void ScInterpreter::ScMatRef()
// Twisted odd corner case where an array element's cell tries to
// access the top left matrix while it is still running, see tdf#88737
// This is a hackish workaround, not a general solution, the matrix
- // isn't available anyway and errCircularReference would be set.
- PushError( errRetryCircular );
+ // isn't available anyway and FormulaError::CircularReference would be set.
+ PushError( FormulaError::RetryCircular );
return;
}
@@ -3249,8 +3249,8 @@ void ScInterpreter::ScMatRef()
nFuncFmtType = nCurFmtType;
nFuncFmtIndex = nCurFmtIndex;
// If not a result matrix, obtain the cell value.
- sal_uInt16 nErr = aCell.mpFormula->GetErrCode();
- if (nErr)
+ FormulaError nErr = aCell.mpFormula->GetErrCode();
+ if (nErr != FormulaError::NONE)
PushError( nErr );
else if (aCell.mpFormula->IsValue())
PushDouble(aCell.mpFormula->GetValue());
diff --git a/sc/source/core/tool/interpr6.cxx b/sc/source/core/tool/interpr6.cxx
index c46606891c95..ebf1a9b434d6 100644
--- a/sc/source/core/tool/interpr6.cxx
+++ b/sc/source/core/tool/interpr6.cxx
@@ -85,7 +85,7 @@ double ScInterpreter::GetGammaContFraction( double fA, double fX )
// most iterations, if fX==fAlpha+1.0; approx sqrt(fAlpha) iterations then
if (!bFinished)
{
- SetError(errNoConvergence);
+ SetError(FormulaError::NoConvergence);
}
return fApprox;
}
@@ -110,7 +110,7 @@ double ScInterpreter::GetGammaSeries( double fA, double fX )
// if fX <= fAlpha+1.0
if (nCount>10000)
{
- SetError(errNoConvergence);
+ SetError(FormulaError::NoConvergence);
}
return fSum;
}
@@ -150,7 +150,7 @@ double ScInterpreter::GetGammaDistPDF( double fX, double fAlpha, double fLambda
{
if (fAlpha < 1.0)
{
- SetError(errDivisionByZero); // should be #DIV/0
+ SetError(FormulaError::DivisionByZero); // should be #DIV/0
return HUGE_VAL;
}
else if (fAlpha == 1)
@@ -207,10 +207,10 @@ class NumericCellAccumulator
{
double mfFirst;
double mfRest;
- sal_uInt16 mnError;
+ FormulaError mnError;
public:
- NumericCellAccumulator() : mfFirst(0.0), mfRest(0.0), mnError(0) {}
+ NumericCellAccumulator() : mfFirst(0.0), mfRest(0.0), mnError(FormulaError::NONE) {}
void operator() (const sc::CellStoreType::value_type& rNode, size_t nOffset, size_t nDataSize)
{
@@ -252,13 +252,13 @@ public:
for (; it != itEnd; ++it)
{
double fVal = 0.0;
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
ScFormulaCell& rCell = const_cast<ScFormulaCell&>(*(*it));
if (!rCell.GetErrorOrValue(nErr, fVal))
// The cell has neither error nor value. Perhaps string result.
continue;
- if (nErr)
+ if (nErr != FormulaError::NONE)
{
// Cell has error - skip all the rest
mnError = nErr;
@@ -277,7 +277,7 @@ public:
}
}
- sal_uInt16 getError() const { return mnError; }
+ FormulaError getError() const { return mnError; }
double getFirst() const { return mfFirst; }
double getRest() const { return mfRest; }
};
@@ -353,11 +353,11 @@ class FuncSum : public sc::ColumnSpanSet::ColumnAction
sc::ColumnBlockConstPosition maPos;
ScColumn* mpCol;
double mfSum;
- sal_uInt16 mnError;
+ FormulaError mnError;
sal_uInt32 mnNumFmt;
public:
- FuncSum() : mpCol(nullptr), mfSum(0.0), mnError(0), mnNumFmt(0) {}
+ FuncSum() : mpCol(nullptr), mfSum(0.0), mnError(FormulaError::NONE), mnNumFmt(0) {}
virtual void startColumn(ScColumn* pCol) override
{
@@ -372,13 +372,13 @@ public:
if (!bVal)
return;
- if (mnError)
+ if (mnError != FormulaError::NONE)
return;
NumericCellAccumulator aFunc;
maPos.miCellPos = sc::ParseBlock(maPos.miCellPos, mpCol->GetCellStore(), aFunc, nRow1, nRow2);
mnError = aFunc.getError();
- if (mnError)
+ if (mnError != FormulaError::NONE)
return;
if ( fMem )
@@ -392,7 +392,7 @@ public:
mnNumFmt = mpCol->GetNumberFormat(nRow2);
};
- sal_uInt16 getError() const { return mnError; }
+ FormulaError getError() const { return mnError; }
double getSum() const { return mfSum; }
sal_uInt32 getNumberFormat() const { return mnNumFmt; }
};
@@ -469,9 +469,9 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
ScAddress aAdr;
ScRange aRange;
size_t nRefInList = 0;
- if ( nGlobalError && ( eFunc == ifCOUNT2 || eFunc == ifCOUNT ||
+ if ( nGlobalError != FormulaError::NONE && ( eFunc == ifCOUNT2 || eFunc == ifCOUNT ||
( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) ) )
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
while (nParamCount-- > 0)
{
switch (GetStackType())
@@ -487,10 +487,10 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
{
// Only check if string can be converted to number, no
// error propagation.
- sal_uInt16 nErr = nGlobalError;
- nGlobalError = 0;
+ FormulaError nErr = nGlobalError;
+ nGlobalError = FormulaError::NONE;
ConvertStringToValue( aStr );
- if (!nGlobalError)
+ if (nGlobalError == FormulaError::NONE)
++nCount;
nGlobalError = nErr;
}
@@ -515,7 +515,7 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
{
while (nParamCount-- > 0)
Pop();
- SetError( errNoValue );
+ SetError( FormulaError::NoValue );
}
}
break;
@@ -549,10 +549,10 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
ScExternalRefCache::TokenRef pToken;
ScExternalRefCache::CellFormat aFmt;
PopExternalSingleRef(pToken, &aFmt);
- if ( nGlobalError && ( eFunc == ifCOUNT2 || eFunc == ifCOUNT ||
+ if ( nGlobalError != FormulaError::NONE && ( eFunc == ifCOUNT2 || eFunc == ifCOUNT ||
( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) ) )
{
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
if ( eFunc == ifCOUNT2 && !( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) )
++nCount;
break;
@@ -569,8 +569,8 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
pToken->GetOpCode() != ocAggregate ) ||
( mnSubTotalFlags & SUBTOTAL_IGN_NESTED_ST_AG ) ) )
nCount++;
- if (nGlobalError)
- nGlobalError = 0;
+ if (nGlobalError != FormulaError::NONE)
+ nGlobalError = FormulaError::NONE;
}
else if (eType == formula::svDouble)
{
@@ -593,9 +593,9 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
case ifSUMSQ: fRes += fVal * fVal; break;
case ifPRODUCT: fRes *= fVal; break;
case ifCOUNT:
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
nCount--;
}
break;
@@ -613,10 +613,10 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
case svSingleRef :
{
PopSingleRef( aAdr );
- if ( nGlobalError && ( eFunc == ifCOUNT2 || eFunc == ifCOUNT ||
+ if ( nGlobalError != FormulaError::NONE && ( eFunc == ifCOUNT2 || eFunc == ifCOUNT ||
( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) ) )
{
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
if ( eFunc == ifCOUNT2 && !( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) )
++nCount;
break;
@@ -634,8 +634,8 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
CellType eCellType = aCell.meType;
if ( eCellType != CELLTYPE_NONE )
nCount++;
- if ( nGlobalError )
- nGlobalError = 0;
+ if ( nGlobalError != FormulaError::NONE )
+ nGlobalError = FormulaError::NONE;
}
else if (aCell.hasNumeric())
{
@@ -654,9 +654,9 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
case ifSUMSQ: fRes += fVal * fVal; break;
case ifPRODUCT: fRes *= fVal; break;
case ifCOUNT:
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
{
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
nCount--;
}
break;
@@ -676,10 +676,10 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
case svRefList :
{
PopDoubleRef( aRange, nParamCount, nRefInList);
- if ( nGlobalError && ( eFunc == ifCOUNT2 || eFunc == ifCOUNT ||
+ if ( nGlobalError != FormulaError::NONE && ( eFunc == ifCOUNT2 || eFunc == ifCOUNT ||
( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) ) )
{
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
if ( eFunc == ifCOUNT2 && !( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) )
++nCount;
if ( eFunc == ifCOUNT2 || eFunc == ifCOUNT )
@@ -696,8 +696,8 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
}
}
- if ( nGlobalError )
- nGlobalError = 0;
+ if ( nGlobalError != FormulaError::NONE )
+ nGlobalError = FormulaError::NONE;
}
else if ( ( eFunc == ifSUM || eFunc == ifCOUNT ) && !mnSubTotalFlags )
{
@@ -708,8 +708,8 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
{
FuncSum aAction;
aSet.executeColumnAction( *pDok, aAction, fMem );
- sal_uInt16 nErr = aAction.getError();
- if ( nErr )
+ FormulaError nErr = aAction.getError();
+ if ( nErr != FormulaError::NONE )
{
SetError( nErr );
return fRes;
@@ -734,7 +734,7 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
else
{
ScValueIterator aValIter( pDok, aRange, mnSubTotalFlags, bTextAsZero );
- sal_uInt16 nErr = 0;
+ FormulaError nErr = FormulaError::NONE;
if (aValIter.GetFirst(fVal, nErr))
{
// placed the loop on the inside for performance reasons:
@@ -747,7 +747,7 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
{
do
{
- if ( !nErr )
+ if ( nErr == FormulaError::NONE )
{
SetError(nErr);
if ( fMem )
@@ -778,7 +778,7 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
{
do
{
- if ( !nErr )
+ if ( nErr == FormulaError::NONE )
{
SetError(nErr);
fRes += fVal * fVal;
@@ -801,7 +801,7 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
case ifPRODUCT:
do
{
- if ( !( nErr && ( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) ) )
+ if ( !( nErr != FormulaError::NONE && ( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) ) )
{
SetError(nErr);
fRes *= fVal;
@@ -813,7 +813,7 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
case ifCOUNT:
do
{
- if ( !nErr )
+ if ( nErr == FormulaError::NONE )
nCount++;
}
while (aValIter.GetNext(fVal, nErr));
@@ -829,7 +829,7 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
{
ScMatrixRef pMat;
PopExternalDoubleRef(pMat);
- if ( nGlobalError && !( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) )
+ if ( nGlobalError != FormulaError::NONE && !( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) )
break;
IterateMatrix( pMat, eFunc, bTextAsZero, nCount, nFuncFmtType, fRes, fMem );
@@ -847,19 +847,19 @@ double ScInterpreter::IterateParameters( ScIterFunc eFunc, bool bTextAsZero )
PopError();
if ( eFunc == ifCOUNT || ( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) )
{
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
else if ( eFunc == ifCOUNT2 && !( mnSubTotalFlags & SUBTOTAL_IGN_ERR_VAL ) )
{
nCount++;
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
}
break;
default :
while (nParamCount-- > 0)
PopError();
- SetError(errIllegalParameter);
+ SetError(FormulaError::IllegalParameter);
}
}
switch( eFunc )
@@ -920,7 +920,7 @@ void ScInterpreter::ScRawSubtract()
// Obtain the minuend.
double fRes = GetDouble();
- while (!nGlobalError && nParamCount-- > 1)
+ while (nGlobalError == FormulaError::NONE && nParamCount-- > 1)
{
// Simple single values without matrix support.
fRes -= GetDouble();
diff --git a/sc/source/core/tool/interpr7.cxx b/sc/source/core/tool/interpr7.cxx
index 2d48c6b74ad0..69eed575810b 100644
--- a/sc/source/core/tool/interpr7.cxx
+++ b/sc/source/core/tool/interpr7.cxx
@@ -88,7 +88,7 @@ void ScInterpreter::ScFilterXML()
OUString aString = GetString().getString();
if(aString.isEmpty() || aXPathExpression.isEmpty())
{
- PushError( formula::errNoValue );
+ PushError( FormulaError::NoValue );
return;
}
@@ -105,7 +105,7 @@ void ScInterpreter::ScFilterXML()
if(!pDoc)
{
- PushError( formula::errNoValue );
+ PushError( FormulaError::NoValue );
return;
}
@@ -117,7 +117,7 @@ void ScInterpreter::ScFilterXML()
if(!pXPathObj)
{
- PushError( formula::errNoValue );
+ PushError( FormulaError::NoValue );
return;
}
@@ -130,7 +130,7 @@ void ScInterpreter::ScFilterXML()
xmlNodeSetPtr pNodeSet = pXPathObj->nodesetval;
if(!pNodeSet)
{
- PushError( formula::errNoValue );
+ PushError( FormulaError::NoValue );
return;
}
@@ -138,7 +138,7 @@ void ScInterpreter::ScFilterXML()
if (nNode >= nSize)
{
// For pJumpMatrix
- PushError( formula::NOTAVAILABLE);
+ PushError( FormulaError::NotAvailable);
return;
}
@@ -153,7 +153,7 @@ void ScInterpreter::ScFilterXML()
xResMat = GetNewMat( 1, nMatRows, true);
if (!xResMat)
{
- PushError( formula::errCodeOverflow);
+ PushError( FormulaError::CodeOverflow);
return;
}
}
@@ -184,9 +184,9 @@ void ScInterpreter::ScFilterXML()
else
{
if (xResMat)
- xResMat->PutError( formula::NOTAVAILABLE, 0, nNode);
+ xResMat->PutError( FormulaError::NotAvailable, 0, nNode);
else
- PushError( formula::NOTAVAILABLE );
+ PushError( FormulaError::NotAvailable );
}
}
if (xResMat)
@@ -237,14 +237,14 @@ void ScInterpreter::ScWebservice()
if(aURI.isEmpty())
{
- PushError( formula::errNoValue );
+ PushError( FormulaError::NoValue );
return;
}
uno::Reference< ucb::XSimpleFileAccess3 > xFileAccess( ucb::SimpleFileAccess::create( comphelper::getProcessComponentContext() ), uno::UNO_QUERY );
if(!xFileAccess.is())
{
- PushError( formula::errNoValue );
+ PushError( FormulaError::NoValue );
return;
}
@@ -255,12 +255,12 @@ void ScInterpreter::ScWebservice()
catch (...)
{
// don't let any exceptions pass
- PushError( formula::errNoValue );
+ PushError( FormulaError::NoValue );
return;
}
if ( !xStream.is() )
{
- PushError( formula::errNoValue );
+ PushError( FormulaError::NoValue );
return;
}
@@ -304,7 +304,7 @@ void ScInterpreter::ScEncodeURL()
OUString aStr = GetString().getString();
if ( aStr.isEmpty() )
{
- PushError( formula::errNoValue );
+ PushError( FormulaError::NoValue );
return;
}
@@ -335,7 +335,7 @@ void ScInterpreter::ScDebugVar()
SvtMiscOptions aMiscOptions;
if (!aMiscOptions.IsExperimentalMode())
{
- PushError(formula::errNoName);
+ PushError(FormulaError::NoName);
return;
}
diff --git a/sc/source/core/tool/interpr8.cxx b/sc/source/core/tool/interpr8.cxx
index d85372117cc5..894c62351375 100644
--- a/sc/source/core/tool/interpr8.cxx
+++ b/sc/source/core/tool/interpr8.cxx
@@ -89,7 +89,7 @@ private:
double mfMSE; // mean squared error (variation)
double mfRMSE; // root mean squared error (standard deviation)
double mfSMAPE; // symmetric mean absolute error
- sal_uInt16 mnErrorValue;
+ FormulaError mnErrorValue;
bool bAdditive; // true: additive method, false: mulitplicative method
bool bEDS; // true: EDS, false: ETS
@@ -119,7 +119,7 @@ public:
bool PreprocessDataRange( const ScMatrixRef& rMatX, const ScMatrixRef& rMatY, int& rSmplInPrd,
bool bDataCompletion, int nAggregation, const ScMatrixRef& rTMat,
ScETSType eETSType );
- sal_uInt16 GetError() { return mnErrorValue; };
+ FormulaError GetError() { return mnErrorValue; };
bool GetForecastRange( const ScMatrixRef& rTMat, const ScMatrixRef& rFcMat );
bool GetStatisticValue( const ScMatrixRef& rTypeMat, const ScMatrixRef& rStatMat );
bool GetSamplesInPeriod( double& rVal );
@@ -146,7 +146,7 @@ ScETSForecastCalculation::ScETSForecastCalculation( SCSIZE nSize, SvNumberFormat
, mfMSE(0.0)
, mfRMSE(0.0)
, mfSMAPE(0.0)
- , mnErrorValue(0)
+ , mnErrorValue(FormulaError::NONE)
, bAdditive(false)
, bEDS(false)
{
@@ -180,7 +180,7 @@ bool ScETSForecastCalculation::PreprocessDataRange( const ScMatrixRef& rMatX, co
if ( rTMat->GetDouble( 0 ) < maRange[ 0 ].X )
{
// target cannot be less than start of X-range
- mnErrorValue = errIllegalFPOperation;
+ mnErrorValue = FormulaError::IllegalFPOperation;
return false;
}
}
@@ -189,7 +189,7 @@ bool ScETSForecastCalculation::PreprocessDataRange( const ScMatrixRef& rMatX, co
if ( rTMat->GetDouble( 0 ) < maRange[ mnCount - 1 ].X )
{
// target cannot be before end of X-range
- mnErrorValue = errIllegalFPOperation;
+ mnErrorValue = FormulaError::IllegalFPOperation;
return false;
}
}
@@ -237,7 +237,7 @@ bool ScETSForecastCalculation::PreprocessDataRange( const ScMatrixRef& rMatX, co
if ( nAggregation == 0 )
{
// identical X-values are not allowed
- mnErrorValue = errNoValue;
+ mnErrorValue = FormulaError::NoValue;
return false;
}
double fTmp = maRange[ i - 1 ].Y;
@@ -340,7 +340,7 @@ bool ScETSForecastCalculation::PreprocessDataRange( const ScMatrixRef& rMatX, co
if ( fmod( fStep, mfStepSize ) != 0.0 )
{
// step not constant nor multiple of mfStepSize in case of gaps
- mnErrorValue = errNoValue;
+ mnErrorValue = FormulaError::NoValue;
return false;
}
bHasGap = true;
@@ -379,7 +379,7 @@ bool ScETSForecastCalculation::PreprocessDataRange( const ScMatrixRef& rMatX, co
if ( static_cast< double >( nMissingXCount ) / fOriginalCount > 0.3 )
{
// maximum of 30% missing points exceeded
- mnErrorValue = errNoValue;
+ mnErrorValue = FormulaError::NoValue;
return false;
}
}
@@ -422,7 +422,7 @@ bool ScETSForecastCalculation::prefillTrendData()
// we need at least 2 periods in the data range
if ( mnCount < 2 * mnSmplInPrd )
{
- mnErrorValue = errNoValue;
+ mnErrorValue = FormulaError::NoValue;
return false;
}
@@ -445,7 +445,7 @@ bool ScETSForecastCalculation::prefillPerIdx()
if ( mnSmplInPrd == 0 )
{
// should never happen; if mnSmplInPrd equals 0, bEDS is true
- mnErrorValue = errUnknownState;
+ mnErrorValue = FormulaError::UnknownState;
return false;
}
SCSIZE nPeriods = mnCount / mnSmplInPrd;
@@ -458,7 +458,7 @@ bool ScETSForecastCalculation::prefillPerIdx()
if ( aPeriodAverage[ i ] == 0.0 )
{
SAL_WARN( "sc.core", "prefillPerIdx(), average of 0 will cause divide by zero error, quitting calculation" );
- mnErrorValue = errDivisionByZero;
+ mnErrorValue = FormulaError::DivisionByZero;
return false;
}
}
@@ -1243,7 +1243,7 @@ void ScInterpreter::ScForecast_Ets( ScETSType eETSType )
double fVal = GetDoubleWithDefault( 1.0 );
if ( fmod( fVal, 1.0 ) != 0 || fVal < 0.0 )
{
- PushError( errIllegalFPOperation );
+ PushError( FormulaError::IllegalFPOperation );
return;
}
nSmplInPrd = static_cast< int >( fVal );
@@ -1399,7 +1399,7 @@ void ScInterpreter::ScConcat_MS()
ReverseStack( nParamCount );
size_t nRefInList = 0;
- while ( nParamCount-- > 0 && !nGlobalError )
+ while ( nParamCount-- > 0 && nGlobalError == FormulaError::NONE )
{
switch ( GetStackType() )
{
@@ -1411,7 +1411,7 @@ void ScInterpreter::ScConcat_MS()
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
break;
ScRefCellValue aCell( *pDok, aAdr );
if ( !aCell.isEmpty() )
@@ -1430,7 +1430,7 @@ void ScInterpreter::ScConcat_MS()
{
ScRange aRange;
PopDoubleRef( aRange, nParamCount, nRefInList);
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
break;
// we need to read row for row, so we can't use ScCellIter
SCCOL nCol1, nCol2;
@@ -1439,7 +1439,7 @@ void ScInterpreter::ScConcat_MS()
aRange.GetVars( nCol1, nRow1, nTab1, nCol2, nRow2, nTab2 );
if ( nTab1 != nTab2 )
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
break;
}
if ( nRow1 > nRow2 )
@@ -1478,7 +1478,7 @@ void ScInterpreter::ScConcat_MS()
SCSIZE nC, nR;
pMat->GetDimensions(nC, nR);
if (nC == 0 || nR == 0)
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
else
{
for ( SCSIZE j = 0; j < nC; j++ )
@@ -1500,7 +1500,7 @@ void ScInterpreter::ScConcat_MS()
break;
default:
PopError();
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
break;
}
}
@@ -1529,7 +1529,7 @@ void ScInterpreter::ScTextJoin_MS()
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
break;
ScRefCellValue aCell( *pDok, aAdr );
if ( !aCell.isEmpty() )
@@ -1548,7 +1548,7 @@ void ScInterpreter::ScTextJoin_MS()
{
ScRange aRange;
PopDoubleRef( aRange, nParamCount, nRefInList);
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
break;
// we need to read row for row, so we can't use ScCellIterator
SCCOL nCol1, nCol2;
@@ -1557,7 +1557,7 @@ void ScInterpreter::ScTextJoin_MS()
aRange.GetVars( nCol1, nRow1, nTab1, nCol2, nRow2, nTab2 );
if ( nTab1 != nTab2 )
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
break;
}
if ( nRow1 > nRow2 )
@@ -1598,7 +1598,7 @@ void ScInterpreter::ScTextJoin_MS()
SCSIZE nC, nR;
pMat->GetDimensions(nC, nR);
if (nC == 0 || nR == 0)
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
else
{
for ( SCSIZE j = 0; j < nC; j++ )
@@ -1625,7 +1625,7 @@ void ScInterpreter::ScTextJoin_MS()
break;
default:
PopError();
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
break;
}
if ( aDelimiters.empty() )
@@ -1642,7 +1642,7 @@ void ScInterpreter::ScTextJoin_MS()
SCSIZE nIdx = 0;
nRefInList = 0;
// get the strings to be joined
- while ( nParamCount-- > 0 && !nGlobalError )
+ while ( nParamCount-- > 0 && nGlobalError == FormulaError::NONE )
{
switch ( GetStackType() )
{
@@ -1671,7 +1671,7 @@ void ScInterpreter::ScTextJoin_MS()
{
ScAddress aAdr;
PopSingleRef( aAdr );
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
break;
ScRefCellValue aCell( *pDok, aAdr );
OUString aStr;
@@ -1708,7 +1708,7 @@ void ScInterpreter::ScTextJoin_MS()
{
ScRange aRange;
PopDoubleRef( aRange, nParamCount, nRefInList);
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
break;
// we need to read row for row, so we can't use ScCellIterator
SCCOL nCol1, nCol2;
@@ -1717,7 +1717,7 @@ void ScInterpreter::ScTextJoin_MS()
aRange.GetVars( nCol1, nRow1, nTab1, nCol2, nRow2, nTab2 );
if ( nTab1 != nTab2 )
{
- SetError( errIllegalParameter);
+ SetError( FormulaError::IllegalParameter);
break;
}
if ( nRow1 > nRow2 )
@@ -1774,7 +1774,7 @@ void ScInterpreter::ScTextJoin_MS()
SCSIZE nC, nR;
pMat->GetDimensions(nC, nR);
if (nC == 0 || nR == 0)
- SetError(errIllegalArgument);
+ SetError(FormulaError::IllegalArgument);
else
{
OUString aStr;
@@ -1835,7 +1835,7 @@ void ScInterpreter::ScTextJoin_MS()
break;
default:
PopError();
- SetError( errIllegalArgument);
+ SetError( FormulaError::IllegalArgument);
break;
}
}
@@ -1850,9 +1850,9 @@ void ScInterpreter::ScIfs_MS()
ReverseStack( nParamCount );
- nGlobalError = 0; // propagate only for condition or active result path
+ nGlobalError = FormulaError::NONE; // propagate only for condition or active result path
bool bFinished = false;
- while ( nParamCount > 0 && !bFinished && !nGlobalError )
+ while ( nParamCount > 0 && !bFinished && nGlobalError == FormulaError::NONE )
{
bool bVal = GetBool();
nParamCount--;
@@ -1885,11 +1885,11 @@ void ScInterpreter::ScIfs_MS()
}
}
- if ( nGlobalError || !bFinished )
+ if ( nGlobalError != FormulaError::NONE || !bFinished )
{
if ( !bFinished )
PushNA(); // no true expression found
- if ( nGlobalError )
+ if ( nGlobalError != FormulaError::NONE )
PushNoValue(); // expression returned something other than true or false
return;
}
@@ -1907,7 +1907,7 @@ void ScInterpreter::ScIfs_MS()
PushTokenRef( xToken );
}
else
- PushError( errUnknownStackVariable );
+ PushError( FormulaError::UnknownStackVariable );
}
@@ -1920,7 +1920,7 @@ void ScInterpreter::ScSwitch_MS()
ReverseStack( nParamCount );
- nGlobalError = 0; // propagate only for match or active result path
+ nGlobalError = FormulaError::NONE; // propagate only for match or active result path
bool isValue = false;
double fRefVal = 0;
svl::SharedString aRefStr;
@@ -1960,7 +1960,7 @@ void ScInterpreter::ScSwitch_MS()
}
nParamCount--;
bool bFinished = false;
- while ( nParamCount > 1 && !bFinished && !nGlobalError )
+ while ( nParamCount > 1 && !bFinished && nGlobalError == FormulaError::NONE )
{
double fVal = 0;
svl::SharedString aStr;
@@ -1969,7 +1969,7 @@ void ScInterpreter::ScSwitch_MS()
else
aStr = GetString();
nParamCount--;
- if ( nGlobalError || (( isValue && rtl::math::approxEqual( fRefVal, fVal ) ) ||
+ if ( nGlobalError != FormulaError::NONE || (( isValue && rtl::math::approxEqual( fRefVal, fVal ) ) ||
( !isValue && aRefStr.getDataIgnoreCase() == aStr.getDataIgnoreCase() )) )
{
// TRUE
@@ -1992,11 +1992,11 @@ void ScInterpreter::ScSwitch_MS()
PushNA();
return;
}
- nGlobalError = 0;
+ nGlobalError = FormulaError::NONE;
}
}
- if ( nGlobalError || !bFinished )
+ if ( nGlobalError != FormulaError::NONE || !bFinished )
{
if ( !bFinished )
PushNA(); // no true expression found
@@ -2018,7 +2018,7 @@ void ScInterpreter::ScSwitch_MS()
PushTokenRef( xToken );
}
else
- PushError( errUnknownStackVariable );
+ PushError( FormulaError::UnknownStackVariable );
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/sc/source/core/tool/jumpmatrix.cxx b/sc/source/core/tool/jumpmatrix.cxx
index b31d2f64e4cb..0961e78ff49d 100644
--- a/sc/source/core/tool/jumpmatrix.cxx
+++ b/sc/source/core/tool/jumpmatrix.cxx
@@ -46,7 +46,7 @@ ScJumpMatrix::ScJumpMatrix(SCSIZE nColsP, SCSIZE nRowsP)
// Initialize result matrix in case of
// a premature end of the interpreter
// due to errors.
- pMat->FillDouble(formula::CreateDoubleError(formula::NOTAVAILABLE), 0, 0, nCols - 1, nRows - 1);
+ pMat->FillDouble(CreateDoubleError(FormulaError::NotAvailable), 0, 0, nCols - 1, nRows - 1);
/*! pJump not initialized */
}
@@ -152,13 +152,13 @@ void ScJumpMatrix::SetNewResMat(SCSIZE nNewCols, SCSIZE nNewRows)
if (nResMatCols < nNewCols)
{
pMat->FillDouble(
- formula::CreateDoubleError(formula::NOTAVAILABLE),
+ CreateDoubleError(FormulaError::NotAvailable),
nResMatCols, 0, nNewCols - 1, nResMatRows - 1);
}
if (nResMatRows < nNewRows)
{
pMat->FillDouble(
- formula::CreateDoubleError(formula::NOTAVAILABLE),
+ CreateDoubleError(FormulaError::NotAvailable),
0, nResMatRows, nNewCols - 1, nNewRows - 1);
}
if (nRows == 1 && nCurCol != 0)
diff --git a/sc/source/core/tool/rangenam.cxx b/sc/source/core/tool/rangenam.cxx
index 19d403d64632..eae117c08434 100644
--- a/sc/source/core/tool/rangenam.cxx
+++ b/sc/source/core/tool/rangenam.cxx
@@ -122,7 +122,7 @@ ScRangeData::ScRangeData( ScDocument* pDok,
ScCompiler aComp( pDoc, aPos, *pCode );
aComp.SetGrammar(pDoc->GetGrammar());
aComp.CompileTokenArray();
- if ( !pCode->GetCodeError() )
+ if ( pCode->GetCodeError() == FormulaError::NONE )
eType |= Type::AbsPos;
}
@@ -165,7 +165,7 @@ void ScRangeData::CompileRangeData( const OUString& rSymbol, bool bSetError )
std::unique_ptr<ScTokenArray> pOldCode( pCode); // old pCode will be deleted
pCode = pNewCode;
pCode->SetFromRangeName(true);
- if( !pCode->GetCodeError() )
+ if( pCode->GetCodeError() == FormulaError::NONE )
{
pCode->Reset();
FormulaToken* p = pCode->GetNextReference();
@@ -189,7 +189,7 @@ void ScRangeData::CompileRangeData( const OUString& rSymbol, bool bSetError )
void ScRangeData::CompileUnresolvedXML( sc::CompileFormulaContext& rCxt )
{
- if (pCode->GetCodeError() == errNoName)
+ if (pCode->GetCodeError() == FormulaError::NoName)
{
// Reconstruct the symbol/formula and then recompile.
OUString aSymbol;
@@ -518,9 +518,9 @@ SCCOL ScRangeData::GetMaxCol() const
return mnMaxCol >= 0 ? mnMaxCol : MAXCOL;
}
-sal_uInt16 ScRangeData::GetErrCode() const
+FormulaError ScRangeData::GetErrCode() const
{
- return pCode ? pCode->GetCodeError() : 0;
+ return pCode ? pCode->GetCodeError() : FormulaError::NONE;
}
bool ScRangeData::HasReferences() const
@@ -634,7 +634,7 @@ void ScRangeData::SetCode( ScTokenArray& rArr )
void ScRangeData::InitCode()
{
- if( !pCode->GetCodeError() )
+ if( pCode->GetCodeError() == FormulaError::NONE )
{
pCode->Reset();
FormulaToken* p = pCode->GetNextReference();
diff --git a/sc/source/core/tool/rangeseq.cxx b/sc/source/core/tool/rangeseq.cxx
index 20b94191f1d2..b1c39ff56a31 100644
--- a/sc/source/core/tool/rangeseq.cxx
+++ b/sc/source/core/tool/rangeseq.cxx
@@ -42,7 +42,7 @@ static bool lcl_HasErrors( ScDocument* pDoc, const ScRange& rRange )
continue;
ScFormulaCell* pCell = aIter.getFormulaCell();
- if (pCell->GetErrCode() != 0)
+ if (pCell->GetErrCode() != FormulaError::NONE)
return true;
}
return false; // no error found
@@ -182,10 +182,10 @@ bool ScRangeToSequence::FillStringArray( uno::Any& rAny, ScDocument* pDoc, const
OUString* pColAry = aColSeq.getArray();
for (long nCol = 0; nCol < nColCount; nCol++)
{
- sal_uInt16 nErrCode = pDoc->GetStringForFormula(
+ FormulaError nErrCode = pDoc->GetStringForFormula(
ScAddress((SCCOL)(nStartCol+nCol), (SCROW)(nStartRow+nRow), nTab),
pColAry[nCol] );
- if ( nErrCode != 0 )
+ if ( nErrCode != FormulaError::NONE )
bHasErrors = true;
}
pRowAry[nRow] = aColSeq;
@@ -265,7 +265,7 @@ bool ScRangeToSequence::FillMixedArray( uno::Any& rAny, ScDocument* pDoc, const
continue;
}
- if (aCell.meType == CELLTYPE_FORMULA && aCell.mpFormula->GetErrCode() != 0)
+ if (aCell.meType == CELLTYPE_FORMULA && aCell.mpFormula->GetErrCode() != FormulaError::NONE)
{
// if NV is allowed, leave empty for errors
bHasErrors = true;
diff --git a/sc/source/core/tool/scmatrix.cxx b/sc/source/core/tool/scmatrix.cxx
index 3b035c2c868b..e9dc4f8eb97e 100644
--- a/sc/source/core/tool/scmatrix.cxx
+++ b/sc/source/core/tool/scmatrix.cxx
@@ -73,17 +73,17 @@ double convertStringToValue( ScInterpreter* pErrorInterpreter, const OUString& r
{
if (pErrorInterpreter)
{
- sal_uInt16 nError = 0;
+ FormulaError nError = FormulaError::NONE;
short nCurFmtType = 0;
double fValue = pErrorInterpreter->ConvertStringToValue( rStr, nError, nCurFmtType);
- if (nError)
+ if (nError != FormulaError::NONE)
{
pErrorInterpreter->SetError( nError);
- return formula::CreateDoubleError( nError);
+ return CreateDoubleError( nError);
}
return fValue;
}
- return formula::CreateDoubleError( formula::errNoValue);
+ return CreateDoubleError( FormulaError::NoValue);
}
struct ElemEqualZero : public unary_function<double, double>
@@ -244,7 +244,7 @@ public:
bool ValidColRow( SCSIZE nC, SCSIZE nR) const;
bool ValidColRowReplicated( SCSIZE & rC, SCSIZE & rR ) const;
bool ValidColRowOrReplicated( SCSIZE & rC, SCSIZE & rR ) const;
- void SetErrorAtInterpreter( sal_uInt16 nError ) const;
+ void SetErrorAtInterpreter( FormulaError nError ) const;
void PutDouble(double fVal, SCSIZE nC, SCSIZE nR);
void PutDouble( double fVal, SCSIZE nIndex);
@@ -256,9 +256,9 @@ public:
void PutEmpty(SCSIZE nC, SCSIZE nR);
void PutEmptyPath(SCSIZE nC, SCSIZE nR);
- void PutError( sal_uInt16 nErrorCode, SCSIZE nC, SCSIZE nR );
+ void PutError( FormulaError nErrorCode, SCSIZE nC, SCSIZE nR );
void PutBoolean(bool bVal, SCSIZE nC, SCSIZE nR);
- sal_uInt16 GetError( SCSIZE nC, SCSIZE nR) const;
+ FormulaError GetError( SCSIZE nC, SCSIZE nR) const;
double GetDouble(SCSIZE nC, SCSIZE nR) const;
double GetDouble( SCSIZE nIndex) const;
double GetDoubleWithStringConversion(SCSIZE nC, SCSIZE nR) const;
@@ -364,7 +364,7 @@ void ScMatrixImpl::Resize(SCSIZE nC, SCSIZE nR)
else
{
// Invalid matrix size, allocate 1x1 matrix with error value.
- maMat.resize(1, 1, formula::CreateDoubleError( formula::errMatrixSize));
+ maMat.resize(1, 1, CreateDoubleError( FormulaError::MatrixSize));
maMatFlag.resize(1, 1);
}
}
@@ -379,7 +379,7 @@ void ScMatrixImpl::Resize(SCSIZE nC, SCSIZE nR, double fVal)
else
{
// Invalid matrix size, allocate 1x1 matrix with error value.
- maMat.resize(1, 1, formula::CreateDoubleError( formula::errStackOverflow));
+ maMat.resize(1, 1, CreateDoubleError( FormulaError::StackOverflow));
maMatFlag.resize(1, 1);
}
}
@@ -437,7 +437,7 @@ bool ScMatrixImpl::ValidColRowOrReplicated( SCSIZE & rC, SCSIZE & rR ) const
return ValidColRow( rC, rR) || ValidColRowReplicated( rC, rR);
}
-void ScMatrixImpl::SetErrorAtInterpreter( sal_uInt16 nError ) const
+void ScMatrixImpl::SetErrorAtInterpreter( FormulaError nError ) const
{
if ( pErrorInterpreter )
pErrorInterpreter->SetError( nError);
@@ -523,9 +523,9 @@ void ScMatrixImpl::PutEmptyPath(SCSIZE nC, SCSIZE nR)
}
}
-void ScMatrixImpl::PutError( sal_uInt16 nErrorCode, SCSIZE nC, SCSIZE nR )
+void ScMatrixImpl::PutError( FormulaError nErrorCode, SCSIZE nC, SCSIZE nR )
{
- maMat.set(nR, nC, formula::CreateDoubleError(nErrorCode));
+ maMat.set(nR, nC, CreateDoubleError(nErrorCode));
}
void ScMatrixImpl::PutBoolean(bool bVal, SCSIZE nC, SCSIZE nR)
@@ -538,17 +538,17 @@ void ScMatrixImpl::PutBoolean(bool bVal, SCSIZE nC, SCSIZE nR)
}
}
-sal_uInt16 ScMatrixImpl::GetError( SCSIZE nC, SCSIZE nR) const
+FormulaError ScMatrixImpl::GetError( SCSIZE nC, SCSIZE nR) const
{
if (ValidColRowOrReplicated( nC, nR ))
{
double fVal = maMat.get_numeric(nR, nC);
- return formula::GetDoubleErrorValue(fVal);
+ return GetDoubleErrorValue(fVal);
}
else
{
OSL_FAIL("ScMatrixImpl::GetError: dimension error");
- return formula::errNoValue;
+ return FormulaError::NoValue;
}
}
@@ -559,8 +559,8 @@ double ScMatrixImpl::GetDouble(SCSIZE nC, SCSIZE nR) const
double fVal = maMat.get_numeric(nR, nC);
if ( pErrorInterpreter )
{
- sal_uInt16 nError = formula::GetDoubleErrorValue(fVal);
- if ( nError )
+ FormulaError nError = GetDoubleErrorValue(fVal);
+ if ( nError != FormulaError::NONE )
SetErrorAtInterpreter( nError);
}
return fVal;
@@ -568,7 +568,7 @@ double ScMatrixImpl::GetDouble(SCSIZE nC, SCSIZE nR) const
else
{
OSL_FAIL("ScMatrixImpl::GetDouble: dimension error");
- return formula::CreateDoubleError( formula::errNoValue);
+ return CreateDoubleError( FormulaError::NoValue);
}
}
@@ -606,7 +606,7 @@ svl::SharedString ScMatrixImpl::GetString(SCSIZE nC, SCSIZE nR) const
default:
OSL_FAIL("ScMatrixImpl::GetString: access error, no string");
}
- SetErrorAtInterpreter(formula::GetDoubleErrorValue(fErr));
+ SetErrorAtInterpreter(GetDoubleErrorValue(fErr));
}
else
{
@@ -658,8 +658,8 @@ svl::SharedString ScMatrixImpl::GetString( SvNumberFormatter& rFormatter, SCSIZE
;
}
- sal_uInt16 nError = formula::GetDoubleErrorValue(fVal);
- if (nError)
+ FormulaError nError = GetDoubleErrorValue(fVal);
+ if (nError != FormulaError::NONE)
{
SetErrorAtInterpreter( nError);
return svl::SharedString( ScGlobal::GetErrorString( nError)); // string not interned
@@ -1018,7 +1018,7 @@ double EvalMatrix(const MatrixImplType& rMat)
mdds::mtm::element_t eType = rMat.get_type(aPos);
if (eType != mdds::mtm::element_numeric && eType != mdds::mtm::element_boolean)
// assuming a CompareMat this is an error
- return formula::CreateDoubleError(formula::errIllegalArgument);
+ return CreateDoubleError(FormulaError::IllegalArgument);
double fVal = rMat.get_numeric(aPos);
if (!::rtl::math::isFinite(fVal))
@@ -1497,7 +1497,7 @@ inline double evaluate( double fVal, ScQueryOp eOp )
}
OSL_TRACE( "evaluate: unhandled comparison operator: %d", (int)eOp);
- return formula::CreateDoubleError( formula::errUnknownState);
+ return CreateDoubleError( FormulaError::UnknownState);
}
class CompareMatrixFunc : public std::unary_function<MatrixImplType::element_block_type, void>
@@ -1695,7 +1695,7 @@ public:
ToDoubleArray( size_t nSize, bool bEmptyAsZero ) :
maArray(nSize, 0.0), miPos(maArray.begin()), mbEmptyAsZero(bEmptyAsZero)
{
- mfNaN = formula::CreateDoubleError( formula::errElementNaN);
+ mfNaN = CreateDoubleError( FormulaError::ElementNaN);
}
void operator() (const MatrixImplType::element_block_node_type& node)
@@ -1766,7 +1766,7 @@ class MergeDoubleArrayFunc : public std::unary_function<MatrixImplType::element_
public:
MergeDoubleArrayFunc(std::vector<double>& rArray) : mrArray(rArray), miPos(mrArray.begin())
{
- mfNaN = formula::CreateDoubleError( formula::errElementNaN);
+ mfNaN = CreateDoubleError( FormulaError::ElementNaN);
}
void operator() (const MatrixImplType::element_block_node_type& node)
@@ -1782,7 +1782,7 @@ public:
numeric_element_block::const_iterator itEnd = numeric_element_block::end(*node.data);
for (; it != itEnd; ++it, ++miPos)
{
- if (formula::GetDoubleErrorValue(*miPos) == formula::errElementNaN)
+ if (GetDoubleErrorValue(*miPos) == FormulaError::ElementNaN)
continue;
*miPos = op(*miPos, *it);
@@ -1795,7 +1795,7 @@ public:
boolean_element_block::const_iterator itEnd = boolean_element_block::end(*node.data);
for (; it != itEnd; ++it, ++miPos)
{
- if (formula::GetDoubleErrorValue(*miPos) == formula::errElementNaN)
+ if (GetDoubleErrorValue(*miPos) == FormulaError::ElementNaN)
continue;
*miPos = op(*miPos, *it ? 1.0 : 0.0);
@@ -1813,7 +1813,7 @@ public:
// Empty element is equivalent of having a numeric value of 0.0.
for (size_t i = 0; i < node.size; ++i, ++miPos)
{
- if (formula::GetDoubleErrorValue(*miPos) == formula::errElementNaN)
+ if (GetDoubleErrorValue(*miPos) == FormulaError::ElementNaN)
continue;
*miPos = op(*miPos, 0.0);
@@ -2452,15 +2452,15 @@ void ScMatrixImpl::MatConcat(SCSIZE nMaxCol, SCSIZE nMaxRow, const ScMatrixRef&
std::vector<OUString> aString(nMaxCol * nMaxRow);
std::vector<bool> aValid(nMaxCol * nMaxRow, true);
- std::vector<sal_uInt16> nErrors(nMaxCol * nMaxRow, 0);
+ std::vector<FormulaError> nErrors(nMaxCol * nMaxRow,FormulaError::NONE);
size_t nRowOffset = 0;
size_t nColOffset = 0;
std::function<void(size_t, size_t, double)> aDoubleFunc =
[&](size_t nRow, size_t nCol, double nVal)
{
- sal_uInt16 nErr = formula::GetDoubleErrorValue(nVal);
- if (nErr)
+ FormulaError nErr = GetDoubleErrorValue(nVal);
+ if (nErr != FormulaError::NONE)
{
aValid[get_index(nMaxRow, nMaxCol, nRow, nCol, nRowOffset, nColOffset)] = false;
nErrors[get_index(nMaxRow, nMaxCol, nRow, nCol, nRowOffset, nColOffset)] = nErr;
@@ -2521,8 +2521,8 @@ void ScMatrixImpl::MatConcat(SCSIZE nMaxCol, SCSIZE nMaxRow, const ScMatrixRef&
std::function<void(size_t, size_t, double)> aDoubleFunc2 =
[&](size_t nRow, size_t nCol, double nVal)
{
- sal_uInt16 nErr = formula::GetDoubleErrorValue(nVal);
- if (nErr)
+ FormulaError nErr = GetDoubleErrorValue(nVal);
+ if (nErr != FormulaError::NONE)
{
aValid[get_index(nMaxRow, nMaxCol, nRow, nCol, nRowOffset, nColOffset)] = false;
nErrors[get_index(nMaxRow, nMaxCol, nRow, nCol, nRowOffset, nColOffset)] = nErr;
@@ -2610,7 +2610,7 @@ void ScMatrixImpl::MatConcat(SCSIZE nMaxCol, SCSIZE nMaxRow, const ScMatrixRef&
}
else
{
- pos = maMat.set(pos, formula::CreateDoubleError(nErrors[nMaxRow * i + j]));
+ pos = maMat.set(pos, CreateDoubleError(nErrors[nMaxRow * i + j]));
}
pos = MatrixImplType::next_position(pos);
}
@@ -2654,7 +2654,7 @@ ScFullMatrix::ScFullMatrix( SCSIZE nC, SCSIZE nR) :
pImpl.reset( new ScMatrixImpl( nC, nR));
else
// Invalid matrix size, allocate 1x1 matrix with error value.
- pImpl.reset( new ScMatrixImpl( 1,1, formula::CreateDoubleError( formula::errMatrixSize)));
+ pImpl.reset( new ScMatrixImpl( 1,1, CreateDoubleError( FormulaError::MatrixSize)));
}
ScFullMatrix::ScFullMatrix(SCSIZE nC, SCSIZE nR, double fInitVal) :
@@ -2664,7 +2664,7 @@ ScFullMatrix::ScFullMatrix(SCSIZE nC, SCSIZE nR, double fInitVal) :
pImpl.reset( new ScMatrixImpl( nC, nR, fInitVal));
else
// Invalid matrix size, allocate 1x1 matrix with error value.
- pImpl.reset( new ScMatrixImpl( 1,1, formula::CreateDoubleError( formula::errMatrixSize)));
+ pImpl.reset( new ScMatrixImpl( 1,1, CreateDoubleError( FormulaError::MatrixSize)));
}
ScFullMatrix::ScFullMatrix( size_t nC, size_t nR, const std::vector<double>& rInitVals ) :
@@ -2674,7 +2674,7 @@ ScFullMatrix::ScFullMatrix( size_t nC, size_t nR, const std::vector<double>& rIn
pImpl.reset( new ScMatrixImpl( nC, nR, rInitVals));
else
// Invalid matrix size, allocate 1x1 matrix with error value.
- pImpl.reset( new ScMatrixImpl( 1,1, formula::CreateDoubleError( formula::errMatrixSize)));
+ pImpl.reset( new ScMatrixImpl( 1,1, CreateDoubleError( FormulaError::MatrixSize)));
}
ScFullMatrix::~ScFullMatrix()
@@ -2794,7 +2794,7 @@ void ScFullMatrix::PutEmptyPath(SCSIZE nC, SCSIZE nR)
pImpl->PutEmptyPath(nC, nR);
}
-void ScFullMatrix::PutError( sal_uInt16 nErrorCode, SCSIZE nC, SCSIZE nR )
+void ScFullMatrix::PutError( FormulaError nErrorCode, SCSIZE nC, SCSIZE nR )
{
pImpl->PutError(nErrorCode, nC, nR);
}
@@ -2804,7 +2804,7 @@ void ScFullMatrix::PutBoolean(bool bVal, SCSIZE nC, SCSIZE nR)
pImpl->PutBoolean(bVal, nC, nR);
}
-sal_uInt16 ScFullMatrix::GetError( SCSIZE nC, SCSIZE nR) const
+FormulaError ScFullMatrix::GetError( SCSIZE nC, SCSIZE nR) const
{
return pImpl->GetError(nC, nR);
}
@@ -3075,8 +3075,8 @@ struct COp<T, double>
/** A template for operations where operands are supposed to be numeric.
A non-numeric (string) operand leads to the configured conversion to number
- method being called if in interpreter context and an errNoValue DoubleError
- if conversion was not possible, else to an unconditional errNoValue
+ method being called if in interpreter context and an FormulaError::NoValue DoubleError
+ if conversion was not possible, else to an unconditional FormulaError::NoValue
DoubleError.
An empty operand evaluates to 0.
XXX: semantically TEmptyRes and types other than number_value_type are
@@ -3106,9 +3106,9 @@ public:
{
if (mpErrorInterpreter)
{
- sal_uInt16 nErr = mpErrorInterpreter->GetError();
- if (nErr)
- mfVal = formula::CreateDoubleError( nErr);
+ FormulaError nErr = mpErrorInterpreter->GetError();
+ if (nErr != FormulaError::NONE)
+ mfVal = CreateDoubleError( nErr);
}
}
@@ -3618,7 +3618,7 @@ void ScVectorRefMatrix::PutEmptyPath(SCSIZE nC, SCSIZE nR)
mpFullMatrix->PutEmptyPath(nC, nR);
}
-void ScVectorRefMatrix::PutError(sal_uInt16 nErrorCode, SCSIZE nC, SCSIZE nR)
+void ScVectorRefMatrix::PutError(FormulaError nErrorCode, SCSIZE nC, SCSIZE nR)
{
ensureFullMatrix();
mpFullMatrix->PutError(nErrorCode, nC, nR);
@@ -3666,7 +3666,7 @@ void ScVectorRefMatrix::PutEmptyPathVector(SCSIZE nCount, SCSIZE nC, SCSIZE nR)
mpFullMatrix->PutEmptyPathVector(nCount, nC, nR);
}
-sal_uInt16 ScVectorRefMatrix::GetError(SCSIZE nC, SCSIZE nR) const
+FormulaError ScVectorRefMatrix::GetError(SCSIZE nC, SCSIZE nR) const
{
const_cast<ScVectorRefMatrix*>(this)->ensureFullMatrix();
return mpFullMatrix->GetError(nC, nR);
diff --git a/sc/source/core/tool/token.cxx b/sc/source/core/tool/token.cxx
index ba91d2a0ad97..156b099f4500 100644
--- a/sc/source/core/tool/token.cxx
+++ b/sc/source/core/tool/token.cxx
@@ -294,7 +294,7 @@ void ScRawToken::SetDouble(double rVal)
nValue = rVal;
}
-void ScRawToken::SetErrorConstant( sal_uInt16 nErr )
+void ScRawToken::SetErrorConstant( FormulaError nErr )
{
eOp = ocPush;
eType = svError;
@@ -4736,8 +4736,8 @@ void appendTokenByType( sc::TokenStringContext& rCxt, OUStringBuffer& rBuf, cons
}
else
{
- sal_uInt16 nErr = pMat->GetError(nC, nR);
- if (nErr)
+ FormulaError nErr = pMat->GetError(nC, nR);
+ if (nErr != FormulaError::NONE)
rBuf.append(ScGlobal::GetErrorString(nErr));
else
appendDouble(rCxt, rBuf, pMat->GetDouble(nC, nR));
@@ -4851,30 +4851,30 @@ void appendTokenByType( sc::TokenStringContext& rCxt, OUStringBuffer& rBuf, cons
break;
case svError:
{
- sal_uInt16 nErr = rToken.GetError();
+ FormulaError nErr = rToken.GetError();
OpCode eOpErr;
switch (nErr)
{
break;
- case errDivisionByZero:
+ case FormulaError::DivisionByZero:
eOpErr = ocErrDivZero;
break;
- case errNoValue:
+ case FormulaError::NoValue:
eOpErr = ocErrValue;
break;
- case errNoRef:
+ case FormulaError::NoRef:
eOpErr = ocErrRef;
break;
- case errNoName:
+ case FormulaError::NoName:
eOpErr = ocErrName;
break;
- case errIllegalFPOperation:
+ case FormulaError::IllegalFPOperation:
eOpErr = ocErrNum;
break;
- case NOTAVAILABLE:
+ case FormulaError::NotAvailable:
eOpErr = ocErrNA;
break;
- case errNoCode:
+ case FormulaError::NoCode:
default:
eOpErr = ocErrNull;
}
diff --git a/sc/source/filter/dif/difexp.cxx b/sc/source/filter/dif/difexp.cxx
index a68c0d236f39..cbdd8a8a4659 100644
--- a/sc/source/filter/dif/difexp.cxx
+++ b/sc/source/filter/dif/difexp.cxx
@@ -31,6 +31,7 @@
#include "cellvalue.hxx"
#include <rtl/strbuf.hxx>
#include <osl/diagnose.h>
+#include <formula/errorcodes.hxx>
void ScFormatFilterPluginImpl::ScExportDif( SvStream& rStream, ScDocument* pDoc,
const ScAddress& rOutPos, const rtl_TextEncoding eNach )
@@ -168,7 +169,7 @@ void ScFormatFilterPluginImpl::ScExportDif( SvStream& rOut, ScDocument* pDoc,
bWriteStringData = true;
break;
case CELLTYPE_FORMULA:
- if (aCell.mpFormula->GetErrCode())
+ if (aCell.mpFormula->GetErrCode() != FormulaError::NONE)
aOS.appendAscii(pNumDataERROR);
else if (aCell.mpFormula->IsValue())
{
diff --git a/sc/source/filter/excel/excform.cxx b/sc/source/filter/excel/excform.cxx
index 0b03feb10721..d911f185d2d4 100644
--- a/sc/source/filter/excel/excform.cxx
+++ b/sc/source/filter/excel/excform.cxx
@@ -1676,7 +1676,7 @@ void ExcelToSc::ExcRelToScRel( sal_uInt16 nRow, sal_uInt8 nCol, ScSingleRefData
const ScTokenArray* ExcelToSc::GetBoolErr( XclBoolError eType )
{
- sal_uInt16 nError;
+ FormulaError nError;
aPool.Reset();
aStack.Reset();
@@ -1684,20 +1684,20 @@ const ScTokenArray* ExcelToSc::GetBoolErr( XclBoolError eType )
switch( eType )
{
- case xlErrNull: eOc = ocStop; nError = formula::errNoCode; break;
- case xlErrDiv0: eOc = ocStop; nError = formula::errDivisionByZero; break;
- case xlErrValue: eOc = ocStop; nError = formula::errNoValue; break;
- case xlErrRef: eOc = ocStop; nError = formula::errNoRef; break;
- case xlErrName: eOc = ocStop; nError = formula::errNoName; break;
- case xlErrNum: eOc = ocStop; nError = formula::errIllegalFPOperation; break;
- case xlErrNA: eOc = ocNotAvail; nError = formula::NOTAVAILABLE; break;
- case xlErrTrue: eOc = ocTrue; nError = 0; break;
- case xlErrFalse: eOc = ocFalse; nError = 0; break;
- case xlErrUnknown: eOc = ocStop; nError = formula::errUnknownState; break;
+ case xlErrNull: eOc = ocStop; nError = FormulaError::NoCode; break;
+ case xlErrDiv0: eOc = ocStop; nError = FormulaError::DivisionByZero; break;
+ case xlErrValue: eOc = ocStop; nError = FormulaError::NoValue; break;
+ case xlErrRef: eOc = ocStop; nError = FormulaError::NoRef; break;
+ case xlErrName: eOc = ocStop; nError = FormulaError::NoName; break;
+ case xlErrNum: eOc = ocStop; nError = FormulaError::IllegalFPOperation; break;
+ case xlErrNA: eOc = ocNotAvail; nError = FormulaError::NotAvailable; break;
+ case xlErrTrue: eOc = ocTrue; nError = FormulaError::NONE; break;
+ case xlErrFalse: eOc = ocFalse; nError = FormulaError::NONE; break;
+ case xlErrUnknown: eOc = ocStop; nError = FormulaError::UnknownState; break;
default:
OSL_FAIL( "ExcelToSc::GetBoolErr - wrong enum!" );
eOc = ocNoName;
- nError = formula::errUnknownState;
+ nError = FormulaError::UnknownState;
}
aPool << eOc;
@@ -1707,7 +1707,7 @@ const ScTokenArray* ExcelToSc::GetBoolErr( XclBoolError eType )
aPool >> aStack;
const ScTokenArray* pErgebnis = aPool[ aStack.Get() ];
- if( nError )
+ if( nError != FormulaError::NONE )
const_cast<ScTokenArray*>(pErgebnis)->SetCodeError( nError );
const_cast<ScTokenArray*>(pErgebnis)->SetExclusiveRecalcModeNormal();
@@ -1744,15 +1744,15 @@ const ScTokenArray* ExcelToSc::GetSharedFormula( const ScAddress& rRefPos ) cons
void ExcelToSc::SetError( ScFormulaCell &rCell, const ConvErr eErr )
{
- sal_uInt16 nInd;
+ FormulaError nInd;
switch( eErr )
{
- case ConvErrNi: nInd = formula::errUnknownToken; break;
- case ConvErrNoMem: nInd = formula::errCodeOverflow; break;
- case ConvErrExternal: nInd = formula::errNoName; break;
- case ConvErrCount: nInd = formula::errCodeOverflow; break;
- default: nInd = formula::errNoCode; // I had no better idea
+ case ConvErrNi: nInd = FormulaError::UnknownToken; break;
+ case ConvErrNoMem: nInd = FormulaError::CodeOverflow; break;
+ case ConvErrExternal: nInd = FormulaError::NoName; break;
+ case ConvErrCount: nInd = FormulaError::CodeOverflow; break;
+ default: nInd = FormulaError::NoCode; // I had no better idea
}
rCell.SetErrCode( nInd );
diff --git a/sc/source/filter/excel/xeformula.cxx b/sc/source/filter/excel/xeformula.cxx
index 3be306e5b82e..b810279e19ca 100644
--- a/sc/source/filter/excel/xeformula.cxx
+++ b/sc/source/filter/excel/xeformula.cxx
@@ -492,8 +492,8 @@ XclTokenArrayRef XclExpFmlaCompImpl::CreateFormula( XclFormulaType eType,
if( mxData->mbOk )
{
XclExpScToken aTokData( GetNextToken() );
- sal_uInt16 nScError = rScTokArr.GetCodeError();
- if( (nScError != 0) && (!aTokData.Is() || (aTokData.GetOpCode() == ocStop)) )
+ FormulaError nScError = rScTokArr.GetCodeError();
+ if( (nScError != FormulaError::NONE) && (!aTokData.Is() || (aTokData.GetOpCode() == ocStop)) )
{
// #i50253# convert simple ocStop token to error code formula (e.g. =#VALUE!)
AppendErrorToken( XclTools::GetXclErrorCode( nScError ), aTokData.mnSpaces );
@@ -1286,13 +1286,14 @@ void XclExpFmlaCompImpl::ProcessMatrix( const XclExpScToken& rTokData )
ScMatrixValue nMatVal = pMatrix->Get( nScCol, nScRow );
if( ScMatrix::IsValueType( nMatVal.nType ) ) // value, boolean, or error
{
+ FormulaError nErr;
if( ScMatrix::IsBooleanType( nMatVal.nType ) )
{
AppendExt( EXC_CACHEDVAL_BOOL );
AppendExt( static_cast< sal_uInt8 >( nMatVal.GetBoolean() ? 1 : 0 ) );
AppendExt( 0, 7 );
}
- else if( sal_uInt16 nErr = nMatVal.GetError() )
+ else if( (nErr = nMatVal.GetError()) != FormulaError::NONE )
{
AppendExt( EXC_CACHEDVAL_ERROR );
AppendExt( XclTools::GetXclErrorCode( nErr ) );
diff --git a/sc/source/filter/excel/xehelper.cxx b/sc/source/filter/excel/xehelper.cxx
index fa5a429a7b98..e0e8dfa6d3cf 100644
--- a/sc/source/filter/excel/xehelper.cxx
+++ b/sc/source/filter/excel/xehelper.cxx
@@ -1027,6 +1027,7 @@ void XclExpCachedMatrix::Save( XclExpStream& rStrm ) const
{
ScMatrixValue nMatVal = mrMatrix.Get( nCol, nRow );
+ FormulaError nScError;
if( SC_MATVAL_EMPTY == nMatVal.nType )
{
rStrm.SetSliceSize( 9 );
@@ -1046,7 +1047,7 @@ void XclExpCachedMatrix::Save( XclExpStream& rStrm ) const
rStrm << EXC_CACHEDVAL_BOOL << nBool;
rStrm.WriteZeroBytes( 7 );
}
- else if( sal_uInt16 nScError = nMatVal.GetError() )
+ else if( (nScError = nMatVal.GetError()) != FormulaError::NONE )
{
sal_Int8 nError ( XclTools::GetXclErrorCode( nScError ) );
rStrm.SetSliceSize( 9 );
diff --git a/sc/source/filter/excel/xelink.cxx b/sc/source/filter/excel/xelink.cxx
index 3a8c0d21fdb0..8c7b1399a576 100644
--- a/sc/source/filter/excel/xelink.cxx
+++ b/sc/source/filter/excel/xelink.cxx
@@ -1185,7 +1185,7 @@ void XclExpCrn::WriteDouble( XclExpStream& rStrm, double fValue )
{
if( ::rtl::math::isNan( fValue ) )
{
- sal_uInt16 nScError = formula::GetDoubleErrorValue(fValue);
+ FormulaError nScError = GetDoubleErrorValue(fValue);
WriteError( rStrm, XclTools::GetXclErrorCode( nScError ) );
}
else
diff --git a/sc/source/filter/excel/xestream.cxx b/sc/source/filter/excel/xestream.cxx
index 7d08fb84ec70..adebb97ad352 100644
--- a/sc/source/filter/excel/xestream.cxx
+++ b/sc/source/filter/excel/xestream.cxx
@@ -639,7 +639,7 @@ void XclExpBiff8Encrypter::EncryptBytes( SvStream& rStrm, vector<sal_uInt8>& aBy
mnOldPos = nStrmPos;
}
-static const char* lcl_GetErrorString( sal_uInt16 nScErrCode )
+static const char* lcl_GetErrorString( FormulaError nScErrCode )
{
sal_uInt8 nXclErrCode = XclTools::GetXclErrorCode( nScErrCode );
switch( nXclErrCode )
diff --git a/sc/source/filter/excel/xetable.cxx b/sc/source/filter/excel/xetable.cxx
index bed5e720b746..c5ab7de726cb 100644
--- a/sc/source/filter/excel/xetable.cxx
+++ b/sc/source/filter/excel/xetable.cxx
@@ -34,6 +34,7 @@
#include "xeescher.hxx"
#include "xeextlst.hxx"
#include "tokenarray.hxx"
+#include <formula/errorcodes.hxx>
#include <thread>
#include <comphelper/threadpool.hxx>
@@ -1045,8 +1046,8 @@ void XclExpFormulaCell::SaveXml( XclExpXmlStream& rStrm )
void XclExpFormulaCell::WriteContents( XclExpStream& rStrm )
{
- sal_uInt16 nScErrCode = mrScFmlaCell.GetErrCode();
- if( nScErrCode )
+ FormulaError nScErrCode = mrScFmlaCell.GetErrCode();
+ if( nScErrCode != FormulaError::NONE )
{
rStrm << EXC_FORMULA_RES_ERROR << sal_uInt8( 0 )
<< XclTools::GetXclErrorCode( nScErrCode )
diff --git a/sc/source/filter/excel/xihelper.cxx b/sc/source/filter/excel/xihelper.cxx
index f562714ee4d1..24fd6bb6cb87 100644
--- a/sc/source/filter/excel/xihelper.cxx
+++ b/sc/source/filter/excel/xihelper.cxx
@@ -812,9 +812,9 @@ XclImpCachedValue::~XclImpCachedValue()
{
}
-sal_uInt16 XclImpCachedValue::GetScError() const
+FormulaError XclImpCachedValue::GetScError() const
{
- return (mnType == EXC_CACHEDVAL_ERROR) ? XclTools::GetScErrorCode( mnBoolErr ) : 0;
+ return (mnType == EXC_CACHEDVAL_ERROR) ? XclTools::GetScErrorCode( mnBoolErr ) : FormulaError::NONE;
}
// Matrix Cached Values ==============================================================
diff --git a/sc/source/filter/excel/xltools.cxx b/sc/source/filter/excel/xltools.cxx
index a187ebab3e3e..1392eb5151e5 100644
--- a/sc/source/filter/excel/xltools.cxx
+++ b/sc/source/filter/excel/xltools.cxx
@@ -197,49 +197,50 @@ sal_uInt8 XclTools::GetXclOrientFromRot( sal_uInt16 nXclRot )
return EXC_ORIENT_NONE;
}
-sal_uInt8 XclTools::GetXclErrorCode( sal_uInt16 nScError )
+sal_uInt8 XclTools::GetXclErrorCode( FormulaError nScError )
{
switch( nScError )
{
- case formula::errIllegalArgument: return EXC_ERR_VALUE;
- case formula::errIllegalFPOperation: return EXC_ERR_NUM; // maybe DIV/0 or NUM...
- case formula::errDivisionByZero: return EXC_ERR_DIV0;
- case formula::errIllegalParameter: return EXC_ERR_VALUE;
- case formula::errPairExpected: return EXC_ERR_VALUE;
- case formula::errOperatorExpected: return EXC_ERR_VALUE;
- case formula::errVariableExpected: return EXC_ERR_VALUE;
- case formula::errParameterExpected: return EXC_ERR_VALUE;
- case formula::errNoValue: return EXC_ERR_VALUE;
- case formula::errCircularReference: return EXC_ERR_VALUE;
- case formula::errNoCode: return EXC_ERR_NULL;
- case formula::errNoRef: return EXC_ERR_REF;
- case formula::errNoName: return EXC_ERR_NAME;
- case formula::errNoAddin: return EXC_ERR_NAME;
- case formula::errNoMacro: return EXC_ERR_NAME;
- case formula::NOTAVAILABLE: return EXC_ERR_NA;
+ case FormulaError::IllegalArgument: return EXC_ERR_VALUE;
+ case FormulaError::IllegalFPOperation: return EXC_ERR_NUM; // maybe DIV/0 or NUM...
+ case FormulaError::DivisionByZero: return EXC_ERR_DIV0;
+ case FormulaError::IllegalParameter: return EXC_ERR_VALUE;
+ case FormulaError::PairExpected: return EXC_ERR_VALUE;
+ case FormulaError::OperatorExpected: return EXC_ERR_VALUE;
+ case FormulaError::VariableExpected: return EXC_ERR_VALUE;
+ case FormulaError::ParameterExpected: return EXC_ERR_VALUE;
+ case FormulaError::NoValue: return EXC_ERR_VALUE;
+ case FormulaError::CircularReference: return EXC_ERR_VALUE;
+ case FormulaError::NoCode: return EXC_ERR_NULL;
+ case FormulaError::NoRef: return EXC_ERR_REF;
+ case FormulaError::NoName: return EXC_ERR_NAME;
+ case FormulaError::NoAddin: return EXC_ERR_NAME;
+ case FormulaError::NoMacro: return EXC_ERR_NAME;
+ case FormulaError::NotAvailable: return EXC_ERR_NA;
+ default: break;
}
return EXC_ERR_NA;
}
-sal_uInt16 XclTools::GetScErrorCode( sal_uInt8 nXclError )
+FormulaError XclTools::GetScErrorCode( sal_uInt8 nXclError )
{
switch( nXclError )
{
- case EXC_ERR_NULL: return formula::errNoCode;
- case EXC_ERR_DIV0: return formula::errDivisionByZero;
- case EXC_ERR_VALUE: return formula::errNoValue;
- case EXC_ERR_REF: return formula::errNoRef;
- case EXC_ERR_NAME: return formula::errNoName;
- case EXC_ERR_NUM: return formula::errIllegalFPOperation;
- case EXC_ERR_NA: return formula::NOTAVAILABLE;
+ case EXC_ERR_NULL: return FormulaError::NoCode;
+ case EXC_ERR_DIV0: return FormulaError::DivisionByZero;
+ case EXC_ERR_VALUE: return FormulaError::NoValue;
+ case EXC_ERR_REF: return FormulaError::NoRef;
+ case EXC_ERR_NAME: return FormulaError::NoName;
+ case EXC_ERR_NUM: return FormulaError::IllegalFPOperation;
+ case EXC_ERR_NA: return FormulaError::NotAvailable;
default: OSL_FAIL( "XclTools::GetScErrorCode - unknown error code" );
}
- return formula::NOTAVAILABLE;
+ return FormulaError::NotAvailable;
}
double XclTools::ErrorToDouble( sal_uInt8 nXclError )
{
- return formula::CreateDoubleError(GetScErrorCode( nXclError ));
+ return CreateDoubleError(GetScErrorCode( nXclError ));
}
XclBoolError XclTools::ErrorToEnum( double& rfDblValue, bool bErrOrBool, sal_uInt8 nValue )
diff --git a/sc/source/filter/inc/scflt.hxx b/sc/source/filter/inc/scflt.hxx
index 164fc56689c5..b315bfc32adb 100644
--- a/sc/source/filter/inc/scflt.hxx
+++ b/sc/source/filter/inc/scflt.hxx
@@ -602,7 +602,7 @@ public:
class Sc10FontCollection : public ScCollection
{
protected:
- sal_uLong nError;
+ sal_uLong nError;
public:
Sc10FontCollection( SvStream& rStream );
sal_uLong GetError() { return nError; }
@@ -761,7 +761,7 @@ class Sc10Import
Sc10NameCollection* pNameCollection;
Sc10PatternCollection* pPatternCollection;
Sc10DataBaseCollection* pDataBaseCollection;
- sal_uLong nError;
+ sal_uLong nError;
SCTAB nShowTab;
ScViewOptions aSc30ViewOpt;
ScfStreamProgressBar* pPrgrsBar;
@@ -770,7 +770,7 @@ public:
Sc10Import( SvStream& rStr, ScDocument* pDocument );
~Sc10Import();
- sal_uLong Import();
+ sal_uLong Import();
void LoadFileHeader();
void LoadFileInfo();
void LoadEditStateInfo();
diff --git a/sc/source/filter/inc/xihelper.hxx b/sc/source/filter/inc/xihelper.hxx
index 0cd1583613a3..6677eeb4b718 100644
--- a/sc/source/filter/inc/xihelper.hxx
+++ b/sc/source/filter/inc/xihelper.hxx
@@ -321,7 +321,7 @@ public:
/** Returns the cached Calc error code, if this value has Error type, else 0. */
inline sal_uInt8 GetXclError() const { return (mnType == EXC_CACHEDVAL_ERROR) ? mnBoolErr : EXC_ERR_NA; }
/** Returns the cached Calc error code, if this value has Error type, else 0. */
- sal_uInt16 GetScError() const;
+ FormulaError GetScError() const;
protected:
typedef ::std::unique_ptr< const ScTokenArray > ScTokenArrayPtr;
diff --git a/sc/source/filter/inc/xltools.hxx b/sc/source/filter/inc/xltools.hxx
index 89d8531bf116..7ca6e2927f34 100644
--- a/sc/source/filter/inc/xltools.hxx
+++ b/sc/source/filter/inc/xltools.hxx
@@ -24,6 +24,7 @@
#include "ftools.hxx"
class SfxObjectShell;
+enum class FormulaError : sal_uInt16;
// BIFF versions ==============================================================
@@ -115,9 +116,9 @@ public:
static sal_uInt8 GetXclOrientFromRot( sal_uInt16 nXclRot );
/** Converts a Calc error code to an Excel error code. */
- static sal_uInt8 GetXclErrorCode( sal_uInt16 nScError );
+ static sal_uInt8 GetXclErrorCode( FormulaError nScError );
/** Converts an Excel error code to a Calc error code. */
- static sal_uInt16 GetScErrorCode( sal_uInt8 nXclError );
+ static FormulaError GetScErrorCode( sal_uInt8 nXclError );
/** Converts the passed BIFF error to a double containing the respective Calc error code. */
static double ErrorToDouble( sal_uInt8 nXclError );
diff --git a/sc/source/filter/oox/defnamesbuffer.cxx b/sc/source/filter/oox/defnamesbuffer.cxx
index fe41ed7d47ac..a3be8b775c33 100644
--- a/sc/source/filter/oox/defnamesbuffer.cxx
+++ b/sc/source/filter/oox/defnamesbuffer.cxx
@@ -331,7 +331,7 @@ std::unique_ptr<ScTokenArray> DefinedName::getScTokens()
// Compile the tokens into RPN once to populate information into tokens
// where necessary, e.g. for TableRef inner reference. RPN can be discarded
// after, a resulting error must be reset.
- sal_uInt16 nErr = pArray->GetCodeError();
+ FormulaError nErr = pArray->GetCodeError();
aCompiler.CompileTokenArray();
pArray->DelRPN();
pArray->SetCodeError(nErr);
diff --git a/sc/source/filter/starcalc/scflt.cxx b/sc/source/filter/starcalc/scflt.cxx
index 77e54435ff9c..79ffdb99ac59 100644
--- a/sc/source/filter/starcalc/scflt.cxx
+++ b/sc/source/filter/starcalc/scflt.cxx
@@ -21,6 +21,7 @@
#include <editeng/eeitem.hxx>
#include <com/sun/star/style/NumberingType.hpp>
+#include <formula/errorcodes.hxx>
#include <svx/algitem.hxx>
#include <editeng/boxitem.hxx>
#include <editeng/brushitem.hxx>
@@ -443,7 +444,7 @@ Sc10NameData::Sc10NameData(SvStream& rStream)
Sc10NameCollection::Sc10NameCollection(SvStream& rStream) :
ScCollection (4, 4),
- nError (0)
+ nError (0)
{
sal_uInt16 ID;
rStream.ReadUInt16( ID );
diff --git a/sc/source/filter/xml/xmlexprt.cxx b/sc/source/filter/xml/xmlexprt.cxx
index 235d7873ffb3..437df5d4ecda 100644
--- a/sc/source/filter/xml/xmlexprt.cxx
+++ b/sc/source/filter/xml/xmlexprt.cxx
@@ -97,6 +97,7 @@
#include <editeng/xmlcnitm.hxx>
#include <editeng/flditem.hxx>
#include <editeng/eeitem.hxx>
+#include <formula/errorcodes.hxx>
#include <xmloff/xmlerror.hxx>
#include <xmloff/XMLEventExport.hxx>
@@ -3144,7 +3145,7 @@ void ScXMLExport::WriteCell(ScMyCell& aCell, sal_Int32 nEqualCellCount)
AddAttribute(sAttrFormula, GetNamespaceMap().GetQNameByKey(nNamespacePrefix, aFormula.copy(1, aFormula.getLength()-2), false));
}
}
- if (pFormulaCell->GetErrCode())
+ if (pFormulaCell->GetErrCode() != FormulaError::NONE)
{
AddAttribute(sAttrValueType, XML_STRING);
AddAttribute(sAttrStringValue, aCell.maBaseCell.getString(pDoc));
diff --git a/sc/source/filter/xml/xmlimprt.cxx b/sc/source/filter/xml/xmlimprt.cxx
index ac0f89f73c19..55c49b33a513 100644
--- a/sc/source/filter/xml/xmlimprt.cxx
+++ b/sc/source/filter/xml/xmlimprt.cxx
@@ -43,6 +43,7 @@
#include <svl/zformat.hxx>
#include <svl/languageoptions.hxx>
#include <editeng/editstat.hxx>
+#include <formula/errorcodes.hxx>
#include "appluno.hxx"
#include "xmlimprt.hxx"
@@ -3412,7 +3413,7 @@ bool ScXMLImport::IsFormulaErrorConstant( const OUString& rStr ) const
if (!mpComp)
return false;
- return mpComp->GetErrorConstant(rStr) > 0;
+ return mpComp->GetErrorConstant(rStr) > FormulaError::NONE;
}
ScEditEngineDefaulter* ScXMLImport::GetEditEngine()
diff --git a/sc/source/ui/app/inputhdl.cxx b/sc/source/ui/app/inputhdl.cxx
index 26b14aca19d1..964896d714a5 100644
--- a/sc/source/ui/app/inputhdl.cxx
+++ b/sc/source/ui/app/inputhdl.cxx
@@ -23,6 +23,7 @@
#include <sfx2/app.hxx>
#include <editeng/acorrcfg.hxx>
+#include <formula/errorcodes.hxx>
#include <svx/algitem.hxx>
#include <editeng/adjustitem.hxx>
#include <editeng/brushitem.hxx>
@@ -1434,8 +1435,8 @@ static OUString lcl_Calculate( const OUString& rFormula, ScDocument* pDoc, const
bColRowName = false;
}
- sal_uInt16 nErrCode = pCalc->GetErrCode();
- if ( nErrCode != 0 )
+ FormulaError nErrCode = pCalc->GetErrCode();
+ if ( nErrCode != FormulaError::NONE )
return ScGlobal::GetErrorString(nErrCode);
SvNumberFormatter& aFormatter = *(pDoc->GetFormatTable());
diff --git a/sc/source/ui/app/scmod.cxx b/sc/source/ui/app/scmod.cxx
index 4a3395356084..8b0e101f45fb 100644
--- a/sc/source/ui/app/scmod.cxx
+++ b/sc/source/ui/app/scmod.cxx
@@ -1265,7 +1265,7 @@ void ScModule::ModifyOptions( const SfxItemSet& rOptSet )
// Re-compile cells with name error, and recalc if at least one cell
// has been re-compiled. In the future we may want to find a way to
// recalc only those that are affected.
- if (pDoc->CompileErrorCells(formula::errNoName))
+ if (pDoc->CompileErrorCells(FormulaError::NoName))
bCalcAll = true;
}
diff --git a/sc/source/ui/app/transobj.cxx b/sc/source/ui/app/transobj.cxx
index 4a061f46d627..50f50536b33e 100644
--- a/sc/source/ui/app/transobj.cxx
+++ b/sc/source/ui/app/transobj.cxx
@@ -53,6 +53,7 @@
#include <editeng/paperinf.hxx>
#include <editeng/sizeitem.hxx>
+#include <formula/errorcodes.hxx>
#include <svx/algitem.hxx>
#include <svl/intitem.hxx>
#include <svl/zforlist.hxx>
@@ -816,9 +817,9 @@ void ScTransferObj::StripRefs( ScDocument* pDoc,
SCCOL nCol = aIter.GetPos().Col() - nSubX;
SCROW nRow = aIter.GetPos().Row() - nSubY;
- sal_uInt16 nErrCode = pFCell->GetErrCode();
+ FormulaError nErrCode = pFCell->GetErrCode();
ScAddress aPos(nCol, nRow, nDestTab);
- if (nErrCode)
+ if (nErrCode != FormulaError::NONE)
{
if ( static_cast<const SvxHorJustifyItem*>(pDestDoc->GetAttr(
nCol,nRow,nDestTab, ATTR_HOR_JUSTIFY))->GetValue() ==
diff --git a/sc/source/ui/condformat/condformatdlgentry.cxx b/sc/source/ui/condformat/condformatdlgentry.cxx
index df5db9acefbf..0343b040253c 100644
--- a/sc/source/ui/condformat/condformatdlgentry.cxx
+++ b/sc/source/ui/condformat/condformatdlgentry.cxx
@@ -24,6 +24,7 @@
#include <vcl/msgbox.hxx>
#include <vcl/settings.hxx>
#include <formula/token.hxx>
+#include <formula/errorcodes.hxx>
#include "tokenarray.hxx"
#include "stlpool.hxx"
#include "tabvwsh.hxx"
@@ -311,7 +312,7 @@ IMPL_LINK_TYPED(ScConditionFrmtEntry, OnEdChanged, Edit&, rEdit, void)
std::unique_ptr<ScTokenArray> ta(aComp.CompileString(aFormula));
// Error, warn the user
- if( ta->GetCodeError() || ( ta->GetLen() == 0 ) )
+ if( ta->GetCodeError() != FormulaError::NONE || ( ta->GetLen() == 0 ) )
{
rEdit.SetControlBackground(COL_LIGHTRED);
maFtVal->SetText(ScGlobal::GetRscString(STR_VALID_DEFERROR));
diff --git a/sc/source/ui/docshell/docsh.cxx b/sc/source/ui/docshell/docsh.cxx
index 823cf06f26c2..20d21be97639 100644
--- a/sc/source/ui/docshell/docsh.cxx
+++ b/sc/source/ui/docshell/docsh.cxx
@@ -24,6 +24,7 @@
#include "scitems.hxx"
#include <editeng/justifyitem.hxx>
#include <comphelper/classids.hxx>
+#include <formula/errorcodes.hxx>
#include <vcl/msgbox.hxx>
#include <vcl/virdev.hxx>
#include <vcl/waitobj.hxx>
@@ -1993,13 +1994,13 @@ void ScDocShell::AsciiSave( SvStream& rStream, const ScImportOptions& rAsciiOpt
break;
case CELLTYPE_FORMULA :
{
- sal_uInt16 nErrCode;
+ FormulaError nErrCode;
if ( bShowFormulas )
{
pCell->mpFormula->GetFormula(aString);
bString = true;
}
- else if ((nErrCode = pCell->mpFormula->GetErrCode()) != 0)
+ else if ((nErrCode = pCell->mpFormula->GetErrCode()) != FormulaError::NONE)
{
aString = ScGlobal::GetErrorString( nErrCode );
bString = true;
diff --git a/sc/source/ui/docshell/externalrefmgr.cxx b/sc/source/ui/docshell/externalrefmgr.cxx
index b34cb9d5ad52..8c496a0d36cb 100644
--- a/sc/source/ui/docshell/externalrefmgr.cxx
+++ b/sc/source/ui/docshell/externalrefmgr.cxx
@@ -140,10 +140,10 @@ struct UpdateFormulaCell : public unary_function<ScFormulaCell*, void>
if (!pCode->HasExternalRef())
return;
- if (pCode->GetCodeError())
+ if (pCode->GetCodeError() != FormulaError::NONE)
{
// Clear the error code, or a cell with error won't get re-compiled.
- pCode->SetCodeError(0);
+ pCode->SetCodeError(FormulaError::NONE);
pCell->SetCompile(true);
pCell->CompileTokenArray();
}
@@ -883,9 +883,9 @@ void ScExternalRefCache::setCellRangeData(sal_uInt16 nFileId, const ScRange& rRa
SAL_WARN("sc.ui","ScExternalRefCache::setCellRangeData - not a one element matrix");
else
{
- sal_uInt16 nErr = GetDoubleErrorValue( pMat->GetDouble(0,0));
- SAL_WARN("sc.ui","ScExternalRefCache::setCellRangeData - matrix error value is " << nErr <<
- (nErr == errMatrixSize ? ", ok" : ", not ok"));
+ FormulaError nErr = GetDoubleErrorValue( pMat->GetDouble(0,0));
+ SAL_WARN("sc.ui","ScExternalRefCache::setCellRangeData - matrix error value is " << (int)nErr <<
+ (nErr == FormulaError::MatrixSize ? ", ok" : ", not ok"));
}
}
}
@@ -1547,8 +1547,8 @@ static FormulaToken* convertToToken( ScDocument* pHostDoc, ScDocument* pSrcDoc,
case CELLTYPE_FORMULA:
{
ScFormulaCell* pFCell = rCell.mpFormula;
- sal_uInt16 nError = pFCell->GetErrCode();
- if (nError)
+ FormulaError nError = pFCell->GetErrCode();
+ if (nError != FormulaError::NONE)
return new FormulaErrorToken( nError);
else if (pFCell->IsValue())
{
@@ -1933,7 +1933,7 @@ ScExternalRefCache::TokenRef ScExternalRefManager::getSingleRefToken(
if (!getSrcDocTable( *pSrcDoc, rTabName, nTab, nFileId))
{
// specified table name doesn't exist in the source document.
- ScExternalRefCache::TokenRef pToken(new FormulaErrorToken(errNoRef));
+ ScExternalRefCache::TokenRef pToken(new FormulaErrorToken(FormulaError::NoRef));
return pToken;
}
@@ -1964,7 +1964,7 @@ ScExternalRefCache::TokenRef ScExternalRefManager::getSingleRefToken(
if (!pSrcDoc)
{
// Source document not reachable. Throw a reference error.
- pToken.reset(new FormulaErrorToken(errNoRef));
+ pToken.reset(new FormulaErrorToken(FormulaError::NoRef));
return pToken;
}
@@ -1972,7 +1972,7 @@ ScExternalRefCache::TokenRef ScExternalRefManager::getSingleRefToken(
if (!getSrcDocTable( *pSrcDoc, rTabName, nTab, nFileId))
{
// specified table name doesn't exist in the source document.
- pToken.reset(new FormulaErrorToken(errNoRef));
+ pToken.reset(new FormulaErrorToken(FormulaError::NoRef));
return pToken;
}
@@ -2037,7 +2037,7 @@ ScExternalRefCache::TokenArrayRef ScExternalRefManager::getDoubleRefTokens(
{
// Source document is not reachable. Throw a reference error.
pArray.reset(new ScTokenArray);
- pArray->AddToken(FormulaErrorToken(errNoRef));
+ pArray->AddToken(FormulaErrorToken(FormulaError::NoRef));
return pArray;
}
@@ -2263,7 +2263,7 @@ ScExternalRefCache::TokenRef ScExternalRefManager::getSingleRefTokenFromSrcDoc(
if (!pToken.get())
{
// Generate an error for unresolvable cells.
- pToken.reset( new FormulaErrorToken( errNoValue));
+ pToken.reset( new FormulaErrorToken( FormulaError::NoValue));
}
// Get number format information.
@@ -2285,7 +2285,7 @@ ScExternalRefCache::TokenArrayRef ScExternalRefManager::getDoubleRefTokensFromSr
{
// specified table name doesn't exist in the source document.
pArray.reset(new ScTokenArray);
- pArray->AddToken(FormulaErrorToken(errNoRef));
+ pArray->AddToken(FormulaErrorToken(FormulaError::NoRef));
return pArray;
}
@@ -2867,12 +2867,12 @@ public:
case sc::FormulaResultValue::Error:
case sc::FormulaResultValue::Invalid:
default:
- pTok.reset(new FormulaErrorToken(errNoValue));
+ pTok.reset(new FormulaErrorToken(FormulaError::NoValue));
}
}
break;
default:
- pTok.reset(new FormulaErrorToken(errNoValue));
+ pTok.reset(new FormulaErrorToken(FormulaError::NoValue));
}
if (pTok)
diff --git a/sc/source/ui/formdlg/formula.cxx b/sc/source/ui/formdlg/formula.cxx
index bf50ba5e2e7a..eb5ddf4acef6 100644
--- a/sc/source/ui/formdlg/formula.cxx
+++ b/sc/source/ui/formdlg/formula.cxx
@@ -31,6 +31,7 @@
#include <tools/urlobj.hxx>
#include <formula/formulahelper.hxx>
#include <formula/IFunctionDescription.hxx>
+#include <formula/errorcodes.hxx>
#include "tokenuno.hxx"
#include "formula.hxx"
@@ -331,8 +332,8 @@ bool ScFormulaDlg::calculateValue( const OUString& rStrExp, OUString& rStrResult
bColRowName = false;
}
- sal_uInt16 nErrCode = pFCell->GetErrCode();
- if ( nErrCode == 0 || pFCell->IsMatrix() )
+ FormulaError nErrCode = pFCell->GetErrCode();
+ if ( nErrCode == FormulaError::NONE || pFCell->IsMatrix() )
{
SvNumberFormatter& aFormatter = *(m_pDoc->GetFormatTable());
Color* pColor;
diff --git a/sc/source/ui/inc/tabvwsh.hxx b/sc/source/ui/inc/tabvwsh.hxx
index c82a0865ab35..dd05b4c8110d 100644
--- a/sc/source/ui/inc/tabvwsh.hxx
+++ b/sc/source/ui/inc/tabvwsh.hxx
@@ -20,6 +20,7 @@
#ifndef INCLUDED_SC_SOURCE_UI_INC_TABVWSH_HXX
#define INCLUDED_SC_SOURCE_UI_INC_TABVWSH_HXX
+#include <formula/errorcodes.hxx>
#include <svx/fmshell.hxx>
#include <svtools/htmlcfg.hxx>
#include <sfx2/viewsh.hxx>
@@ -359,7 +360,7 @@ public:
void ExecuteCellFormatDlg( SfxRequest& rReq, const OString &rTabPage);
- bool GetFunction( OUString& rFuncStr, sal_uInt16 nErrCode );
+ bool GetFunction( OUString& rFuncStr, FormulaError nErrCode );
void StartSimpleRefDialog( const OUString& rTitle, const OUString& rInitVal,
bool bCloseOnButtonUp, bool bSingleCell, bool bMultiSelection );
diff --git a/sc/source/ui/namedlg/namedefdlg.cxx b/sc/source/ui/namedlg/namedefdlg.cxx
index c46f17e99817..7892d4977419 100644
--- a/sc/source/ui/namedlg/namedefdlg.cxx
+++ b/sc/source/ui/namedlg/namedefdlg.cxx
@@ -11,7 +11,7 @@
#include <vcl/msgbox.hxx>
#include <vcl/settings.hxx>
-
+#include <formula/errorcodes.hxx>
#include <sfx2/app.hxx>
#include "document.hxx"
@@ -122,7 +122,7 @@ bool ScNameDefDlg::IsFormulaValid()
ScCompiler aComp( mpDoc, maCursorPos);
aComp.SetGrammar( mpDoc->GetGrammar() );
ScTokenArray* pCode = aComp.CompileString(m_pEdRange->GetText());
- if (pCode->GetCodeError())
+ if (pCode->GetCodeError() != FormulaError::NONE)
{
//TODO: info message
delete pCode;
@@ -233,7 +233,7 @@ void ScNameDefDlg::AddPushed()
pNewEntry->AddType(nType);
// aExpression valid?
- if ( 0 == pNewEntry->GetErrCode() )
+ if ( FormulaError::NONE == pNewEntry->GetErrCode() )
{
if ( !pRangeName->insert( pNewEntry, false /*bReuseFreeIndex*/ ) )
pNewEntry = nullptr;
diff --git a/sc/source/ui/namedlg/namedlg.cxx b/sc/source/ui/namedlg/namedlg.cxx
index bc5539126b8d..23f207aa7aeb 100644
--- a/sc/source/ui/namedlg/namedlg.cxx
+++ b/sc/source/ui/namedlg/namedlg.cxx
@@ -34,7 +34,7 @@
#include <vcl/msgbox.hxx>
#include <vcl/settings.hxx>
-
+#include <formula/errorcodes.hxx>
#include <o3tl/make_unique.hxx>
#include <map>
@@ -299,7 +299,7 @@ bool ScNameDlg::IsFormulaValid()
ScCompiler aComp( mpDoc, maCursorPos);
aComp.SetGrammar( mpDoc->GetGrammar() );
ScTokenArray* pCode = aComp.CompileString(m_pEdAssign->GetText());
- if (pCode->GetCodeError())
+ if (pCode->GetCodeError() != FormulaError::NONE)
{
m_pFtInfo->SetControlBackground(GetSettings().GetStyleSettings().GetHighlightColor());
delete pCode;
diff --git a/sc/source/ui/unoobj/cellsuno.cxx b/sc/source/ui/unoobj/cellsuno.cxx
index 2085ff4a7d61..33bc42ef80e2 100644
--- a/sc/source/ui/unoobj/cellsuno.cxx
+++ b/sc/source/ui/unoobj/cellsuno.cxx
@@ -1147,7 +1147,7 @@ static bool lcl_PutDataArray( ScDocShell& rDocShell, const ScRange& rRange,
case uno::TypeClass_VOID:
{
// void = "no value"
- rDoc.SetError( nDocCol, nDocRow, nTab, formula::NOTAVAILABLE );
+ rDoc.SetError( nDocCol, nDocRow, nTab, FormulaError::NotAvailable );
}
break;
@@ -3645,7 +3645,7 @@ uno::Reference<sheet::XSheetCellRanges> SAL_CALL ScCellRangesBase::queryFormulaC
{
ScFormulaCell* pFCell = aIter.getFormulaCell();
bool bAdd = false;
- if (pFCell->GetErrCode())
+ if (pFCell->GetErrCode() != FormulaError::NONE)
{
if ( nResultFlags & sheet::FormulaResult::ERROR )
bAdd = true;
@@ -6548,12 +6548,12 @@ sal_Int32 SAL_CALL ScCellObj::getError() throw(uno::RuntimeException, std::excep
return 0;
}
- sal_uInt16 nError = 0;
+ FormulaError nError = FormulaError::NONE;
ScRefCellValue aCell(pDocSh->GetDocument(), aCellPos);
if (aCell.meType == CELLTYPE_FORMULA)
nError = aCell.mpFormula->GetErrCode();
- return nError;
+ return (sal_Int32)nError;
}
// XFormulaTokens
diff --git a/sc/source/ui/unoobj/chart2uno.cxx b/sc/source/ui/unoobj/chart2uno.cxx
index 5dafe5654af8..2fce34a9c611 100644
--- a/sc/source/ui/unoobj/chart2uno.cxx
+++ b/sc/source/ui/unoobj/chart2uno.cxx
@@ -2593,8 +2593,8 @@ void ScChart2DataSequence::BuildDataCache()
case CELLTYPE_FORMULA:
{
ScFormulaCell* pFCell = aCell.mpFormula;
- sal_uInt16 nErr = pFCell->GetErrCode();
- if (nErr)
+ FormulaError nErr = pFCell->GetErrCode();
+ if (nErr != FormulaError::NONE)
break;
if (pFCell->IsValue())
diff --git a/sc/source/ui/unoobj/funcuno.cxx b/sc/source/ui/unoobj/funcuno.cxx
index 445b73d3cba1..afbe7098dfcb 100644
--- a/sc/source/ui/unoobj/funcuno.cxx
+++ b/sc/source/ui/unoobj/funcuno.cxx
@@ -616,8 +616,8 @@ uno::Any SAL_CALL ScFunctionAccess::callFunction( const OUString& aName,
// if there is no matrix result
const ScMatrix* pMat = (mbArray && pFormula) ? pFormula->GetMatrix() : nullptr;
- sal_uInt16 nErrCode = pFormula ? pFormula->GetErrCode() : formula::errIllegalArgument;
- if ( nErrCode == 0 )
+ FormulaError nErrCode = pFormula ? pFormula->GetErrCode() : FormulaError::IllegalArgument;
+ if ( nErrCode == FormulaError::NONE )
{
if ( pMat )
{
@@ -636,7 +636,7 @@ uno::Any SAL_CALL ScFunctionAccess::callFunction( const OUString& aName,
aRet <<= aStrVal;
}
}
- else if ( nErrCode == formula::NOTAVAILABLE )
+ else if ( nErrCode == FormulaError::NotAvailable )
{
// #N/A: leave result empty, no exception
}
diff --git a/sc/source/ui/view/cellsh.cxx b/sc/source/ui/view/cellsh.cxx
index cc1ff7533114..8907fc3a83e6 100644
--- a/sc/source/ui/view/cellsh.cxx
+++ b/sc/source/ui/view/cellsh.cxx
@@ -777,7 +777,7 @@ void ScCellShell::GetState(SfxItemSet &rSet)
rSet.Put( SfxStringItem( nWhich, OUString("...") ) );
else
{
- sal_uInt16 nErrCode = 0;
+ FormulaError nErrCode = FormulaError::NONE;
ScFormulaCell* pCell = pDoc->GetFormulaCell(ScAddress(nPosX, nPosY, nTab));
if (pCell)
{
@@ -803,7 +803,7 @@ void ScCellShell::GetState(SfxItemSet &rSet)
case SID_STATUS_SUM:
{
OUString aFuncStr;
- if ( pTabViewShell->GetFunction( aFuncStr, 0 ) )
+ if ( pTabViewShell->GetFunction( aFuncStr, FormulaError::NONE ) )
rSet.Put( SfxStringItem( nWhich, aFuncStr ) );
}
break;
diff --git a/sc/source/ui/view/output2.cxx b/sc/source/ui/view/output2.cxx
index 07a3a44546fc..c981c631c41a 100644
--- a/sc/source/ui/view/output2.cxx
+++ b/sc/source/ui/view/output2.cxx
@@ -597,7 +597,7 @@ void ScDrawStringsVars::SetTextToWidthOrHash( ScRefCellValue& rCell, long nWidth
if (eType == CELLTYPE_FORMULA)
{
ScFormulaCell* pFCell = rCell.mpFormula;
- if (pFCell->GetErrCode() != 0 || pOutput->mbShowFormulas)
+ if (pFCell->GetErrCode() != FormulaError::NONE || pOutput->mbShowFormulas)
{
SetHashText(); // If the error string doesn't fit, always use "###". Also for "display formulas" (#i116691#)
return;
diff --git a/sc/source/ui/view/tabvwsha.cxx b/sc/source/ui/view/tabvwsha.cxx
index ef0d1ced1843..149b31098760 100644
--- a/sc/source/ui/view/tabvwsha.cxx
+++ b/sc/source/ui/view/tabvwsha.cxx
@@ -63,7 +63,7 @@
using namespace com::sun::star;
-bool ScTabViewShell::GetFunction( OUString& rFuncStr, sal_uInt16 nErrCode )
+bool ScTabViewShell::GetFunction( OUString& rFuncStr, FormulaError nErrCode )
{
OUString aStr;
@@ -79,9 +79,9 @@ bool ScTabViewShell::GetFunction( OUString& rFuncStr, sal_uInt16 nErrCode )
ScSubTotalFunc eFunc = (ScSubTotalFunc)nFunc;
if (bIgnoreError && (eFunc == SUBTOTAL_FUNC_CNT || eFunc == SUBTOTAL_FUNC_CNT2))
- nErrCode = 0;
+ nErrCode = FormulaError::NONE;
- if (nErrCode)
+ if (nErrCode != FormulaError::NONE)
{
rFuncStr = ScGlobal::GetLongErrorString(nErrCode);
return true;
diff --git a/sc/source/ui/view/viewfunc.cxx b/sc/source/ui/view/viewfunc.cxx
index 18f4ee1a836f..e43ef8aa896f 100644
--- a/sc/source/ui/view/viewfunc.cxx
+++ b/sc/source/ui/view/viewfunc.cxx
@@ -416,7 +416,7 @@ void ScViewFunc::EnterData( SCCOL nCol, SCROW nRow, SCTAB nTab,
{ // try to parse with first parser-correction
pArr = aComp.CompileString( aComp.GetCorrectedFormula() );
}
- if ( !pArr->GetCodeError() )
+ if ( pArr->GetCodeError() == FormulaError::NONE )
{
bAddEqual = true;
aComp.CompileTokenArray();
@@ -466,8 +466,8 @@ void ScViewFunc::EnterData( SCCOL nCol, SCROW nRow, SCTAB nTab,
// cells and the error be set explicitly, so that
// via FormulaCell copy-ctor and Interpreter it will be, when possible,
// ironed out again, too intelligent.. e.g.: =1))
- sal_uInt16 nError = pArr->GetCodeError();
- if ( !nError )
+ FormulaError nError = pArr->GetCodeError();
+ if ( nError == FormulaError::NONE )
{
// update list of recent functions with all functions that
// are not within parentheses
@@ -510,7 +510,7 @@ void ScViewFunc::EnterData( SCCOL nCol, SCROW nRow, SCTAB nTab,
sal_uLong nIndex = (sal_uLong) static_cast<const SfxUInt32Item*>( pDoc->GetAttr(
nCol, nRow, i, ATTR_VALUE_FORMAT ))->GetValue();
if ( pFormatter->GetType( nIndex ) == css::util::NumberFormat::TEXT ||
- ( ( rString[0] == '+' || rString[0] == '-' ) && nError && rString == aFormula ) )
+ ( ( rString[0] == '+' || rString[0] == '-' ) && nError != FormulaError::NONE && rString == aFormula ) )
{
if ( pData )
{
@@ -523,7 +523,7 @@ void ScViewFunc::EnterData( SCCOL nCol, SCROW nRow, SCTAB nTab,
else
{
ScFormulaCell* pCell = new ScFormulaCell( aCell, *pDoc, aPos );
- if ( nError )
+ if ( nError != FormulaError::NONE )
{
pCell->GetCode()->DelRPN();
pCell->SetErrCode( nError );
@@ -2655,7 +2655,7 @@ bool ScViewFunc::InsertName( const OUString& rName, const OUString& rSymbol,
nType |= ScRangeData::Type::Criteria;
pNewEntry->AddType(nType);
- if ( !pNewEntry->GetErrCode() ) // text valid?
+ if ( pNewEntry->GetErrCode() == FormulaError::NONE ) // text valid?
{
ScDocShellModificator aModificator( *pDocSh );