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
				
			
		
							
								
								
									
										44
									
								
								ext/-test-/funcall/funcall.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								ext/-test-/funcall/funcall.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,44 @@ | |||
| #include "ruby.h" | ||||
| 
 | ||||
| VALUE rb_funcall_passing_block(VALUE, ID, int, const VALUE*); | ||||
| 
 | ||||
| static VALUE | ||||
| with_funcall2(int argc, VALUE *argv, VALUE self) | ||||
| { | ||||
|     return rb_funcallv(self, rb_intern("target"), argc, argv); | ||||
| } | ||||
| 
 | ||||
| static VALUE | ||||
| 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 cTestFuncall = rb_path2class("TestFuncall"); | ||||
|     VALUE cRelay = rb_define_module_under(cTestFuncall, "Relay"); | ||||
| 
 | ||||
|     rb_define_singleton_method(cRelay, | ||||
| 			       "with_funcall2", | ||||
| 			       with_funcall2, | ||||
| 			       -1); | ||||
|     rb_define_singleton_method(cRelay, | ||||
| 			       "with_funcall_passing_block", | ||||
| 			       with_funcall_passing_block, | ||||
| 			       -1); | ||||
|     rb_define_singleton_method(cTestFuncall, "extra_args_name", | ||||
|                                 extra_args_name, | ||||
|                                 0); | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 normal
						normal