mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Simplify FunctionType constructors.
This commit is contained in:
		
							parent
							
								
									6b3a5e5d87
								
							
						
					
					
						commit
						917dd28eef
					
				| @ -2153,32 +2153,19 @@ FunctionType::FunctionType(FunctionDefinition const& _function, bool _isInternal | |||||||
| 	m_stateMutability(_function.stateMutability()), | 	m_stateMutability(_function.stateMutability()), | ||||||
| 	m_declaration(&_function) | 	m_declaration(&_function) | ||||||
| { | { | ||||||
| 	TypePointers params; |  | ||||||
| 	vector<string> paramNames; |  | ||||||
| 	TypePointers retParams; |  | ||||||
| 	vector<string> retParamNames; |  | ||||||
| 
 |  | ||||||
| 	if (_isInternal && m_stateMutability == StateMutability::Payable) | 	if (_isInternal && m_stateMutability == StateMutability::Payable) | ||||||
| 		m_stateMutability = StateMutability::NonPayable; | 		m_stateMutability = StateMutability::NonPayable; | ||||||
| 
 | 
 | ||||||
| 	params.reserve(_function.parameters().size()); |  | ||||||
| 	paramNames.reserve(_function.parameters().size()); |  | ||||||
| 	for (ASTPointer<VariableDeclaration> const& var: _function.parameters()) | 	for (ASTPointer<VariableDeclaration> const& var: _function.parameters()) | ||||||
| 	{ | 	{ | ||||||
| 		paramNames.push_back(var->name()); | 		m_parameterNames.push_back(var->name()); | ||||||
| 		params.push_back(var->annotation().type); | 		m_parameterTypes.push_back(var->annotation().type); | ||||||
| 	} | 	} | ||||||
| 	retParams.reserve(_function.returnParameters().size()); |  | ||||||
| 	retParamNames.reserve(_function.returnParameters().size()); |  | ||||||
| 	for (ASTPointer<VariableDeclaration> const& var: _function.returnParameters()) | 	for (ASTPointer<VariableDeclaration> const& var: _function.returnParameters()) | ||||||
| 	{ | 	{ | ||||||
| 		retParamNames.push_back(var->name()); | 		m_returnParameterNames.push_back(var->name()); | ||||||
| 		retParams.push_back(var->annotation().type); | 		m_returnParameterTypes.push_back(var->annotation().type); | ||||||
| 	} | 	} | ||||||
| 	swap(params, m_parameterTypes); |  | ||||||
| 	swap(paramNames, m_parameterNames); |  | ||||||
| 	swap(retParams, m_returnParameterTypes); |  | ||||||
| 	swap(retParamNames, m_returnParameterNames); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| FunctionType::FunctionType(VariableDeclaration const& _varDecl): | FunctionType::FunctionType(VariableDeclaration const& _varDecl): | ||||||
| @ -2186,16 +2173,14 @@ FunctionType::FunctionType(VariableDeclaration const& _varDecl): | |||||||
| 	m_stateMutability(StateMutability::View), | 	m_stateMutability(StateMutability::View), | ||||||
| 	m_declaration(&_varDecl) | 	m_declaration(&_varDecl) | ||||||
| { | { | ||||||
| 	TypePointers paramTypes; |  | ||||||
| 	vector<string> paramNames; |  | ||||||
| 	auto returnType = _varDecl.annotation().type; | 	auto returnType = _varDecl.annotation().type; | ||||||
| 
 | 
 | ||||||
| 	while (true) | 	while (true) | ||||||
| 	{ | 	{ | ||||||
| 		if (auto mappingType = dynamic_cast<MappingType const*>(returnType.get())) | 		if (auto mappingType = dynamic_cast<MappingType const*>(returnType.get())) | ||||||
| 		{ | 		{ | ||||||
| 			paramTypes.push_back(mappingType->keyType()); | 			m_parameterTypes.push_back(mappingType->keyType()); | ||||||
| 			paramNames.push_back(""); | 			m_parameterNames.push_back(""); | ||||||
| 			returnType = mappingType->valueType(); | 			returnType = mappingType->valueType(); | ||||||
| 		} | 		} | ||||||
| 		else if (auto arrayType = dynamic_cast<ArrayType const*>(returnType.get())) | 		else if (auto arrayType = dynamic_cast<ArrayType const*>(returnType.get())) | ||||||
| @ -2204,15 +2189,13 @@ FunctionType::FunctionType(VariableDeclaration const& _varDecl): | |||||||
| 				// Return byte arrays as as whole.
 | 				// Return byte arrays as as whole.
 | ||||||
| 				break; | 				break; | ||||||
| 			returnType = arrayType->baseType(); | 			returnType = arrayType->baseType(); | ||||||
| 			paramNames.push_back(""); | 			m_parameterNames.push_back(""); | ||||||
| 			paramTypes.push_back(make_shared<IntegerType>(256)); | 			m_parameterTypes.push_back(make_shared<IntegerType>(256)); | ||||||
| 		} | 		} | ||||||
| 		else | 		else | ||||||
| 			break; | 			break; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	TypePointers retParams; |  | ||||||
| 	vector<string> retParamNames; |  | ||||||
| 	if (auto structType = dynamic_cast<StructType const*>(returnType.get())) | 	if (auto structType = dynamic_cast<StructType const*>(returnType.get())) | ||||||
| 	{ | 	{ | ||||||
| 		for (auto const& member: structType->members(nullptr)) | 		for (auto const& member: structType->members(nullptr)) | ||||||
| @ -2223,24 +2206,19 @@ FunctionType::FunctionType(VariableDeclaration const& _varDecl): | |||||||
| 				if (auto arrayType = dynamic_cast<ArrayType const*>(member.type.get())) | 				if (auto arrayType = dynamic_cast<ArrayType const*>(member.type.get())) | ||||||
| 					if (!arrayType->isByteArray()) | 					if (!arrayType->isByteArray()) | ||||||
| 						continue; | 						continue; | ||||||
| 				retParams.push_back(member.type); | 				m_returnParameterTypes.push_back(member.type); | ||||||
| 				retParamNames.push_back(member.name); | 				m_returnParameterNames.push_back(member.name); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	else | 	else | ||||||
| 	{ | 	{ | ||||||
| 		retParams.push_back(ReferenceType::copyForLocationIfReference( | 		m_returnParameterTypes.push_back(ReferenceType::copyForLocationIfReference( | ||||||
| 			DataLocation::Memory, | 			DataLocation::Memory, | ||||||
| 			returnType | 			returnType | ||||||
| 		)); | 		)); | ||||||
| 		retParamNames.push_back(""); | 		m_returnParameterNames.push_back(""); | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	swap(paramTypes, m_parameterTypes); |  | ||||||
| 	swap(paramNames, m_parameterNames); |  | ||||||
| 	swap(retParams, m_returnParameterTypes); |  | ||||||
| 	swap(retParamNames, m_returnParameterNames); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| FunctionType::FunctionType(EventDefinition const& _event): | FunctionType::FunctionType(EventDefinition const& _event): | ||||||
| @ -2248,17 +2226,11 @@ FunctionType::FunctionType(EventDefinition const& _event): | |||||||
| 	m_stateMutability(StateMutability::NonPayable), | 	m_stateMutability(StateMutability::NonPayable), | ||||||
| 	m_declaration(&_event) | 	m_declaration(&_event) | ||||||
| { | { | ||||||
| 	TypePointers params; |  | ||||||
| 	vector<string> paramNames; |  | ||||||
| 	params.reserve(_event.parameters().size()); |  | ||||||
| 	paramNames.reserve(_event.parameters().size()); |  | ||||||
| 	for (ASTPointer<VariableDeclaration> const& var: _event.parameters()) | 	for (ASTPointer<VariableDeclaration> const& var: _event.parameters()) | ||||||
| 	{ | 	{ | ||||||
| 		paramNames.push_back(var->name()); | 		m_parameterNames.push_back(var->name()); | ||||||
| 		params.push_back(var->annotation().type); | 		m_parameterTypes.push_back(var->annotation().type); | ||||||
| 	} | 	} | ||||||
| 	swap(params, m_parameterTypes); |  | ||||||
| 	swap(paramNames, m_parameterNames); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| FunctionType::FunctionType(FunctionTypeName const& _typeName): | FunctionType::FunctionType(FunctionTypeName const& _typeName): | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user