Make main properly return with failure on parsing errors
This commit is contained in:
parent
d3d69b82d5
commit
8c0e9926c5
43
src/main.c
43
src/main.c
@ -32,21 +32,22 @@ void print_text(tokenlist_t *list) {
|
||||
}
|
||||
}
|
||||
|
||||
void print_ast(tokenlist_t *list) {
|
||||
error_t *print_ast(tokenlist_t *list) {
|
||||
parse_result_t result = parse(list->head);
|
||||
if (result.err) {
|
||||
puts(result.err->message);
|
||||
error_free(result.err);
|
||||
return;
|
||||
}
|
||||
if (result.err)
|
||||
return result.err;
|
||||
|
||||
ast_node_print(result.node);
|
||||
|
||||
if (result.next != nullptr) {
|
||||
puts("First unparsed token:");
|
||||
lexer_token_print(&result.next->token);
|
||||
}
|
||||
|
||||
ast_node_free(result.node);
|
||||
if (result.next != nullptr) {
|
||||
return errorf("did not parse entire input token stream");
|
||||
}
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
int get_execution_mode(int argc, char *argv[]) {
|
||||
@ -63,6 +64,20 @@ int get_execution_mode(int argc, char *argv[]) {
|
||||
return MODE_AST;
|
||||
}
|
||||
|
||||
error_t *do_action(mode_t mode, tokenlist_t *list) {
|
||||
switch (mode) {
|
||||
case MODE_TOKENS:
|
||||
print_tokens(list);
|
||||
return nullptr;
|
||||
case MODE_TEXT:
|
||||
print_text(list);
|
||||
return nullptr;
|
||||
case MODE_AST:
|
||||
return print_ast(list);
|
||||
}
|
||||
__builtin_unreachable();
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
mode_t mode = get_execution_mode(argc, argv);
|
||||
char *filename = argv[2];
|
||||
@ -81,17 +96,9 @@ int main(int argc, char *argv[]) {
|
||||
if (err)
|
||||
goto cleanup_tokens;
|
||||
|
||||
switch (mode) {
|
||||
case MODE_TOKENS:
|
||||
print_tokens(list);
|
||||
break;
|
||||
case MODE_TEXT:
|
||||
print_text(list);
|
||||
break;
|
||||
case MODE_AST:
|
||||
print_ast(list);
|
||||
break;
|
||||
}
|
||||
err = do_action(mode, list);
|
||||
if (err)
|
||||
goto cleanup_tokens;
|
||||
|
||||
tokenlist_free(list);
|
||||
error_free(err);
|
||||
|
Loading…
x
Reference in New Issue
Block a user