From 139510238bcbb8d7fd8022c23a603c51d2acbe2e Mon Sep 17 00:00:00 2001 From: Aaron Patterson Date: Tue, 10 Sep 2019 11:27:40 -0700 Subject: WB needs to be executed after object is reachable --- parse.y | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'parse.y') diff --git a/parse.y b/parse.y index 852a5edee7..a7d43b783b 100644 --- a/parse.y +++ b/parse.y @@ -465,7 +465,7 @@ static NODE *symbol_append(struct parser_params *p, NODE *symbols, NODE *symbol) static NODE *match_op(struct parser_params*,NODE*,NODE*,const YYLTYPE*,const YYLTYPE*); -static ID *local_tbl(struct parser_params*); +static ID *local_tbl(struct parser_params*, VALUE *tmp); static VALUE reg_compile(struct parser_params*, VALUE, int); static void reg_fragment_setenc(struct parser_params*, VALUE, int); @@ -11144,8 +11144,8 @@ new_args_tail(struct parser_params *p, NODE *kw_args, ID kw_rest_arg, ID block, args = ZALLOC(struct rb_args_info); VALUE tmpbuf = rb_imemo_tmpbuf_auto_free_pointer(args); args->imemo = tmpbuf; - RB_OBJ_WRITTEN(p->ast, Qnil, tmpbuf); node = NEW_NODE(NODE_ARGS, 0, 0, args, &NULL_LOC); + RB_OBJ_WRITTEN(p->ast, Qnil, tmpbuf); if (p->error_p) return node; args->block_arg = block; @@ -11633,7 +11633,7 @@ local_pop(struct parser_params *p) #ifndef RIPPER static ID* -local_tbl(struct parser_params *p) +local_tbl(struct parser_params *p, VALUE *tmp) { int cnt_args = vtable_size(p->lvtbl->args); int cnt_vars = vtable_size(p->lvtbl->vars); @@ -11655,8 +11655,8 @@ local_tbl(struct parser_params *p) buf[0] = cnt; VALUE tmpbuf = rb_imemo_tmpbuf_auto_free_pointer(buf); + *tmp = tmpbuf; buf[cnt + 1] = (ID)tmpbuf; - RB_OBJ_WRITTEN(p->ast, Qnil, tmpbuf); return buf; } -- cgit v1.2.3