mirror of
https://github.com/odin-lang/Odin.git
synced 2025-12-30 18:02:02 +00:00
Improve error handling for trailing commas #2136
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
#include "parser_pos.cpp"
|
||||
|
||||
// #undef at the bottom of this file
|
||||
#define ALLOW_NEWLINE build_context.strict_style
|
||||
#define ALLOW_NEWLINE (!build_context.strict_style)
|
||||
|
||||
Token token_end_of_line(AstFile *f, Token tok) {
|
||||
u8 const *start = f->tokenizer.start + tok.pos.offset;
|
||||
@@ -1384,7 +1384,13 @@ Token expect_token_after(AstFile *f, TokenKind kind, char const *msg) {
|
||||
Token prev = f->curr_token;
|
||||
if (prev.kind != kind) {
|
||||
String p = token_to_string(prev);
|
||||
syntax_error(f->curr_token, "Expected '%.*s' after %s, got '%.*s'",
|
||||
Token token = f->curr_token;
|
||||
if (token_is_newline(prev)) {
|
||||
token = prev;
|
||||
token.pos.column -= 1;
|
||||
skip_possible_newline(f);
|
||||
}
|
||||
syntax_error(token, "Expected '%.*s' after %s, got '%.*s'",
|
||||
LIT(token_strings[kind]),
|
||||
msg,
|
||||
LIT(p));
|
||||
@@ -3420,7 +3426,6 @@ Ast *parse_results(AstFile *f, bool *diverging) {
|
||||
|
||||
isize prev_level = f->expr_level;
|
||||
defer (f->expr_level = prev_level);
|
||||
// f->expr_level = -1;
|
||||
|
||||
if (f->curr_token.kind != Token_OpenParen) {
|
||||
Token begin_token = f->curr_token;
|
||||
@@ -3435,6 +3440,9 @@ Ast *parse_results(AstFile *f, bool *diverging) {
|
||||
Ast *list = nullptr;
|
||||
expect_token(f, Token_OpenParen);
|
||||
list = parse_field_list(f, nullptr, FieldFlag_Results, Token_CloseParen, true, false);
|
||||
if (ALLOW_NEWLINE) {
|
||||
skip_possible_newline(f);
|
||||
}
|
||||
expect_token_after(f, Token_CloseParen, "parameter list");
|
||||
return list;
|
||||
}
|
||||
@@ -3492,6 +3500,9 @@ Ast *parse_proc_type(AstFile *f, Token proc_token) {
|
||||
|
||||
expect_token(f, Token_OpenParen);
|
||||
params = parse_field_list(f, nullptr, FieldFlag_Signature, Token_CloseParen, true, true);
|
||||
if (ALLOW_NEWLINE) {
|
||||
skip_possible_newline(f);
|
||||
}
|
||||
expect_token_after(f, Token_CloseParen, "parameter list");
|
||||
results = parse_results(f, &diverging);
|
||||
|
||||
@@ -3713,7 +3724,7 @@ bool allow_field_separator(AstFile *f) {
|
||||
if (allow_token(f, Token_Comma)) {
|
||||
return true;
|
||||
}
|
||||
if (ALLOW_NEWLINE && token.kind == Token_Semicolon) {
|
||||
if (ALLOW_NEWLINE && token.kind == Token_Semicolon && !token_is_newline(token)) {
|
||||
String p = token_to_string(token);
|
||||
syntax_error(token_end_of_line(f, f->prev_token), "Expected a comma, got a %.*s", LIT(p));
|
||||
advance_token(f);
|
||||
|
||||
Reference in New Issue
Block a user