mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	merge revision(s) f1b76ea63ce40670071a857f408a4747c571f1e9,1d1f98d49c9908f4e3928e582d31fd2e9f252f92: [Backport #16024]
Occupy match data * string.c (rb_str_split_m): occupy match data not to be modified during yielding the block. [Bug #16024] Reuse match data * string.c (rb_str_split_m): reuse occupied match data. [Bug #16024] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_6@67743 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
		
							parent
							
								
									9ab43c7a6c
								
							
						
					
					
						commit
						54a470d09e
					
				
					 5 changed files with 18 additions and 3 deletions
				
			
		|  | @ -1989,6 +1989,7 @@ long rb_reg_search0(VALUE, VALUE, long, int, int); | |||
| VALUE rb_reg_match_p(VALUE re, VALUE str, long pos); | ||||
| bool rb_reg_start_with_p(VALUE re, VALUE str); | ||||
| void rb_backref_set_string(VALUE string, long pos, long len); | ||||
| void rb_match_unbusy(VALUE); | ||||
| int rb_match_count(VALUE match); | ||||
| int rb_match_nth_defined(int nth, VALUE match); | ||||
| VALUE rb_reg_new_ary(VALUE ary, int options); | ||||
|  |  | |||
							
								
								
									
										6
									
								
								re.c
									
										
									
									
									
								
							
							
						
						
									
										6
									
								
								re.c
									
										
									
									
									
								
							|  | @ -1300,6 +1300,12 @@ rb_match_busy(VALUE match) | |||
|     FL_SET(match, MATCH_BUSY); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| rb_match_unbusy(VALUE match) | ||||
| { | ||||
|     FL_UNSET(match, MATCH_BUSY); | ||||
| } | ||||
| 
 | ||||
| int | ||||
| rb_match_count(VALUE match) | ||||
| { | ||||
|  |  | |||
							
								
								
									
										9
									
								
								string.c
									
										
									
									
									
								
							
							
						
						
									
										9
									
								
								string.c
									
										
									
									
									
								
							|  | @ -7949,9 +7949,13 @@ rb_str_split_m(int argc, VALUE *argv, VALUE str) | |||
| 	long idx; | ||||
| 	int last_null = 0; | ||||
| 	struct re_registers *regs; | ||||
|         VALUE match = 0; | ||||
| 
 | ||||
| 	while ((end = rb_reg_search(spat, str, start, 0)) >= 0) { | ||||
| 	    regs = RMATCH_REGS(rb_backref_get()); | ||||
|         for (; (end = rb_reg_search(spat, str, start, 0)) >= 0; | ||||
|              (match ? (rb_match_unbusy(match), rb_backref_set(match)) : (void)0)) { | ||||
|             match = rb_backref_get(); | ||||
|             if (!result) rb_match_busy(match); | ||||
|             regs = RMATCH_REGS(match); | ||||
| 	    if (start == end && BEG(0) == END(0)) { | ||||
| 		if (!ptr) { | ||||
| 		    SPLIT_STR(0, 0); | ||||
|  | @ -7982,6 +7986,7 @@ rb_str_split_m(int argc, VALUE *argv, VALUE str) | |||
| 	    } | ||||
| 	    if (!NIL_P(limit) && lim <= ++i) break; | ||||
| 	} | ||||
|         if (match) rb_match_unbusy(match); | ||||
|     } | ||||
|     if (RSTRING_LEN(str) > 0 && (!NIL_P(limit) || RSTRING_LEN(str) > beg || lim < 0)) { | ||||
| 	SPLIT_STR(beg, RSTRING_LEN(str)-beg); | ||||
|  |  | |||
|  | @ -1784,6 +1784,9 @@ CODE | |||
| 
 | ||||
|     result = []; "".split(//, 1) {|s| result << s} | ||||
|     assert_equal([], result) | ||||
| 
 | ||||
|     result = []; "aaa,bbb,ccc,ddd".split(/,/) {|s| result << s.gsub(/./, "A")} | ||||
|     assert_equal(["AAA"]*4, result) | ||||
|   ensure | ||||
|     $; = fs | ||||
|   end | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| #define RUBY_VERSION "2.6.3" | ||||
| #define RUBY_RELEASE_DATE RUBY_RELEASE_YEAR_STR"-"RUBY_RELEASE_MONTH_STR"-"RUBY_RELEASE_DAY_STR | ||||
| #define RUBY_PATCHLEVEL 93 | ||||
| #define RUBY_PATCHLEVEL 94 | ||||
| 
 | ||||
| #define RUBY_RELEASE_YEAR 2019 | ||||
| #define RUBY_RELEASE_MONTH 8 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 nagachika
						nagachika