Fix minor parsing bug with procedure return types

This commit is contained in:
Ginger Bill
2017-07-19 22:17:57 +01:00
parent f1ab17ed4e
commit d233706a2d
3 changed files with 14 additions and 7 deletions
+2 -2
View File
@@ -1,6 +1,6 @@
import "fmt.odin";
main :: proc() {
v, ok := fmt.string_to_enum_value(Allocator.Mode, "FreeAll");
if ok do assert(v == Allocator.Mode.FreeAll);
fmt.println("Hellope!");
}
+4 -4
View File
@@ -236,10 +236,10 @@ type_info_base_without_enum :: proc(info: ^TypeInfo) -> ^TypeInfo {
foreign __llvm_core {
assume :: proc(cond: bool) #link_name "llvm.assume" ---;
__debug_trap :: proc() #link_name "llvm.debugtrap" ---;
__trap :: proc() #link_name "llvm.trap" ---;
read_cycle_counter :: proc() -> u64 #link_name "llvm.readcyclecounter" ---;
assume :: proc(cond: bool) #cc_c #link_name "llvm.assume" ---;
__debug_trap :: proc() #cc_c #link_name "llvm.debugtrap" ---;
__trap :: proc() #cc_c #link_name "llvm.trap" ---;
read_cycle_counter :: proc() -> u64 #cc_c #link_name "llvm.readcyclecounter" ---;
}
+8 -1
View File
@@ -3391,6 +3391,10 @@ AstNode *parse_results(AstFile *f) {
return nullptr;
}
isize prev_level = f->expr_level;
defer (f->expr_level = prev_level);
// f->expr_level = -1;
if (f->curr_token.kind != Token_OpenParen) {
CommentGroup empty_group = {};
Token begin_token = f->curr_token;
@@ -3790,10 +3794,13 @@ AstNode *parse_field_list(AstFile *f, isize *name_count_, u32 allowed_flags, Tok
AstNode *parse_type_or_ident(AstFile *f) {
#if 1
bool prev_allow_type = f->allow_type;
isize prev_expr_level = f->expr_level;
defer (f->allow_type = prev_allow_type);
defer (f->expr_level = prev_expr_level);
f->allow_type = true;
f->expr_level = -1;
AstNode *operand = parse_operand(f, true);
AstNode *type = parse_atom_expr(f, operand, true);
f->allow_type = prev_allow_type;
return type;
#else
switch (f->curr_token.kind) {