mirror of
				https://github.com/ruby/ruby.git
				synced 2022-11-09 12:17:21 -05:00 
			
		
		
		
	compile.c: apply opt_str_freeze to String#-@ (uminus)
The same optimization used for "literal string".freeze can easily apply to uminus without introducing any compatibility problems. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@57828 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
		
							parent
							
								
									c51de81d8e
								
							
						
					
					
						commit
						568f8adfc8
					
				
					 2 changed files with 3 additions and 1 deletions
				
			
		|  | @ -178,6 +178,7 @@ tests = [ | |||
|   }, | ||||
| 
 | ||||
|   [ 'opt_str_freeze', %q{ 'true'.freeze }, ], | ||||
|   [ 'opt_str_freeze', %q{ -'true' }, ], | ||||
|   [ 'opt_str_freeze', <<~'},', ], # { | ||||
|     class String | ||||
|       def freeze | ||||
|  |  | |||
|  | @ -5188,7 +5188,8 @@ iseq_compile_each(rb_iseq_t *iseq, LINK_ANCHOR *const ret, NODE *node, int poppe | |||
| 	 *   "literal".freeze -> opt_str_freeze("literal") | ||||
| 	 */ | ||||
| 	if (node->nd_recv && nd_type(node->nd_recv) == NODE_STR && | ||||
| 	    node->nd_mid == idFreeze && node->nd_args == NULL && | ||||
| 	    (node->nd_mid == idFreeze || node->nd_mid == idUMinus) && | ||||
| 	    node->nd_args == NULL && | ||||
| 	    ISEQ_COMPILE_DATA(iseq)->current_block == NULL && | ||||
| 	    ISEQ_COMPILE_DATA(iseq)->option->specialized_instruction) { | ||||
| 	    VALUE str = rb_fstring(node->nd_recv->nd_lit); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 normal
						normal