mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Merge pull request #8574 from ethereum/immutableAssignAtDecl
Properly handle assignments of immutables at declaration.
This commit is contained in:
		
						commit
						c8f0629e94
					
				| @ -550,7 +550,7 @@ void ContractCompiler::initializeStateVariables(ContractDefinition const& _contr | ||||
| { | ||||
| 	solAssert(!_contract.isLibrary(), "Tried to initialize state variables of library."); | ||||
| 	for (VariableDeclaration const* variable: _contract.stateVariables()) | ||||
| 		if (variable->value() && !variable->isConstant() && !variable->immutable()) | ||||
| 		if (variable->value() && !variable->isConstant()) | ||||
| 			ExpressionCompiler(m_context, m_optimiserSettings.runOrderLiterals).appendStateVariableInitialization(*variable); | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -73,6 +73,9 @@ void ExpressionCompiler::appendStateVariableInitialization(VariableDeclaration c | ||||
| 		utils().convertType(*type, *_varDecl.annotation().type); | ||||
| 		type = _varDecl.annotation().type; | ||||
| 	} | ||||
| 	if (_varDecl.immutable()) | ||||
| 		ImmutableItem(m_context, _varDecl).storeValue(*type, _varDecl.location(), true); | ||||
| 	else | ||||
| 		StorageItem(m_context, _varDecl).storeValue(*type, _varDecl.location(), true); | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -183,6 +183,7 @@ void ImmutableItem::setToZero(SourceLocation const&, bool) const | ||||
| StorageItem::StorageItem(CompilerContext& _compilerContext, VariableDeclaration const& _declaration): | ||||
| 	StorageItem(_compilerContext, *_declaration.annotation().type) | ||||
| { | ||||
| 	solAssert(!_declaration.immutable(), ""); | ||||
| 	auto const& location = m_context.storageLocationOfVariable(_declaration); | ||||
| 	m_context << location.first << u256(location.second); | ||||
| } | ||||
|  | ||||
| @ -0,0 +1,8 @@ | ||||
| contract A { | ||||
| 	uint8 immutable a = 2; | ||||
| 	function f() public view returns (uint) { | ||||
| 		return a; | ||||
| 	} | ||||
| } | ||||
| // ---- | ||||
| // f() -> 2 | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user