mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Fix SSA reverser in special case of declaration followed by self-assignment.
This commit is contained in:
		
							parent
							
								
									b747c26788
								
							
						
					
					
						commit
						f86c5da202
					
				| @ -56,18 +56,24 @@ void SSAReverser::operator()(Block& _block) | |||||||
| 					identifier && | 					identifier && | ||||||
| 					identifier->name == varDecl->variables.front().name | 					identifier->name == varDecl->variables.front().name | ||||||
| 				) | 				) | ||||||
| 					return make_vector<Statement>( | 				{ | ||||||
| 						Assignment{ | 					// in the special case a == a_1, just remove the assignment
 | ||||||
| 							std::move(assignment->location), | 					if (assignment->variableNames.front().name == identifier->name) | ||||||
| 							assignment->variableNames, | 						return make_vector<Statement>(std::move(_stmt1)); | ||||||
| 							std::move(varDecl->value) | 					else | ||||||
| 						}, | 						return make_vector<Statement>( | ||||||
| 						VariableDeclaration{ | 							Assignment{ | ||||||
| 							std::move(varDecl->location), | 								std::move(assignment->location), | ||||||
| 							std::move(varDecl->variables), | 								assignment->variableNames, | ||||||
| 							std::make_unique<Expression>(std::move(assignment->variableNames.front())) | 								std::move(varDecl->value) | ||||||
| 						} | 							}, | ||||||
| 					); | 							VariableDeclaration{ | ||||||
|  | 								std::move(varDecl->location), | ||||||
|  | 								std::move(varDecl->variables), | ||||||
|  | 								std::make_unique<Expression>(std::move(assignment->variableNames.front())) | ||||||
|  | 							} | ||||||
|  | 						); | ||||||
|  | 				} | ||||||
| 			} | 			} | ||||||
| 			// Replaces
 | 			// Replaces
 | ||||||
| 			//   let a_1 := E
 | 			//   let a_1 := E
 | ||||||
|  | |||||||
| @ -40,6 +40,13 @@ class AssignmentCounter; | |||||||
|  * 		a := E |  * 		a := E | ||||||
|  * 		let a_1 := a |  * 		let a_1 := a | ||||||
|  * |  * | ||||||
|  |  * 	In the special case | ||||||
|  |  * 		let a := E | ||||||
|  |  * 		a := a | ||||||
|  |  * | ||||||
|  |  * 	the redundant assignment "a := a" is removed. | ||||||
|  |  * | ||||||
|  |  * | ||||||
|  * Secondly, the SSA transform will rewrite |  * Secondly, the SSA transform will rewrite | ||||||
|  * |  * | ||||||
|  * 		let a := E |  * 		let a := E | ||||||
|  | |||||||
| @ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  |     let a := calldataload(0) | ||||||
|  |     a := a | ||||||
|  | } | ||||||
|  | // ==== | ||||||
|  | // step: ssaReverser | ||||||
|  | // ---- | ||||||
|  | // { let a := calldataload(0) } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user