2014-04-30 07:32:29 +02:00
|
|
|
/***************************************************************************************************
|
|
|
|
**
|
2015-02-27 11:21:09 +01:00
|
|
|
** Copyright (C) 2013 Ingo Berg
|
2014-04-30 07:32:29 +02:00
|
|
|
**
|
|
|
|
** Permission is hereby granted, free of charge, to any person obtaining a copy of this
|
|
|
|
** software and associated documentation files (the "Software"), to deal in the Software
|
|
|
|
** without restriction, including without limitation the rights to use, copy, modify,
|
|
|
|
** merge, publish, distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
** permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
|
|
**
|
|
|
|
** The above copyright notice and this permission notice shall be included in all copies or
|
|
|
|
** substantial portions of the Software.
|
|
|
|
**
|
|
|
|
** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT
|
|
|
|
** NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
** NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
|
|
|
** DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
** OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
**
|
|
|
|
******************************************************************************************************/
|
|
|
|
|
|
|
|
#ifndef QMUPARSERERROR_H
|
|
|
|
#define QMUPARSERERROR_H
|
|
|
|
|
2016-08-08 13:44:49 +02:00
|
|
|
#include <qcompilerdetection.h>
|
|
|
|
#include <QCoreApplication>
|
2014-05-06 11:45:21 +02:00
|
|
|
#include <QException>
|
2016-08-08 13:44:49 +02:00
|
|
|
#include <QMap>
|
|
|
|
#include <QString>
|
2014-06-03 14:15:17 +02:00
|
|
|
#include <QVector>
|
2016-08-08 13:44:49 +02:00
|
|
|
#include <QtGlobal>
|
|
|
|
#include <sstream>
|
2014-04-30 07:32:29 +02:00
|
|
|
|
2016-08-08 13:44:49 +02:00
|
|
|
#include "../qmuparser/qmuparser_global.h"
|
|
|
|
#include "qmuparser_global.h"
|
2014-04-30 07:32:29 +02:00
|
|
|
#include "qmuparserdef.h"
|
2014-12-04 18:28:47 +01:00
|
|
|
#include "qmutranslation.h"
|
2014-04-30 07:32:29 +02:00
|
|
|
|
|
|
|
/** @file
|
|
|
|
@brief This file defines the error class used by the parser.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace qmu
|
|
|
|
{
|
|
|
|
|
|
|
|
/** @brief Error codes. */
|
|
|
|
enum EErrorCodes
|
|
|
|
{
|
|
|
|
// Formula syntax errors
|
|
|
|
ecUNEXPECTED_OPERATOR = 0, ///< Unexpected binary operator found
|
|
|
|
ecUNASSIGNABLE_TOKEN = 1, ///< Token cant be identified.
|
|
|
|
ecUNEXPECTED_EOF = 2, ///< Unexpected end of formula. (Example: "2+sin(")
|
2017-01-03 10:08:29 +01:00
|
|
|
ecUNEXPECTED_ARG_SEP = 3, ///< An unexpected semicolon has been found. (Example: "1;23")
|
2014-04-30 07:32:29 +02:00
|
|
|
ecUNEXPECTED_ARG = 4, ///< An unexpected argument has been found
|
|
|
|
ecUNEXPECTED_VAL = 5, ///< An unexpected value token has been found
|
|
|
|
ecUNEXPECTED_VAR = 6, ///< An unexpected variable token has been found
|
|
|
|
ecUNEXPECTED_PARENS = 7, ///< Unexpected Parenthesis, opening or closing
|
|
|
|
ecUNEXPECTED_STR = 8, ///< A string has been found at an inapropriate position
|
|
|
|
ecSTRING_EXPECTED = 9, ///< A string function has been called with a different type of argument
|
|
|
|
ecVAL_EXPECTED = 10, ///< A numerical function has been called with a non value type of argument
|
|
|
|
ecMISSING_PARENS = 11, ///< Missing parens. (Example: "3*sin(3")
|
|
|
|
ecUNEXPECTED_FUN = 12, ///< Unexpected function found. (Example: "sin(8)cos(9)")
|
|
|
|
ecUNTERMINATED_STRING = 13, ///< unterminated string constant. (Example: "3*valueof("hello)")
|
|
|
|
ecTOO_MANY_PARAMS = 14, ///< Too many function parameters
|
2017-01-03 10:08:29 +01:00
|
|
|
ecTOO_FEW_PARAMS = 15, ///< Too few function parameters. (Example: "ite(1<2;2)")
|
2014-04-30 07:32:29 +02:00
|
|
|
ecOPRT_TYPE_CONFLICT = 16, ///< binary operators may only be applied to value items of the same type
|
|
|
|
ecSTR_RESULT = 17, ///< result is a string
|
|
|
|
|
|
|
|
// Invalid Parser input Parameters
|
|
|
|
ecINVALID_NAME = 18, ///< Invalid function, variable or constant name.
|
|
|
|
ecINVALID_BINOP_IDENT = 19, ///< Invalid binary operator identifier
|
|
|
|
ecINVALID_INFIX_IDENT = 20, ///< Invalid function, variable or constant name.
|
|
|
|
ecINVALID_POSTFIX_IDENT = 21, ///< Invalid function, variable or constant name.
|
|
|
|
|
|
|
|
ecBUILTIN_OVERLOAD = 22, ///< Trying to overload builtin operator
|
|
|
|
ecINVALID_FUN_PTR = 23, ///< Invalid callback function pointer
|
|
|
|
ecINVALID_VAR_PTR = 24, ///< Invalid variable pointer
|
|
|
|
ecEMPTY_EXPRESSION = 25, ///< The Expression is empty
|
|
|
|
ecNAME_CONFLICT = 26, ///< Name conflict
|
|
|
|
ecOPT_PRI = 27, ///< Invalid operator priority
|
|
|
|
//
|
|
|
|
ecDOMAIN_ERROR = 28, ///< catch division by zero, sqrt(-1), log(0) (currently unused)
|
|
|
|
ecDIV_BY_ZERO = 29, ///< Division by zero (currently unused)
|
|
|
|
ecGENERIC = 30, ///< Generic error
|
|
|
|
ecLOCALE = 31, ///< Conflict with current locale
|
|
|
|
|
|
|
|
ecUNEXPECTED_CONDITIONAL = 32,
|
|
|
|
ecMISSING_ELSE_CLAUSE = 33,
|
|
|
|
ecMISPLACED_COLON = 34,
|
|
|
|
|
|
|
|
// internal errors
|
|
|
|
ecINTERNAL_ERROR = 35, ///< Internal error of any kind.
|
|
|
|
|
|
|
|
// The last two are special entries
|
|
|
|
ecCOUNT, ///< This is no error code, It just stores just the total number of error codes
|
|
|
|
ecUNDEFINED = -1 ///< Undefined message, placeholder to detect unassigned error messages
|
|
|
|
};
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
/** @brief A class that handles the error messages.
|
|
|
|
*/
|
2015-10-18 09:50:33 +02:00
|
|
|
class QMUPARSERSHARED_EXPORT QmuParserErrorMsg
|
2014-04-30 07:32:29 +02:00
|
|
|
{
|
|
|
|
public:
|
2014-05-01 13:33:40 +02:00
|
|
|
typedef QmuParserErrorMsg self_type;
|
2014-04-30 07:32:29 +02:00
|
|
|
|
2014-05-01 13:33:40 +02:00
|
|
|
QmuParserErrorMsg();
|
|
|
|
~QmuParserErrorMsg();
|
2014-04-30 07:32:29 +02:00
|
|
|
|
2014-05-22 14:11:14 +02:00
|
|
|
static const QmuParserErrorMsg& Instance();
|
2014-06-02 09:43:27 +02:00
|
|
|
QString operator[] ( int a_iIdx ) const;
|
2014-04-30 07:32:29 +02:00
|
|
|
|
|
|
|
private:
|
2014-05-01 13:33:40 +02:00
|
|
|
Q_DISABLE_COPY(QmuParserErrorMsg)
|
2014-12-04 18:28:47 +01:00
|
|
|
QMap<int, QmuTranslation> m_vErrMsg; ///< A map with the predefined error messages
|
2014-05-01 13:33:40 +02:00
|
|
|
static const self_type m_Instance; ///< The instance pointer
|
2014-04-30 07:32:29 +02:00
|
|
|
};
|
|
|
|
|
2014-05-06 16:36:42 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
// cppcheck-suppress unusedFunction
|
2014-05-22 14:11:14 +02:00
|
|
|
inline const QmuParserErrorMsg& QmuParserErrorMsg::Instance()
|
2014-05-06 16:36:42 +02:00
|
|
|
{
|
|
|
|
return m_Instance;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2014-06-02 09:43:27 +02:00
|
|
|
inline QString QmuParserErrorMsg::operator[] ( int a_iIdx ) const
|
2014-05-06 16:36:42 +02:00
|
|
|
{
|
2018-01-21 15:00:53 +01:00
|
|
|
return m_vErrMsg.value(a_iIdx).translate(QString());
|
2014-05-06 16:36:42 +02:00
|
|
|
}
|
|
|
|
|
2014-04-30 07:32:29 +02:00
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
/** @brief Error class of the parser.
|
|
|
|
@author Ingo Berg
|
|
|
|
|
|
|
|
Part of the math parser package.
|
|
|
|
*/
|
2014-05-06 11:45:21 +02:00
|
|
|
class QMUPARSERSHARED_EXPORT QmuParserError : public QException
|
2014-04-30 07:32:29 +02:00
|
|
|
{
|
|
|
|
public:
|
2014-05-01 13:33:40 +02:00
|
|
|
QmuParserError();
|
|
|
|
explicit QmuParserError ( EErrorCodes a_iErrc );
|
|
|
|
explicit QmuParserError ( const QString &sMsg );
|
|
|
|
QmuParserError ( EErrorCodes a_iErrc, const QString &sTok, const QString &sFormula = QString(), int a_iPos = -1 );
|
|
|
|
QmuParserError ( EErrorCodes a_iErrc, int a_iPos, const QString &sTok );
|
2017-04-06 14:50:15 +02:00
|
|
|
QmuParserError ( const QString &szMsg, int iPos, const QString &sTok = QString() );
|
2014-05-01 13:33:40 +02:00
|
|
|
QmuParserError ( const QmuParserError &a_Obj );
|
|
|
|
QmuParserError& operator= ( const QmuParserError &a_Obj );
|
2018-06-26 14:53:48 +02:00
|
|
|
virtual ~QmuParserError() QMUP_NOEXCEPT_EXPR (true) override {}
|
2014-05-01 13:33:40 +02:00
|
|
|
|
2014-05-22 14:11:14 +02:00
|
|
|
void SetFormula ( const QString &a_strFormula );
|
|
|
|
const QString& GetExpr() const;
|
|
|
|
const QString& GetMsg() const;
|
|
|
|
int GetPos() const;
|
|
|
|
const QString& GetToken() const;
|
|
|
|
EErrorCodes GetCode() const;
|
2018-06-26 14:53:48 +02:00
|
|
|
Q_NORETURN virtual void raise() const override;
|
|
|
|
Q_REQUIRED_RESULT virtual QmuParserError *clone() const override;
|
2014-04-30 07:32:29 +02:00
|
|
|
private:
|
2014-05-05 09:29:14 +02:00
|
|
|
QString m_sMsg; ///< The message string
|
|
|
|
QString m_sExpr; ///< Formula string
|
|
|
|
QString m_sTok; ///< Token related with the error
|
|
|
|
int m_iPos; ///< Formula position related to the error
|
|
|
|
EErrorCodes m_iErrc; ///< Error code
|
2014-05-01 13:33:40 +02:00
|
|
|
const QmuParserErrorMsg &m_ErrMsg;
|
|
|
|
void Reset();
|
2014-04-30 07:32:29 +02:00
|
|
|
};
|
|
|
|
|
2014-05-06 16:36:42 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief Set the expression related to this error.
|
|
|
|
*/
|
2014-05-22 14:11:14 +02:00
|
|
|
inline void QmuParserError::SetFormula ( const QString &a_strFormula )
|
2014-05-06 16:36:42 +02:00
|
|
|
{
|
|
|
|
m_sExpr = a_strFormula;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief gets the expression related tp this error.
|
|
|
|
*/
|
2014-05-22 14:11:14 +02:00
|
|
|
inline const QString& QmuParserError::GetExpr() const
|
2014-05-06 16:36:42 +02:00
|
|
|
{
|
|
|
|
return m_sExpr;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief Returns the message string for this error.
|
|
|
|
*/
|
2014-05-22 14:11:14 +02:00
|
|
|
inline const QString& QmuParserError::GetMsg() const
|
2014-05-06 16:36:42 +02:00
|
|
|
{
|
|
|
|
return m_sMsg;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief Return the formula position related to the error.
|
|
|
|
*
|
|
|
|
* If the error is not related to a distinct position this will return -1
|
|
|
|
*/
|
2014-05-22 14:11:14 +02:00
|
|
|
inline int QmuParserError::GetPos() const
|
2014-05-06 16:36:42 +02:00
|
|
|
{
|
|
|
|
return m_iPos;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief Return string related with this token (if available).
|
|
|
|
*/
|
2014-05-22 14:11:14 +02:00
|
|
|
inline const QString& QmuParserError::GetToken() const
|
2014-05-06 16:36:42 +02:00
|
|
|
{
|
|
|
|
return m_sTok;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief Return the error code.
|
|
|
|
*/
|
2014-05-22 14:11:14 +02:00
|
|
|
inline EErrorCodes QmuParserError::GetCode() const
|
2014-05-06 16:36:42 +02:00
|
|
|
{
|
|
|
|
return m_iErrc;
|
|
|
|
}
|
|
|
|
|
2014-04-30 07:32:29 +02:00
|
|
|
} // namespace qmu
|
|
|
|
|
|
|
|
#endif
|