diff options
| author | ksss <[email protected]> | 2017-01-06 16:27:19 +0900 |
|---|---|---|
| committer | ksss <[email protected]> | 2017-01-06 16:27:19 +0900 |
| commit | ddcb30d84bfad619184a504b76e153bed0b875b9 (patch) | |
| tree | 736991745b3b782705039c16532adcc59168e181 /src/kernel.c | |
| parent | 158a6ab2ed64a448d7345d56d1d7430a9f52d4b8 (diff) | |
| download | mruby-ddcb30d84bfad619184a504b76e153bed0b875b9.tar.gz mruby-ddcb30d84bfad619184a504b76e153bed0b875b9.zip | |
Check intern object returned by mrb_check_string_type
Diffstat (limited to 'src/kernel.c')
| -rw-r--r-- | src/kernel.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/src/kernel.c b/src/kernel.c index 5e44d73b4..0791bbd92 100644 --- a/src/kernel.c +++ b/src/kernel.c @@ -965,14 +965,17 @@ obj_respond_to(mrb_state *mrb, mrb_value self) } else { mrb_value tmp; - if (!mrb_string_p(mid)) { + if (mrb_string_p(mid)) { + tmp = mrb_check_intern_str(mrb, mid); + } + else { tmp = mrb_check_string_type(mrb, mid); if (mrb_nil_p(tmp)) { tmp = mrb_inspect(mrb, mid); mrb_raisef(mrb, E_TYPE_ERROR, "%S is not a symbol", tmp); } + tmp = mrb_check_intern_str(mrb, tmp); } - tmp = mrb_check_intern_str(mrb, mid); if (mrb_nil_p(tmp)) { respond_to_p = FALSE; } |
