diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2016-03-23 23:51:23 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2016-03-23 23:51:23 +0900 |
| commit | 4fcff347474088e72d8b6016219d35ceb00c5a22 (patch) | |
| tree | bdd5107fe01cfdf03763aa344e9ff08577d9c40c | |
| parent | 817b884343cc349d3c32da7f1c65cb4867963bde (diff) | |
| download | mruby-4fcff347474088e72d8b6016219d35ceb00c5a22.tar.gz mruby-4fcff347474088e72d8b6016219d35ceb00c5a22.zip | |
`||=` reference error can happen with constants as well; #3138
| -rw-r--r-- | mrbgems/mruby-compiler/core/parse.y | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/mrbgems/mruby-compiler/core/parse.y b/mrbgems/mruby-compiler/core/parse.y index 9793aea8c..2fb07bc1f 100644 --- a/mrbgems/mruby-compiler/core/parse.y +++ b/mrbgems/mruby-compiler/core/parse.y @@ -709,7 +709,8 @@ new_masgn(parser_state *p, node *a, node *b) static node* new_op_asgn(parser_state *p, node *a, mrb_sym op, node *b) { - if (op == mrb_intern_lit(p->mrb, "||") && (intptr_t)a->car == NODE_CVAR) { + if (op == mrb_intern_lit(p->mrb, "||") && + ((intptr_t)a->car == NODE_CONST || (intptr_t)a->car == NODE_CVAR)) { return new_rescue(p, a, list1(list3(list1(new_const(p, mrb_intern_lit(p->mrb, "NameError"))), 0, new_asgn(p, a, b))), NULL); } |
