mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	Make warning values consistent [Bug #17523]
They should be affected, as well as `$VERBOSE`, by `-w`/`-W` options, not only in the main script but in scripts loaded by `-r` option too.
This commit is contained in:
		
							parent
							
								
									85b5d4c8bf
								
							
						
					
					
						commit
						6f6dfdcc68
					
				
				
				Notes:
				
					git
				
				2021-01-13 18:13:16 +09:00 
				
			
			
			
		
		
					 2 changed files with 11 additions and 2 deletions
				
			
		
							
								
								
									
										4
									
								
								ruby.c
									
										
									
									
									
								
							
							
						
						
									
										4
									
								
								ruby.c
									
										
									
									
									
								
							|  | @ -1510,6 +1510,8 @@ ruby_opt_init(ruby_cmdline_options_t *opt) | |||
|         } | ||||
|     } | ||||
| 
 | ||||
|     rb_warning_category_update(opt->warn.mask, opt->warn.set); | ||||
| 
 | ||||
|     Init_ext(); /* load statically linked extensions before rubygems */ | ||||
|     rb_call_builtin_inits(); | ||||
|     ruby_init_prelude(); | ||||
|  | @ -1946,7 +1948,6 @@ process_options(int argc, char **argv, ruby_cmdline_options_t *opt) | |||
|         ruby_set_script_name(progname); | ||||
| 	rb_parser_set_options(parser, opt->do_print, opt->do_loop, | ||||
| 			      opt->do_line, opt->do_split); | ||||
|         rb_warning_category_update(opt->warn.mask, opt->warn.set); | ||||
| 	ast = rb_parser_compile_string(parser, opt->script, opt->e_script, 1); | ||||
|     } | ||||
|     else { | ||||
|  | @ -2186,7 +2187,6 @@ load_file_internal(VALUE argp_v) | |||
|     } | ||||
|     rb_parser_set_options(parser, opt->do_print, opt->do_loop, | ||||
| 			  opt->do_line, opt->do_split); | ||||
|     rb_warning_category_update(opt->warn.mask, opt->warn.set); | ||||
|     if (NIL_P(f)) { | ||||
| 	f = rb_str_new(0, 0); | ||||
| 	rb_enc_associate(f, enc); | ||||
|  |  | |||
|  | @ -85,6 +85,15 @@ class TestRubyOptions < Test::Unit::TestCase | |||
|     assert_in_out_err(%w(-W -e) + ['p Warning[:deprecated]'], "", %w(true), []) | ||||
|     assert_in_out_err(%w(-We) + ['p Warning[:deprecated]'], "", %w(true), []) | ||||
|     assert_in_out_err(%w(-e) + ['p Warning[:deprecated]'], "", %w(false), []) | ||||
|     code = 'puts "#{$VERBOSE}:#{Warning[:deprecated]}:#{Warning[:experimental]}"' | ||||
|     Tempfile.create(["test_ruby_test_rubyoption", ".rb"]) do |t| | ||||
|       t.puts code | ||||
|       t.close | ||||
|       assert_in_out_err(["-r#{t.path}", '-e', code], "", %w(false:false:true false:false:true), []) | ||||
|       assert_in_out_err(["-r#{t.path}", '-w', '-e', code], "", %w(true:true:true true:true:true), []) | ||||
|       assert_in_out_err(["-r#{t.path}", '-W:deprecated', '-e', code], "", %w(false:true:true false:true:true), []) | ||||
|       assert_in_out_err(["-r#{t.path}", '-W:no-experimental', '-e', code], "", %w(false:false:false false:false:false), []) | ||||
|     end | ||||
|   ensure | ||||
|     ENV['RUBYOPT'] = save_rubyopt | ||||
|   end | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Nobuyoshi Nakada
						Nobuyoshi Nakada