mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Merge pull request #4323 from ethereum/compilerstack-cleanup
Reorder some of the flow in CompilerStack::compileContract for readability
This commit is contained in:
		
						commit
						edc0530452
					
				| @ -669,7 +669,7 @@ void CompilerStack::resolveImports() | ||||
| 	swap(m_sourceOrder, sourceOrder); | ||||
| } | ||||
| 
 | ||||
| string CompilerStack::absolutePath(string const& _path, string const& _reference) const | ||||
| string CompilerStack::absolutePath(string const& _path, string const& _reference) | ||||
| { | ||||
| 	using path = boost::filesystem::path; | ||||
| 	path p(_path); | ||||
| @ -711,9 +711,15 @@ void CompilerStack::compileContract( | ||||
| 	for (auto const* dependency: _contract.annotation().contractDependencies) | ||||
| 		compileContract(*dependency, _compiledContracts); | ||||
| 
 | ||||
| 	shared_ptr<Compiler> compiler = make_shared<Compiler>(m_evmVersion, m_optimize, m_optimizeRuns); | ||||
| 	Contract& compiledContract = m_contracts.at(_contract.fullyQualifiedName()); | ||||
| 
 | ||||
| 	shared_ptr<Compiler> compiler = make_shared<Compiler>(m_evmVersion, m_optimize, m_optimizeRuns); | ||||
| 	compiledContract.compiler = compiler; | ||||
| 
 | ||||
| 	string metadata = createMetadata(compiledContract); | ||||
| 	compiledContract.metadata = metadata; | ||||
| 
 | ||||
| 	// Prepare CBOR metadata for the bytecode
 | ||||
| 	bytes cborEncodedHash = | ||||
| 		// CBOR-encoding of the key "bzzr0"
 | ||||
| 		bytes{0x65, 'b', 'z', 'z', 'r', '0'}+ | ||||
| @ -734,8 +740,9 @@ void CompilerStack::compileContract( | ||||
| 	solAssert(cborEncodedMetadata.size() <= 0xffff, "Metadata too large"); | ||||
| 	// 16-bit big endian length
 | ||||
| 	cborEncodedMetadata += toCompactBigEndian(cborEncodedMetadata.size(), 2); | ||||
| 
 | ||||
| 	// Run optimiser and compile the contract.
 | ||||
| 	compiler->compileContract(_contract, _compiledContracts, cborEncodedMetadata); | ||||
| 	compiledContract.compiler = compiler; | ||||
| 
 | ||||
| 	try | ||||
| 	{ | ||||
| @ -763,7 +770,6 @@ void CompilerStack::compileContract( | ||||
| 		solAssert(false, "Assembly exception for deployed bytecode"); | ||||
| 	} | ||||
| 
 | ||||
| 	compiledContract.metadata = metadata; | ||||
| 	_compiledContracts[compiledContract.contract] = &compiler->assembly(); | ||||
| 
 | ||||
| 	try | ||||
|  | ||||
| @ -273,9 +273,9 @@ private: | ||||
| 	std::string applyRemapping(std::string const& _path, std::string const& _context); | ||||
| 	void resolveImports(); | ||||
| 	/// @returns the absolute path corresponding to @a _path relative to @a _reference.
 | ||||
| 	std::string absolutePath(std::string const& _path, std::string const& _reference) const; | ||||
| 	static std::string absolutePath(std::string const& _path, std::string const& _reference); | ||||
| 	/// Helper function to return path converted strings.
 | ||||
| 	std::string sanitizePath(std::string const& _path) const { return boost::filesystem::path(_path).generic_string(); } | ||||
| 	static std::string sanitizePath(std::string const& _path) { return boost::filesystem::path(_path).generic_string(); } | ||||
| 
 | ||||
| 	/// @returns true if the contract is requested to be compiled.
 | ||||
| 	bool isRequestedContract(ContractDefinition const& _contract) const; | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user