main: add pretty errors
This commit is contained in:
parent
cef08d30e1
commit
ced173d80f
@ -11,7 +11,6 @@ void pretty_print_error(vector<string> history, CodePosition pos) {
|
||||
if (pos.column == -1 || pos.line == -1)
|
||||
return;
|
||||
|
||||
cout << pos.column << ";" << pos.line << endl;
|
||||
string line = history[pos.line];
|
||||
|
||||
printf(BOLD "%4d " RESET , pos.line+1);
|
||||
|
14
src/main.cpp
14
src/main.cpp
@ -1,8 +1,9 @@
|
||||
#include <string.h>
|
||||
#include <cstring>
|
||||
#include <iostream>
|
||||
using namespace std;
|
||||
|
||||
#include "include/input.h"
|
||||
#include "include/errors.h"
|
||||
#include "include/colors.h"
|
||||
#include "include/parser.h"
|
||||
#include "include/tokenize.h"
|
||||
@ -20,10 +21,12 @@ int main(int argc, char* argv[]) {
|
||||
i++;
|
||||
}
|
||||
|
||||
vector<string> input;
|
||||
vector<Token> tokens;
|
||||
while (true) {
|
||||
try {
|
||||
vector<string> input = get_input();
|
||||
vector<Token> tokens = tokenize(input);
|
||||
input = get_input();
|
||||
tokens = tokenize(input);
|
||||
|
||||
Node ast = parse(tokens);
|
||||
|
||||
@ -32,8 +35,11 @@ int main(int argc, char* argv[]) {
|
||||
|
||||
EvalResult res = eval(ast);
|
||||
cout << get<int>(res) << endl;
|
||||
|
||||
} catch (const SyntaxError& e) {
|
||||
cout << RED "SyntaxError: " RESET << e.what() << endl;
|
||||
pretty_print_error(input, e.pos);
|
||||
cout << BOLD RED "Syntax Error: " RESET << e.what() << endl;
|
||||
|
||||
} catch (const ParseException& e) {
|
||||
cout << RED "ParsingError" RESET << endl;
|
||||
}
|
||||
|
@ -64,21 +64,25 @@ Node parse(vector<Token> tokens) {
|
||||
|
||||
Node node = ret.node;
|
||||
|
||||
while (tokens.size() != 0) {
|
||||
ParseReturn ret = parse_instruction(tokens);
|
||||
tokens = ret.tokens;
|
||||
try {
|
||||
while (tokens.size() != 0) {
|
||||
ParseReturn ret = parse_instruction(tokens);
|
||||
tokens = ret.tokens;
|
||||
|
||||
if (!holds_alternative<InnerNode>(ret.node) || get<InnerNode>(ret.node).type != NodeType::Epsilon) {
|
||||
InnerNode new_node = {
|
||||
.type=NodeType::Prog,
|
||||
.children={node, ret.node},
|
||||
.pos=null_pos
|
||||
};
|
||||
node = new_node;
|
||||
if (!holds_alternative<InnerNode>(ret.node) || get<InnerNode>(ret.node).type != NodeType::Epsilon) {
|
||||
InnerNode new_node = {
|
||||
.type=NodeType::Prog,
|
||||
.children={node, ret.node},
|
||||
.pos=get_node_pos(ret.node)
|
||||
};
|
||||
node = new_node;
|
||||
}
|
||||
}
|
||||
return node;
|
||||
} catch (const ParseException& pex) {
|
||||
CodePosition pos = tokens.back().pos;
|
||||
throw SyntaxError("Unable to parse", pos);
|
||||
}
|
||||
|
||||
return node;
|
||||
}
|
||||
|
||||
ParseReturn parse_instruction(vector<Token> tokens) {
|
||||
@ -161,7 +165,7 @@ ParseReturn parse_expr_statement(vector<Token> tokens) {
|
||||
InnerNode node = {
|
||||
.type=NodeType::Declaration,
|
||||
.children={type, identifier},
|
||||
.pos=type.pos
|
||||
.pos=identifier.pos
|
||||
};
|
||||
return {
|
||||
.node=node,
|
||||
@ -178,7 +182,7 @@ ParseReturn parse_expr_statement(vector<Token> tokens) {
|
||||
InnerNode node = {
|
||||
.type=NodeType::AssignedDeclaration,
|
||||
.children={type, identifier, ret.node},
|
||||
.pos=type.pos
|
||||
.pos=get_node_pos(ret.node)
|
||||
};
|
||||
return {
|
||||
.node=node,
|
||||
@ -225,7 +229,7 @@ ParseReturn parse_expr(vector<Token> tokens) {
|
||||
InnerNode new_node = {
|
||||
.type=type,
|
||||
.children={node, ret.node},
|
||||
.pos=get_node_pos(node)
|
||||
.pos=get_node_pos(ret.node)
|
||||
};
|
||||
node = new_node;
|
||||
} catch (const ParseException& pex) {
|
||||
@ -286,7 +290,7 @@ ParseReturn parse_t(vector<Token> tokens) {
|
||||
InnerNode new_node = {
|
||||
.type=type,
|
||||
.children={node, ret.node},
|
||||
.pos=get_node_pos(node)
|
||||
.pos=get_node_pos(ret.node)
|
||||
};
|
||||
node = new_node;
|
||||
} catch (const ParseException& pex) {
|
||||
@ -419,7 +423,7 @@ ParseReturn parse_f(vector<Token> tokens) {
|
||||
InnerNode node = {
|
||||
.type = NodeType::Assignment,
|
||||
.children = { ret.node, ret_expr.node },
|
||||
.pos=get_node_pos(ret.node)
|
||||
.pos=get_node_pos(ret_expr.node)
|
||||
};
|
||||
return {
|
||||
.node=node,
|
||||
@ -437,14 +441,17 @@ ParseReturn parse_f(vector<Token> tokens) {
|
||||
if (tokens.back().type != TokenType::LParenthese)
|
||||
throw ParseException();
|
||||
|
||||
CodePosition pos = tokens.back().pos;
|
||||
tokens.pop_back();
|
||||
|
||||
ParseReturn ret = parse_expr(tokens);
|
||||
tokens=ret.tokens;
|
||||
|
||||
_debug_print_tokens(tokens);
|
||||
|
||||
CodePosition pos = tokens.back().pos;
|
||||
cout << pos.line << ";" << pos.column << endl;
|
||||
if (tokens.size() < 1 || tokens.back().type != TokenType::RParenthese)
|
||||
throw SyntaxError("Missing ')'", pos);
|
||||
throw SyntaxError("Missing ')'", tokens.back().pos);
|
||||
|
||||
tokens.pop_back();
|
||||
|
||||
|
@ -71,9 +71,8 @@ vector<Token> tokenize(vector<string> input) {
|
||||
string line = input[i];
|
||||
int j = 0;
|
||||
|
||||
CodePosition pos = { .line = i, .column = j };
|
||||
|
||||
while (j < int(line.length())) {
|
||||
CodePosition pos = { .line = i, .column = j };
|
||||
string str = line.substr(j, string::npos);
|
||||
smatch m;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user