mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
ruby.h: relax rb_funcall check on extra args for clang
clang 5.+ (tested clang 7.0.0) seems to be attempting division-by-zero and giving a very large number for static args to rb_funcall. * include/ruby/ruby.h (rb_varargs_bad_length): relax check for clang * ext/-test-/funcall/funcall.c: renamed from passing_block.c define extra_args_name function * test/-ext-/funcall/test_funcall.rb: new test [ruby-core:85266] [Bug #14425] From: Eric Wong <e@80x24.org> git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@62116 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
b10b51225e
commit
3ce9a14040
3 changed files with 28 additions and 1 deletions
|
@ -14,10 +14,21 @@ with_funcall_passing_block(int argc, VALUE *argv, VALUE self)
|
|||
return rb_funcall_passing_block(self, rb_intern("target"), argc, argv);
|
||||
}
|
||||
|
||||
static VALUE
|
||||
extra_args_name(VALUE self)
|
||||
{
|
||||
/*
|
||||
* at least clang 5.x gets tripped by the extra 0 arg
|
||||
* [ruby-core:85266] [Bug #14425]
|
||||
*/
|
||||
return rb_funcall(self, rb_intern("name"), 0, 0);
|
||||
}
|
||||
|
||||
void
|
||||
Init_funcall(void)
|
||||
{
|
||||
VALUE cRelay = rb_path2class("TestFuncall::Relay");
|
||||
VALUE cTestFuncall = rb_path2class("TestFuncall");
|
||||
VALUE cRelay = rb_define_module_under(cTestFuncall, "Relay");
|
||||
|
||||
rb_define_singleton_method(cRelay,
|
||||
"with_funcall2",
|
||||
|
@ -27,4 +38,7 @@ Init_funcall(void)
|
|||
"with_funcall_passing_block",
|
||||
with_funcall_passing_block,
|
||||
-1);
|
||||
rb_define_singleton_method(cTestFuncall, "extra_args_name",
|
||||
extra_args_name,
|
||||
0);
|
||||
}
|
|
@ -1783,6 +1783,8 @@ VALUE rb_check_symbol(volatile VALUE *namep);
|
|||
# if defined(HAVE_BUILTIN___BUILTIN_CHOOSE_EXPR_CONSTANT_P)
|
||||
# if HAVE_ATTRIBUTE_ERRORFUNC
|
||||
ERRORFUNC((" argument length doesn't match"), int rb_varargs_bad_length(int,int));
|
||||
# elif defined(__clang__) /* [ruby-core:85266] [Bug #14425] */
|
||||
# define rb_varargs_bad_length(argc, vargc) ((argc)/((argc) <= (vargc)))
|
||||
# else
|
||||
# define rb_varargs_bad_length(argc, vargc) ((argc)/((argc) == (vargc)))
|
||||
# endif
|
||||
|
|
11
test/-ext-/funcall/test_funcall.rb
Normal file
11
test/-ext-/funcall/test_funcall.rb
Normal file
|
@ -0,0 +1,11 @@
|
|||
# frozen_string_literal: true
|
||||
require 'test/unit'
|
||||
|
||||
class TestFuncall < Test::Unit::TestCase
|
||||
require '-test-/funcall'
|
||||
|
||||
def test_funcall_extra_args
|
||||
assert_equal 'TestFuncall', TestFuncall.extra_args_name,
|
||||
'[ruby-core:85266] [Bug #14425]'
|
||||
end
|
||||
end
|
Loading…
Add table
Reference in a new issue