summaryrefslogtreecommitdiff
path: root/proc.c
diff options
context:
space:
mode:
authornaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2016-03-29 16:06:24 +0000
committernaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2016-03-29 16:06:24 +0000
commit592599d99636c63e335ebae1e0ad6f07aa7028bf (patch)
tree8a81154356a070baed732ba98a93fb5a826d76ce /proc.c
parent6ead2416ebf449d77aa8b39a55da08084cd0c2d9 (diff)
merge revision(s) 54128: [Backport #12137]
* proc.c (proc_binding): proc from symbol can not make a binding. [ruby-core:74100] [Bug #12137] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_3@54413 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'proc.c')
-rw-r--r--proc.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/proc.c b/proc.c
index 6d153c1b3e..980142174b 100644
--- a/proc.c
+++ b/proc.c
@@ -2646,6 +2646,7 @@ proc_binding(VALUE self)
GetProcPtr(self, proc);
envval = rb_vm_proc_envval(proc);
iseq = proc->block.iseq;
+ if (SYMBOL_P(iseq)) goto error;
if (RUBY_VM_IFUNC_P(iseq)) {
struct vm_ifunc *ifunc = (struct vm_ifunc *)iseq;
if (IS_METHOD_PROC_IFUNC(ifunc)) {
@@ -2654,6 +2655,7 @@ proc_binding(VALUE self)
iseq = rb_method_iseq(method);
}
else {
+ error:
rb_raise(rb_eArgError, "Can't create Binding from C level Proc");
}
}