Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mruby
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Libraries
mruby
Commits
326e043a
Commit
326e043a
authored
7 years ago
by
Yukihiro "Matz" Matsumoto
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Exceptions may be raised in yyparse(); fix #3600
parent
918e7bb1
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
23 additions
and
4 deletions
+23
-4
mrbgems/mruby-compiler/core/parse.y
mrbgems/mruby-compiler/core/parse.y
+22
-4
src/vm.c
src/vm.c
+1
-0
No files found.
mrbgems/mruby-compiler/core/parse.y
View file @
326e043a
...
@@ -5514,10 +5514,11 @@ void mrb_parser_dump(mrb_state *mrb, node *tree, int offset);
...
@@ -5514,10 +5514,11 @@ void mrb_parser_dump(mrb_state *mrb, node *tree, int offset);
MRB_API void
MRB_API void
mrb_parser_parse(parser_state *p, mrbc_context *c)
mrb_parser_parse(parser_state *p, mrbc_context *c)
{
{
struct mrb_jmpbuf buf;
struct mrb_jmpbuf buf
1
;
p->jmp = &buf;
p->jmp = &buf
1
;
MRB_TRY(p->jmp) {
MRB_TRY(p->jmp) {
int n;
p->cmd_start = TRUE;
p->cmd_start = TRUE;
p->in_def = p->in_single = 0;
p->in_def = p->in_single = 0;
...
@@ -5525,7 +5526,25 @@ mrb_parser_parse(parser_state *p, mrbc_context *c)
...
@@ -5525,7 +5526,25 @@ mrb_parser_parse(parser_state *p, mrbc_context *c)
p->lex_strterm = NULL;
p->lex_strterm = NULL;
parser_init_cxt(p, c);
parser_init_cxt(p, c);
if (yyparse(p) != 0 || p->nerr > 0) {
if (p->mrb->jmp) {
n = yyparse(p);
}
else {
struct mrb_jmpbuf buf2;
p->mrb->jmp = &buf2;
MRB_TRY(p->mrb->jmp) {
n = yyparse(p);
}
MRB_CATCH(p->mrb->jmp) {
p->nerr++;
mrb_p(p->mrb, mrb_obj_value(p->mrb->exc));
}
MRB_END_EXC(p->mrb->jmp);
p->mrb->jmp = 0;
}
if (n != 0 || p->nerr > 0) {
p->tree = 0;
p->tree = 0;
return;
return;
}
}
...
@@ -5536,7 +5555,6 @@ mrb_parser_parse(parser_state *p, mrbc_context *c)
...
@@ -5536,7 +5555,6 @@ mrb_parser_parse(parser_state *p, mrbc_context *c)
if (c && c->dump_result) {
if (c && c->dump_result) {
mrb_parser_dump(p->mrb, p->tree, 0);
mrb_parser_dump(p->mrb, p->tree, 0);
}
}
}
}
MRB_CATCH(p->jmp) {
MRB_CATCH(p->jmp) {
yyerror(p, "memory allocation error");
yyerror(p, "memory allocation error");
...
...
This diff is collapsed.
Click to expand it.
src/vm.c
View file @
326e043a
...
@@ -369,6 +369,7 @@ mrb_funcall_with_block(mrb_state *mrb, mrb_value self, mrb_sym mid, mrb_int argc
...
@@ -369,6 +369,7 @@ mrb_funcall_with_block(mrb_state *mrb, mrb_value self, mrb_sym mid, mrb_int argc
val
=
mrb_obj_value
(
mrb
->
exc
);
val
=
mrb_obj_value
(
mrb
->
exc
);
}
}
MRB_END_EXC
(
&
c_jmp
);
MRB_END_EXC
(
&
c_jmp
);
mrb
->
jmp
=
0
;
}
}
else
{
else
{
struct
RProc
*
p
;
struct
RProc
*
p
;
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment