Which can happen for example for -nan(0x8000000000000) as a result of calculating with -inf. This was displayed as NaN instead of a proper error value, now #NUM! Example test case: =FORECAST.ETS.ADD(50, {-1,-2,-3,-4}, {10,20,30,40}) Change-Id: I1e1d95e1f188e0036b72be37dd20039c9a9a13f6
123 lines
5.2 KiB
C++
123 lines
5.2 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*
|
|
* This file is part of the LibreOffice project.
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*
|
|
* This file incorporates work covered by the following license notice:
|
|
*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed
|
|
* with this work for additional information regarding copyright
|
|
* ownership. The ASF licenses this file to you under the Apache
|
|
* License, Version 2.0 (the "License"); you may not use this file
|
|
* except in compliance with the License. You may obtain a copy of
|
|
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
|
|
*/
|
|
|
|
#ifndef INCLUDED_FORMULA_ERRORCODES_HXX
|
|
#define INCLUDED_FORMULA_ERRORCODES_HXX
|
|
|
|
#include <rtl/math.hxx>
|
|
#include <sal/mathconf.h>
|
|
#include <sal/types.h>
|
|
|
|
namespace formula {
|
|
|
|
const sal_uInt16 errIllegalChar = 501;
|
|
const sal_uInt16 errIllegalArgument = 502;
|
|
const sal_uInt16 errIllegalFPOperation = 503; // #NUM!
|
|
const sal_uInt16 errIllegalParameter = 504;
|
|
const sal_uInt16 errIllegalJump = 505;
|
|
const sal_uInt16 errSeparator = 506;
|
|
const sal_uInt16 errPair = 507;
|
|
const sal_uInt16 errPairExpected = 508;
|
|
const sal_uInt16 errOperatorExpected = 509;
|
|
const sal_uInt16 errVariableExpected = 510;
|
|
const sal_uInt16 errParameterExpected = 511;
|
|
const sal_uInt16 errCodeOverflow = 512;
|
|
const sal_uInt16 errStringOverflow = 513;
|
|
const sal_uInt16 errStackOverflow = 514;
|
|
const sal_uInt16 errUnknownState = 515;
|
|
const sal_uInt16 errUnknownVariable = 516;
|
|
const sal_uInt16 errUnknownOpCode = 517;
|
|
const sal_uInt16 errUnknownStackVariable = 518;
|
|
const sal_uInt16 errNoValue = 519; // #VALUE!
|
|
const sal_uInt16 errUnknownToken = 520;
|
|
const sal_uInt16 errNoCode = 521; // #NULL!
|
|
const sal_uInt16 errCircularReference = 522;
|
|
const sal_uInt16 errNoConvergence = 523;
|
|
const sal_uInt16 errNoRef = 524; // #REF!
|
|
const sal_uInt16 errNoName = 525; // #NAME?
|
|
const sal_uInt16 errDoubleRef = 526;
|
|
// Not displayed, temporary for TrackFormulas,
|
|
// Cell depends on another cell that has errCircularReference
|
|
const sal_uInt16 errTrackFromCircRef = 528;
|
|
// ScInterpreter internal: no numeric value but numeric queried. If this is
|
|
// set as mnStringNoValueError no error is generated but 0 returned.
|
|
const sal_uInt16 errCellNoValue = 529;
|
|
// Interpreter: needed AddIn not found
|
|
const sal_uInt16 errNoAddin = 530;
|
|
// Interpreter: needed Macro not found
|
|
const sal_uInt16 errNoMacro = 531;
|
|
// Interpreter: Division by zero
|
|
const sal_uInt16 errDivisionByZero = 532; // #DIV/0!
|
|
// Compiler: a non-simple (str,err,val) value was put in an array
|
|
const sal_uInt16 errNestedArray = 533;
|
|
// ScInterpreter internal: no numeric value but numeric queried. If this is
|
|
// temporarily (!) set as mnStringNoValueError, the error is generated and can
|
|
// be used to distinguish that condition from all other (inherited) errors. Do
|
|
// not use for anything else! Never push or inherit the error otherwise!
|
|
const sal_uInt16 errNotNumericString = 534;
|
|
// ScInterpreter internal: jump matrix already has a result at this position,
|
|
// do not overwrite in case of empty code path.
|
|
const sal_uInt16 errJumpMatHasResult = 535;
|
|
// ScInterpreter internal: (matrix) element is not a numeric value, i.e.
|
|
// string or empty, to be distinguished from the general errNoValue NAN and not
|
|
// to be used as result.
|
|
const sal_uInt16 errElementNaN = 536;
|
|
// ScInterpreter/ScFormulaCell internal: keep dirty, retry interpreting next
|
|
// round.
|
|
const sal_uInt16 errRetryCircular = 537;
|
|
// If matrix could not be allocated.
|
|
const sal_uInt16 errMatrixSize = 538;
|
|
|
|
// Interpreter: NA() not available condition, not a real error
|
|
const sal_uInt16 NOTAVAILABLE = 0x7fff;
|
|
|
|
|
|
/** Unconditionally construct a double value of NAN where the lower bits
|
|
represent an interpreter error code. */
|
|
inline double CreateDoubleError( sal_uInt16 nErr )
|
|
{
|
|
sal_math_Double smVal;
|
|
::rtl::math::setNan( &smVal.value );
|
|
smVal.nan_parts.fraction_lo = nErr;
|
|
return smVal.value;
|
|
}
|
|
|
|
/** Recreate the error code of a coded double error, if any. */
|
|
inline sal_uInt16 GetDoubleErrorValue( double fVal )
|
|
{
|
|
if ( ::rtl::math::isFinite( fVal ) )
|
|
return 0;
|
|
if ( ::rtl::math::isInf( fVal ) )
|
|
return errIllegalFPOperation; // normal INF
|
|
sal_uInt32 nErr = reinterpret_cast< sal_math_Double * >( &fVal)->nan_parts.fraction_lo;
|
|
if ( nErr & 0xffff0000 )
|
|
return errNoValue; // just a normal NAN
|
|
if (!nErr)
|
|
// Another NAN, e.g. -nan(0x8000000000000) from calculating with -inf
|
|
return errIllegalFPOperation;
|
|
// Any other error known to us as error code.
|
|
return (sal_uInt16)(nErr & 0x0000ffff);
|
|
}
|
|
|
|
} // namespace formula
|
|
|
|
#endif // INCLUDED_FORMULA_ERRORCODES_HXX
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|