From 39f0e02e06980d55dec34141c02c219f73f2bfc7 Mon Sep 17 00:00:00 2001 From: Dipin Hora Date: Thu, 7 Nov 2019 01:45:31 +0000 Subject: [PATCH] Fix nested tuple access regression introduced by #3304 PR #3304 introduced a bug that caused segfaults with nested tuple access. This commit resolves the issue and adds a test to prevent another regression. resolves #3354. --- src/libponyc/pass/refer.c | 24 ++++++++++++------------ test/libponyc/badpony.cc | 12 ++++++++++++ 2 files changed, 24 insertions(+), 12 deletions(-) diff --git a/src/libponyc/pass/refer.c b/src/libponyc/pass/refer.c index 96bdca6d35..67bdfac529 100644 --- a/src/libponyc/pass/refer.c +++ b/src/libponyc/pass/refer.c @@ -658,7 +658,7 @@ bool refer_dot(pass_opt_t* opt, ast_t* ast) { // check multi_dot reference if it's not a function call // only if we had a field consume/reassign - if(!ast_checkflag(ast, AST_FLAG_FCNSM_REASGN) + if(ast_checkflag(ast, AST_FLAG_FCNSM_REASGN) && (ast_id(ast_parent(ast)) != TK_CALL) && (ast_id(ast_parent(ast)) != TK_QUALIFY)) return refer_multi_dot(opt, ast); @@ -1055,20 +1055,20 @@ static bool check_assigned_same_expression(ast_t* ast, const char* name, return ast_get_child(assign_left, name); } -static void set_flag_recursive(ast_t* outer, ast_t* inner, uint32_t flag) +static void set_flag_recursive(ast_t* outer, uint32_t flag) { pony_assert(outer != NULL); - pony_assert(inner != NULL); - do - { - ast_setflag(inner, flag); + ast_setflag(outer, flag); - if(inner == outer) - break; + ast_t* child = ast_child(outer); - inner = ast_parent(inner); - } while(inner != NULL); + while(child != NULL) + { + set_flag_recursive(child, flag); + + child = ast_sibling(child); + } } static bool refer_consume(pass_opt_t* opt, ast_t* ast) @@ -1152,8 +1152,8 @@ static bool refer_consume(pass_opt_t* opt, ast_t* ast) consumed_same_expr = true; - // assign flag to full tree from ast to assign_ast - set_flag_recursive(assign_ast, ast, AST_FLAG_FCNSM_REASGN); + // assign flag to assign_ast and all children + set_flag_recursive(assign_ast, AST_FLAG_FCNSM_REASGN); break; } diff --git a/test/libponyc/badpony.cc b/test/libponyc/badpony.cc index 8da6cbf97c..7d966a607e 100644 --- a/test/libponyc/badpony.cc +++ b/test/libponyc/badpony.cc @@ -1072,3 +1072,15 @@ TEST_F(BadPonyTest, AllowAliasForNonEphemeralReturn) TEST_COMPILE(src); } + +TEST_F(BadPonyTest, AllowNestedTupleAccess) +{ + // From issue #3354 + const char* src = + "actor Main\n" + " new create(env: Env) =>\n" + " let x = (1, (2, 3))._2._1"; + + TEST_ERRORS_1(src, + "Cannot look up member _2 on a literal") +}