mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Merge pull request #7431 from ethereum/fix_array_mapping
Fix ICE when pop dyn storage array of mapping
This commit is contained in:
		
						commit
						34a84f3a4f
					
				| @ -13,6 +13,7 @@ Compiler Features: | ||||
| 
 | ||||
| 
 | ||||
| Bugfixes: | ||||
|  * Fix internal error when popping a dynamic storage array of mappings. | ||||
| 
 | ||||
| 
 | ||||
| ### 0.5.11 (2019-08-12) | ||||
|  | ||||
| @ -896,11 +896,16 @@ void ArrayUtils::popStorageArrayElement(ArrayType const& _type) const | ||||
| 		// Stack: ArrayReference oldLength
 | ||||
| 		m_context << u256(1) << Instruction::SWAP1 << Instruction::SUB; | ||||
| 		// Stack ArrayReference newLength
 | ||||
| 		m_context << Instruction::DUP2 << Instruction::DUP2; | ||||
| 		// Stack ArrayReference newLength ArrayReference newLength;
 | ||||
| 		accessIndex(_type, false); | ||||
| 		// Stack: ArrayReference newLength storage_slot byte_offset
 | ||||
| 		StorageItem(m_context, *_type.baseType()).setToZero(SourceLocation(), true); | ||||
| 
 | ||||
| 		if (_type.baseType()->category() != Type::Category::Mapping) | ||||
| 		{ | ||||
| 			m_context << Instruction::DUP2 << Instruction::DUP2; | ||||
| 			// Stack ArrayReference newLength ArrayReference newLength;
 | ||||
| 			accessIndex(_type, false); | ||||
| 			// Stack: ArrayReference newLength storage_slot byte_offset
 | ||||
| 			StorageItem(m_context, *_type.baseType()).setToZero(SourceLocation(), true); | ||||
| 		} | ||||
| 
 | ||||
| 		// Stack: ArrayReference newLength
 | ||||
| 		m_context << Instruction::SWAP1 << Instruction::SSTORE; | ||||
| 	} | ||||
|  | ||||
| @ -0,0 +1,39 @@ | ||||
| contract C { | ||||
| 	mapping (uint => uint)[][] a; | ||||
| 
 | ||||
| 	function n1(uint key, uint value) public { | ||||
| 		a.length++; | ||||
| 		mapping (uint => uint)[] storage b = a[a.length - 1]; | ||||
| 		b.length++; | ||||
| 		b[b.length - 1][key] = value; | ||||
| 	} | ||||
| 
 | ||||
| 	function n2() public { | ||||
| 		a.length++; | ||||
| 		mapping (uint => uint)[] storage b = a[a.length - 1]; | ||||
| 		b.length++; | ||||
| 	} | ||||
| 
 | ||||
| 	function map(uint key) public view returns (uint) { | ||||
| 		mapping (uint => uint)[] storage b = a[a.length - 1]; | ||||
| 		return b[b.length - 1][key]; | ||||
| 	} | ||||
| 
 | ||||
| 	function p() public { | ||||
| 		a.pop(); | ||||
| 	} | ||||
| 
 | ||||
| 	function d() public returns (uint) { | ||||
| 		delete a; | ||||
| 		return a.length; | ||||
| 	} | ||||
| } | ||||
| // ---- | ||||
| // n1(uint256,uint256): 42, 64 -> | ||||
| // map(uint256): 42 -> 64 | ||||
| // p() -> | ||||
| // n2() -> | ||||
| // map(uint256): 42 -> 64 | ||||
| // d() -> 0 | ||||
| // n2() -> | ||||
| // map(uint256): 42 -> 64 | ||||
| @ -0,0 +1,34 @@ | ||||
| contract C { | ||||
| 	mapping (uint => uint)[] a; | ||||
| 
 | ||||
| 	function n1(uint key, uint value) public { | ||||
| 		a.length++; | ||||
| 		a[a.length - 1][key] = value; | ||||
| 	} | ||||
| 
 | ||||
| 	function n2() public { | ||||
| 		a.length++; | ||||
| 	} | ||||
| 
 | ||||
| 	function map(uint key) public view returns (uint) { | ||||
| 		return a[a.length - 1][key]; | ||||
| 	} | ||||
| 
 | ||||
| 	function p() public { | ||||
| 		a.pop(); | ||||
| 	} | ||||
| 
 | ||||
| 	function d() public returns (uint) { | ||||
| 		delete a; | ||||
| 		return a.length; | ||||
| 	} | ||||
| } | ||||
| // ---- | ||||
| // n1(uint256,uint256): 42, 64 -> | ||||
| // map(uint256): 42 -> 64 | ||||
| // p() -> | ||||
| // n2() -> | ||||
| // map(uint256): 42 -> 64 | ||||
| // d() -> 0 | ||||
| // n2() -> | ||||
| // map(uint256): 42 -> 64 | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user