diff options
| author | take_cheeze <[email protected]> | 2014-07-09 22:02:33 +0900 |
|---|---|---|
| committer | take_cheeze <[email protected]> | 2014-07-09 22:02:33 +0900 |
| commit | b344b2934532500d29fff93fd0dd2b1f3c89f6c7 (patch) | |
| tree | 84f2717ccd8fd43137df14b13d9a4a585f028069 | |
| parent | 023908afc2790f8070da13d9ab3e51677b88dcde (diff) | |
| download | mruby-b344b2934532500d29fff93fd0dd2b1f3c89f6c7.tar.gz mruby-b344b2934532500d29fff93fd0dd2b1f3c89f6c7.zip | |
Use `mrb_parse_nstring` instead in eval.
| -rw-r--r-- | mrbgems/mruby-eval/src/eval.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/mrbgems/mruby-eval/src/eval.c b/mrbgems/mruby-eval/src/eval.c index b5cb833c2..3036837d5 100644 --- a/mrbgems/mruby-eval/src/eval.c +++ b/mrbgems/mruby-eval/src/eval.c @@ -113,10 +113,12 @@ create_proc_from_string(mrb_state *mrb, char *s, int len, mrb_value binding, cha mrbc_filename(mrb, cxt, file); } - p = mrb_parser_new(mrb); - p->s = s; - p->send = s + len; - mrb_parser_parse(p, cxt); + p = mrb_parse_nstring(mrb, s, len, cxt); + + /* only occur when memory ran out */ + if (!p) { + mrb_raise(mrb, E_RUNTIME_ERROR, "Failed to create parser state."); + } if (0 < p->nerr) { /* parse error */ |
