From 36a015741db9fbf748fe9ab082f78c5d8663024c Mon Sep 17 00:00:00 2001 From: Josh Wolfe Date: Fri, 31 Mar 2017 08:41:00 -0700 Subject: clean up analysis of {blocks} * Don't insert void statements all over the place. {} now stays as {} instead of {{}}, and {;} becomes {} instead of {{};{}}. * Ensure final statement is always the return value statement, or the block is empty. This means {label:} becomes {label:{}}. --- src/parser.cpp | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) (limited to 'src/parser.cpp') diff --git a/src/parser.cpp b/src/parser.cpp index 0da247c051..bbaee219b7 100644 --- a/src/parser.cpp +++ b/src/parser.cpp @@ -2094,16 +2094,14 @@ static AstNode *ast_parse_block(ParseContext *pc, size_t *token_index, bool mand AstNode *node = ast_create_node(pc, NodeTypeBlock, last_token); - // {} -> {void} - // {;} -> {void;void} - // {2} -> {2} - // {2;} -> {2;void} - // {;2} -> {void;2} for (;;) { AstNode *statement_node = ast_parse_label(pc, token_index, false); + bool need_implicit_final_void_statement = false; bool semicolon_expected; if (statement_node) { semicolon_expected = false; + // if a label is the last thing in a block, add a void statement. + need_implicit_final_void_statement = true; } else { statement_node = ast_parse_variable_declaration_expr(pc, token_index, false, VisibModPrivate); if (!statement_node) { @@ -2117,17 +2115,23 @@ static AstNode *ast_parse_block(ParseContext *pc, size_t *token_index, bool mand if (!statement_node) { statement_node = ast_parse_non_block_expr(pc, token_index, false); if (!statement_node) { - statement_node = ast_create_void_expr(pc, last_token); + // final semicolon means add a void statement. + need_implicit_final_void_statement = true; } } } } - node->data.block.statements.append(statement_node); + if (statement_node) + node->data.block.statements.append(statement_node); last_token = &pc->tokens->at(*token_index); if (last_token->id == TokenIdRBrace) { *token_index += 1; + if (node->data.block.statements.length > 0 && need_implicit_final_void_statement) { + node->data.block.statements.append(ast_create_void_expr(pc, last_token)); + } + return node; } else if (!semicolon_expected) { continue; -- cgit v1.2.3