Finally, some real progress on the AST!!
This commit is contained in:
parent
73f3f20a71
commit
98b14e6bf5
@ -7,4 +7,39 @@ class NumberNode : public ExprNode
|
||||
public:
|
||||
NumberNode();
|
||||
~NumberNode();
|
||||
};
|
||||
|
||||
virtual bool is_floating()
|
||||
{
|
||||
return false;
|
||||
}
|
||||
virtual bool is_integral()
|
||||
{
|
||||
return false;
|
||||
}
|
||||
};
|
||||
|
||||
template<typename T> class BasicNumberNode : public NumberNode
|
||||
{
|
||||
T value;
|
||||
|
||||
public:
|
||||
BasicNumberNode(T value) : value(value)
|
||||
{
|
||||
}
|
||||
~BasicNumberNode()
|
||||
{
|
||||
}
|
||||
|
||||
constexpr bool is_floating() override
|
||||
{
|
||||
return std::is_floating_point<T>::value;
|
||||
}
|
||||
|
||||
constexpr bool is_integral() override
|
||||
{
|
||||
return std::is_integral<T>::value;
|
||||
}
|
||||
};
|
||||
|
||||
using IntegerNode = BasicNumberNode<int>;
|
||||
using FloatNode = BasicNumberNode<float>;
|
@ -10,39 +10,51 @@ Parser::~Parser()
|
||||
|
||||
std::shared_ptr<Parser> Parser::new_parser(const TokenStream& tokens)
|
||||
{
|
||||
return std::shared_ptr<Parser>(
|
||||
new Parser(tokens)); // As always, not using std::make_shared 'cause constructor is private
|
||||
return std::shared_ptr<Parser>(
|
||||
new Parser(tokens)); // As always, not using std::make_shared 'cause constructor is private
|
||||
}
|
||||
|
||||
std::shared_ptr<ASTNode> Parser::parse()
|
||||
{
|
||||
auto result = walk_expr();
|
||||
auto result = walk_expr();
|
||||
|
||||
if (result.is_error())
|
||||
{
|
||||
result.ethrow();
|
||||
}
|
||||
if (result.is_error())
|
||||
{
|
||||
result.ethrow();
|
||||
}
|
||||
|
||||
return result.get();
|
||||
return result.get();
|
||||
}
|
||||
|
||||
Parser::ErrorOr<ExprNode> Parser::walk_expr()
|
||||
{
|
||||
return ErrorOr<ExprNode>(new ExprNode()); // constructor does not want to accept a shared_ptr<T> in the argument
|
||||
// list, thats why im not using make_shared here
|
||||
return ErrorOr<ExprNode>(new ExprNode()); // constructor does not want to accept a shared_ptr<T> in the argument
|
||||
// list, thats why im not using make_shared here
|
||||
}
|
||||
|
||||
Parser::ErrorOr<NumberNode> Parser::walk_number()
|
||||
{
|
||||
return ErrorOr<NumberNode>(new NumberNode());
|
||||
Token& current_token = tokens[m_index++];
|
||||
if (current_token.tk_type == TT_Number)
|
||||
{
|
||||
return ErrorOr<NumberNode>(new IntegerNode(current_token.int_value));
|
||||
}
|
||||
else if (current_token.tk_type == TT_Float)
|
||||
{
|
||||
return ErrorOr<NumberNode>(new FloatNode(current_token.float_value));
|
||||
}
|
||||
else
|
||||
{
|
||||
return ErrorOr<NumberNode>("expected a number", current_token);
|
||||
}
|
||||
}
|
||||
|
||||
void Parser::save_current_position()
|
||||
{
|
||||
saved_m_index = m_index;
|
||||
saved_m_index = m_index;
|
||||
}
|
||||
|
||||
void Parser::restore_current_position()
|
||||
{
|
||||
m_index = saved_m_index;
|
||||
m_index = saved_m_index;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user