summaryrefslogtreecommitdiffhomepage
path: root/src/symbol.c
diff options
context:
space:
mode:
authordearblue <[email protected]>2021-01-28 21:15:31 +0900
committerdearblue <[email protected]>2021-01-28 21:15:31 +0900
commit3d8a8fb6613f177416cc09e81e2a0082db006926 (patch)
treeefa0f9a4aa5182b433e95d5923fa8ec7f1474b13 /src/symbol.c
parentbb42c1b286844e37aa8110e1b2d9b5dd9eff8f3e (diff)
downloadmruby-3d8a8fb6613f177416cc09e81e2a0082db006926.tar.gz
mruby-3d8a8fb6613f177416cc09e81e2a0082db006926.zip
Check first `0` when converting symbols into strings
This was because it caused `SIGSEGV` when `mruby -v` displayed an unnamed variable. ```console % bin/mruby -ve 'call { |(a, b)| }' ...SNIP... irep 0x8007d0050 nregs=3 nlocals=1 pools=0 syms=1 reps=1 iseq=12 file: -e 1 000 OP_LOADSELF R1 1 002 OP_BLOCK R2 I(0:0x8007d00a0) 1 005 OP_SENDB R1 :call 0 1 009 OP_RETURN R1 1 011 OP_STOP irep 0x8007d00a0 nregs=6 nlocals=5 pools=0 syms=0 reps=0 iseq=29 local variable names: zsh: segmentation fault (core dumped) bin/mruby -ve 'call { |(a, b)| }' ```
Diffstat (limited to 'src/symbol.c')
-rw-r--r--src/symbol.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/symbol.c b/src/symbol.c
index b15e0f11c..3cd925d99 100644
--- a/src/symbol.c
+++ b/src/symbol.c
@@ -303,6 +303,7 @@ mrb_check_intern_str(mrb_state *mrb, mrb_value str)
static const char*
sym2name_len(mrb_state *mrb, mrb_sym sym, char *buf, mrb_int *lenp)
{
+ if (sym == 0) goto outofsym;
if (SYMBOL_INLINE_P(sym)) return sym_inline_unpack(sym, buf, lenp);
#ifndef MRB_NO_PRESYM
@@ -313,7 +314,8 @@ sym2name_len(mrb_state *mrb, mrb_sym sym, char *buf, mrb_int *lenp)
#endif
sym -= MRB_PRESYM_MAX;
- if (sym == 0 || mrb->symidx < sym) {
+ if (mrb->symidx < sym) {
+ outofsym:
if (lenp) *lenp = 0;
return NULL;
}