mirror of
https://github.com/fish-shell/fish-shell
synced 2024-12-27 05:13:10 +00:00
142 lines
4.2 KiB
C
142 lines
4.2 KiB
C
|
/*
|
||
|
__________
|
||
|
_____ __ __\______ \_____ _______ ______ ____ _______
|
||
|
/ \ | | \| ___/\__ \ \_ __ \/ ___/_/ __ \\_ __ \
|
||
|
| Y Y \| | /| | / __ \_| | \/\___ \ \ ___/ | | \/
|
||
|
|__|_| /|____/ |____| (____ /|__| /____ > \___ >|__|
|
||
|
\/ \/ \/ \/
|
||
|
Copyright (C) 2004-2013 Ingo Berg
|
||
|
|
||
|
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 MU_PARSER_BYTECODE_H
|
||
|
#define MU_PARSER_BYTECODE_H
|
||
|
|
||
|
#include <cassert>
|
||
|
#include <string>
|
||
|
#include <stack>
|
||
|
#include <vector>
|
||
|
|
||
|
#include "muParserDef.h"
|
||
|
#include "muParserError.h"
|
||
|
#include "muParserToken.h"
|
||
|
|
||
|
/** \file
|
||
|
\brief Definition of the parser bytecode class.
|
||
|
*/
|
||
|
|
||
|
|
||
|
namespace mu
|
||
|
{
|
||
|
struct SToken
|
||
|
{
|
||
|
ECmdCode Cmd;
|
||
|
int StackPos;
|
||
|
|
||
|
union
|
||
|
{
|
||
|
struct //SValData
|
||
|
{
|
||
|
value_type *ptr;
|
||
|
value_type data;
|
||
|
value_type data2;
|
||
|
} Val;
|
||
|
|
||
|
struct //SFunData
|
||
|
{
|
||
|
// Note: generic_fun_type is merely a placeholder. The real type could be
|
||
|
// anything between gun_type1 and fun_type9. I can't use a void
|
||
|
// pointer due to constraints in the ANSI standard which allows
|
||
|
// data pointers and function pointers to differ in size.
|
||
|
generic_fun_type ptr;
|
||
|
int argc;
|
||
|
int idx;
|
||
|
} Fun;
|
||
|
|
||
|
struct //SOprtData
|
||
|
{
|
||
|
value_type *ptr;
|
||
|
int offset;
|
||
|
} Oprt;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
|
||
|
/** \brief Bytecode implementation of the Math Parser.
|
||
|
|
||
|
The bytecode contains the formula converted to revers polish notation stored in a continious
|
||
|
memory area. Associated with this data are operator codes, variable pointers, constant
|
||
|
values and function pointers. Those are necessary in order to calculate the result.
|
||
|
All those data items will be casted to the underlying datatype of the bytecode.
|
||
|
|
||
|
\author (C) 2004-2013 Ingo Berg
|
||
|
*/
|
||
|
class ParserByteCode
|
||
|
{
|
||
|
private:
|
||
|
|
||
|
/** \brief Token type for internal use only. */
|
||
|
typedef ParserToken<value_type, string_type> token_type;
|
||
|
|
||
|
/** \brief Token vector for storing the RPN. */
|
||
|
typedef std::vector<SToken> rpn_type;
|
||
|
|
||
|
/** \brief Position in the Calculation array. */
|
||
|
unsigned m_iStackPos;
|
||
|
|
||
|
/** \brief Maximum size needed for the stack. */
|
||
|
std::size_t m_iMaxStackSize;
|
||
|
|
||
|
/** \brief The actual rpn storage. */
|
||
|
rpn_type m_vRPN;
|
||
|
|
||
|
bool m_bEnableOptimizer;
|
||
|
|
||
|
void ConstantFolding(ECmdCode a_Oprt);
|
||
|
|
||
|
public:
|
||
|
|
||
|
ParserByteCode();
|
||
|
ParserByteCode(const ParserByteCode &a_ByteCode);
|
||
|
ParserByteCode& operator=(const ParserByteCode &a_ByteCode);
|
||
|
void Assign(const ParserByteCode &a_ByteCode);
|
||
|
|
||
|
void AddVar(value_type *a_pVar);
|
||
|
void AddVal(value_type a_fVal);
|
||
|
void AddOp(ECmdCode a_Oprt);
|
||
|
void AddIfElse(ECmdCode a_Oprt);
|
||
|
void AddAssignOp(value_type *a_pVar);
|
||
|
void AddFun(generic_fun_type a_pFun, int a_iArgc);
|
||
|
void AddBulkFun(generic_fun_type a_pFun, int a_iArgc);
|
||
|
void AddStrFun(generic_fun_type a_pFun, int a_iArgc, int a_iIdx);
|
||
|
|
||
|
void EnableOptimizer(bool bStat);
|
||
|
|
||
|
void Finalize();
|
||
|
void clear();
|
||
|
std::size_t GetMaxStackSize() const;
|
||
|
std::size_t GetSize() const;
|
||
|
|
||
|
const SToken* GetBase() const;
|
||
|
void AsciiDump();
|
||
|
};
|
||
|
|
||
|
} // namespace mu
|
||
|
|
||
|
#endif
|
||
|
|
||
|
|