diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-03-03 13:25:13 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-03-03 13:25:13 +0900 |
| commit | 9a92b40aaf0fc7b94623f5fca3692167b4048643 (patch) | |
| tree | f0d46c586ae3e1f1ea718014c3901650f4448da7 /src/codegen.c | |
| parent | ba7ea507880430908735972b6d72c2bb4059b558 (diff) | |
| download | mruby-9a92b40aaf0fc7b94623f5fca3692167b4048643.tar.gz mruby-9a92b40aaf0fc7b94623f5fca3692167b4048643.zip | |
rescue clause should understand splats; close #1786
Diffstat (limited to 'src/codegen.c')
| -rw-r--r-- | src/codegen.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/codegen.c b/src/codegen.c index 77bc5e34e..f30b26b00 100644 --- a/src/codegen.c +++ b/src/codegen.c @@ -1183,7 +1183,12 @@ codegen(codegen_scope *s, node *tree, int val) } genop(s, MKOP_AB(OP_MOVE, cursp(), exc)); pop(); - genop(s, MKOP_ABC(OP_SEND, cursp(), new_msym(s, mrb_intern_lit(s->mrb, "===")), 1)); + if (n4 && n4->car && (intptr_t)n4->car->car == NODE_SPLAT) { + genop(s, MKOP_ABC(OP_SEND, cursp(), new_msym(s, mrb_intern_lit(s->mrb, "__case_eqq")), 1)); + } + else { + genop(s, MKOP_ABC(OP_SEND, cursp(), new_msym(s, mrb_intern_lit(s->mrb, "===")), 1)); + } tmp = new_label(s); genop(s, MKOP_AsBx(OP_JMPIF, cursp(), pos2)); pos2 = tmp; |
