mirror of
https://github.com/italicsjenga/agb.git
synced 2024-12-26 09:41:34 +11:00
79 lines
1.5 KiB
C
79 lines
1.5 KiB
C
|
/* Copyright (c) 2013-2014 Jeffrey Pfau
|
||
|
*
|
||
|
* 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/. */
|
||
|
#ifndef PARSER_H
|
||
|
#define PARSER_H
|
||
|
|
||
|
#include <mgba-util/common.h>
|
||
|
|
||
|
#include <mgba-util/vector.h>
|
||
|
|
||
|
CXX_GUARD_START
|
||
|
|
||
|
struct Token;
|
||
|
DECLARE_VECTOR(LexVector, struct Token);
|
||
|
|
||
|
enum Operation {
|
||
|
OP_ASSIGN,
|
||
|
OP_ADD,
|
||
|
OP_SUBTRACT,
|
||
|
OP_MULTIPLY,
|
||
|
OP_DIVIDE,
|
||
|
OP_MODULO,
|
||
|
OP_AND,
|
||
|
OP_OR,
|
||
|
OP_XOR,
|
||
|
OP_LESS,
|
||
|
OP_GREATER,
|
||
|
OP_EQUAL,
|
||
|
OP_NOT_EQUAL,
|
||
|
OP_LOGICAL_AND,
|
||
|
OP_LOGICAL_OR,
|
||
|
OP_LE,
|
||
|
OP_GE,
|
||
|
OP_NEGATE,
|
||
|
OP_FLIP,
|
||
|
OP_NOT,
|
||
|
OP_SHIFT_L,
|
||
|
OP_SHIFT_R,
|
||
|
OP_DEREFERENCE,
|
||
|
};
|
||
|
|
||
|
struct Token {
|
||
|
enum TokenType {
|
||
|
TOKEN_ERROR_TYPE,
|
||
|
TOKEN_UINT_TYPE,
|
||
|
TOKEN_IDENTIFIER_TYPE,
|
||
|
TOKEN_OPERATOR_TYPE,
|
||
|
TOKEN_OPEN_PAREN_TYPE,
|
||
|
TOKEN_CLOSE_PAREN_TYPE,
|
||
|
TOKEN_SEGMENT_TYPE,
|
||
|
} type;
|
||
|
union {
|
||
|
uint32_t uintValue;
|
||
|
char* identifierValue;
|
||
|
enum Operation operatorValue;
|
||
|
};
|
||
|
};
|
||
|
|
||
|
struct ParseTree {
|
||
|
struct Token token;
|
||
|
struct ParseTree* lhs;
|
||
|
struct ParseTree* rhs;
|
||
|
};
|
||
|
|
||
|
size_t lexExpression(struct LexVector* lv, const char* string, size_t length, const char* eol);
|
||
|
void parseLexedExpression(struct ParseTree* tree, struct LexVector* lv);
|
||
|
|
||
|
void lexFree(struct LexVector* lv);
|
||
|
void parseFree(struct ParseTree* tree);
|
||
|
|
||
|
struct mDebugger;
|
||
|
bool mDebuggerEvaluateParseTree(struct mDebugger* debugger, struct ParseTree* tree, int32_t* value, int* segment);
|
||
|
|
||
|
CXX_GUARD_END
|
||
|
|
||
|
#endif
|