mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			93 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/*
 | 
						|
	This file is part of solidity.
 | 
						|
 | 
						|
	solidity is free software: you can redistribute it and/or modify
 | 
						|
	it under the terms of the GNU General Public License as published by
 | 
						|
	the Free Software Foundation, either version 3 of the License, or
 | 
						|
	(at your option) any later version.
 | 
						|
 | 
						|
	solidity is distributed in the hope that it will be useful,
 | 
						|
	but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
						|
	GNU General Public License for more details.
 | 
						|
 | 
						|
	You should have received a copy of the GNU General Public License
 | 
						|
	along with solidity.  If not, see <http://www.gnu.org/licenses/>.
 | 
						|
*/
 | 
						|
/**
 | 
						|
 * @author Christian <c@ethdev.com>
 | 
						|
 * @date 2016
 | 
						|
 * Full-stack Solidity inline assember.
 | 
						|
 */
 | 
						|
 | 
						|
#pragma once
 | 
						|
 | 
						|
#include <libsolidity/interface/Exceptions.h>
 | 
						|
 | 
						|
#include <string>
 | 
						|
#include <functional>
 | 
						|
 | 
						|
namespace dev
 | 
						|
{
 | 
						|
namespace eth
 | 
						|
{
 | 
						|
class Assembly;
 | 
						|
}
 | 
						|
namespace solidity
 | 
						|
{
 | 
						|
class Scanner;
 | 
						|
namespace assembly
 | 
						|
{
 | 
						|
struct Block;
 | 
						|
struct Identifier;
 | 
						|
 | 
						|
enum class IdentifierContext { LValue, RValue };
 | 
						|
 | 
						|
/// Object that is used to resolve references and generate code for access to identifiers external
 | 
						|
/// to inline assembly (not used in standalone assembly mode).
 | 
						|
struct ExternalIdentifierAccess
 | 
						|
{
 | 
						|
	using Resolver = std::function<size_t(assembly::Identifier const&, IdentifierContext)>;
 | 
						|
	/// Resolve a an external reference given by the identifier in the given context.
 | 
						|
	/// @returns the size of the value (number of stack slots) or size_t(-1) if not found.
 | 
						|
	Resolver resolve;
 | 
						|
	using CodeGenerator = std::function<void(assembly::Identifier const&, IdentifierContext, eth::Assembly&)>;
 | 
						|
	/// Generate code for retrieving the value (rvalue context) or storing the value (lvalue context)
 | 
						|
	/// of an identifier. The code should be appended to the assembly. In rvalue context, the value is supposed
 | 
						|
	/// to be put onto the stack, in lvalue context, the value is assumed to be at the top of the stack.
 | 
						|
	CodeGenerator generateCode;
 | 
						|
};
 | 
						|
 | 
						|
class InlineAssemblyStack
 | 
						|
{
 | 
						|
public:
 | 
						|
	/// Parse the given inline assembly chunk starting with `{` and ending with the corresponding `}`.
 | 
						|
	/// @return false or error.
 | 
						|
	bool parse(
 | 
						|
		std::shared_ptr<Scanner> const& _scanner,
 | 
						|
		ExternalIdentifierAccess::Resolver const& _externalIdentifierResolver = ExternalIdentifierAccess::Resolver()
 | 
						|
	);
 | 
						|
	/// Converts the parser result back into a string form (not necessarily the same form
 | 
						|
	/// as the source form, but it should parse into the same parsed form again).
 | 
						|
	std::string toString();
 | 
						|
 | 
						|
	eth::Assembly assemble();
 | 
						|
 | 
						|
	/// Parse and assemble a string in one run - for use in Solidity code generation itself.
 | 
						|
	bool parseAndAssemble(
 | 
						|
		std::string const& _input,
 | 
						|
		eth::Assembly& _assembly,
 | 
						|
		ExternalIdentifierAccess const& _identifierAccess = ExternalIdentifierAccess()
 | 
						|
	);
 | 
						|
 | 
						|
	ErrorList const& errors() const { return m_errors; }
 | 
						|
 | 
						|
private:
 | 
						|
	std::shared_ptr<Block> m_parserResult;
 | 
						|
	ErrorList m_errors;
 | 
						|
};
 | 
						|
 | 
						|
}
 | 
						|
}
 | 
						|
}
 |