mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Provide access to AssemblyStack's AST.
This commit is contained in:
		
							parent
							
								
									10888b21d8
								
							
						
					
					
						commit
						a344381d5e
					
				| @ -178,3 +178,11 @@ string AssemblyStack::print() const | |||||||
| 	solAssert(m_parserResult->code, ""); | 	solAssert(m_parserResult->code, ""); | ||||||
| 	return m_parserResult->toString(m_language == Language::Yul) + "\n"; | 	return m_parserResult->toString(m_language == Language::Yul) + "\n"; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | shared_ptr<Object> AssemblyStack::parserResult() const | ||||||
|  | { | ||||||
|  | 	solAssert(m_analysisSuccessful, "Analysis was not successful."); | ||||||
|  | 	solAssert(m_parserResult, ""); | ||||||
|  | 	solAssert(m_parserResult->code, ""); | ||||||
|  | 	return m_parserResult; | ||||||
|  | } | ||||||
|  | |||||||
| @ -82,6 +82,9 @@ public: | |||||||
| 	/// Pretty-print the input after having parsed it.
 | 	/// Pretty-print the input after having parsed it.
 | ||||||
| 	std::string print() const; | 	std::string print() const; | ||||||
| 
 | 
 | ||||||
|  | 	/// Return the parsed and analyzed object.
 | ||||||
|  | 	std::shared_ptr<Object> parserResult() const; | ||||||
|  | 
 | ||||||
| private: | private: | ||||||
| 	bool analyzeParsed(); | 	bool analyzeParsed(); | ||||||
| 	bool analyzeParsed(yul::Object& _object); | 	bool analyzeParsed(yul::Object& _object); | ||||||
|  | |||||||
| @ -29,6 +29,7 @@ | |||||||
| #include <libyul/AsmParser.h> | #include <libyul/AsmParser.h> | ||||||
| #include <libyul/AsmAnalysis.h> | #include <libyul/AsmAnalysis.h> | ||||||
| #include <libyul/AsmPrinter.h> | #include <libyul/AsmPrinter.h> | ||||||
|  | #include <libyul/AssemblyStack.h> | ||||||
| #include <libyul/backends/evm/EVMDialect.h> | #include <libyul/backends/evm/EVMDialect.h> | ||||||
| 
 | 
 | ||||||
| #include <liblangutil/Scanner.h> | #include <liblangutil/Scanner.h> | ||||||
| @ -63,33 +64,13 @@ void yul::test::printErrors(ErrorList const& _errors) | |||||||
| 
 | 
 | ||||||
| pair<shared_ptr<Block>, shared_ptr<yul::AsmAnalysisInfo>> yul::test::parse(string const& _source, bool _yul) | pair<shared_ptr<Block>, shared_ptr<yul::AsmAnalysisInfo>> yul::test::parse(string const& _source, bool _yul) | ||||||
| { | { | ||||||
| 	shared_ptr<Dialect> dialect = defaultDialect(_yul); | 	AssemblyStack stack( | ||||||
| 	ErrorList errors; |  | ||||||
| 	ErrorReporter errorReporter(errors); |  | ||||||
| 	auto scanner = make_shared<Scanner>(CharStream(_source, "")); |  | ||||||
| 	auto parserResult = yul::Parser(errorReporter, dialect).parse(scanner, false); |  | ||||||
| 	if (parserResult) |  | ||||||
| 	{ |  | ||||||
| 		BOOST_REQUIRE(errorReporter.errors().empty()); |  | ||||||
| 		auto analysisInfo = make_shared<yul::AsmAnalysisInfo>(); |  | ||||||
| 		yul::AsmAnalyzer analyzer( |  | ||||||
| 			*analysisInfo, |  | ||||||
| 			errorReporter, |  | ||||||
| 		dev::test::Options::get().evmVersion(), | 		dev::test::Options::get().evmVersion(), | ||||||
| 			boost::none, | 		_yul ? AssemblyStack::Language::Yul : AssemblyStack::Language::StrictAssembly | ||||||
| 			dialect |  | ||||||
| 	); | 	); | ||||||
| 		if (analyzer.analyze(*parserResult)) | 	if (!stack.parseAndAnalyze("", _source) || !stack.errors().empty()) | ||||||
| 		{ |  | ||||||
| 			BOOST_REQUIRE(errorReporter.errors().empty()); |  | ||||||
| 			return make_pair(parserResult, analysisInfo); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	printErrors(errors); |  | ||||||
| 		BOOST_FAIL("Invalid source."); | 		BOOST_FAIL("Invalid source."); | ||||||
| 
 | 	return make_pair(stack.parserResult()->code, stack.parserResult()->analysisInfo); | ||||||
| 	// Unreachable.
 |  | ||||||
| 	return {}; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| yul::Block yul::test::disambiguate(string const& _source, bool _yul) | yul::Block yul::test::disambiguate(string const& _source, bool _yul) | ||||||
|  | |||||||
| @ -46,6 +46,7 @@ | |||||||
| #include <libyul/AsmPrinter.h> | #include <libyul/AsmPrinter.h> | ||||||
| #include <libyul/AsmParser.h> | #include <libyul/AsmParser.h> | ||||||
| #include <libyul/AsmAnalysis.h> | #include <libyul/AsmAnalysis.h> | ||||||
|  | #include <libyul/AssemblyStack.h> | ||||||
| #include <liblangutil/SourceReferenceFormatter.h> | #include <liblangutil/SourceReferenceFormatter.h> | ||||||
| 
 | 
 | ||||||
| #include <liblangutil/ErrorReporter.h> | #include <liblangutil/ErrorReporter.h> | ||||||
| @ -97,9 +98,6 @@ YulOptimizerTest::YulOptimizerTest(string const& _filename) | |||||||
| 
 | 
 | ||||||
| bool YulOptimizerTest::run(ostream& _stream, string const& _linePrefix, bool const _formatted) | bool YulOptimizerTest::run(ostream& _stream, string const& _linePrefix, bool const _formatted) | ||||||
| { | { | ||||||
| 	yul::AsmPrinter printer{m_yul}; |  | ||||||
| 	shared_ptr<Block> ast; |  | ||||||
| 	shared_ptr<yul::AsmAnalysisInfo> analysisInfo; |  | ||||||
| 	if (!parse(_stream, _linePrefix, _formatted)) | 	if (!parse(_stream, _linePrefix, _formatted)) | ||||||
| 		return false; | 		return false; | ||||||
| 
 | 
 | ||||||
| @ -257,7 +255,7 @@ bool YulOptimizerTest::run(ostream& _stream, string const& _linePrefix, bool con | |||||||
| 		return false; | 		return false; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	m_obtainedResult = m_optimizerStep + "\n" + printer(*m_ast) + "\n"; | 	m_obtainedResult = m_optimizerStep + "\n" + AsmPrinter{m_yul}(*m_ast) + "\n"; | ||||||
| 
 | 
 | ||||||
| 	if (m_expectation != m_obtainedResult) | 	if (m_expectation != m_obtainedResult) | ||||||
| 	{ | 	{ | ||||||
| @ -292,31 +290,19 @@ void YulOptimizerTest::printIndented(ostream& _stream, string const& _output, st | |||||||
| 
 | 
 | ||||||
| bool YulOptimizerTest::parse(ostream& _stream, string const& _linePrefix, bool const _formatted) | bool YulOptimizerTest::parse(ostream& _stream, string const& _linePrefix, bool const _formatted) | ||||||
| { | { | ||||||
| 	m_dialect = m_yul ? yul::Dialect::yul() : yul::EVMDialect::strictAssemblyForEVMObjects(); | 	AssemblyStack stack( | ||||||
| 	ErrorList errors; | 		dev::test::Options::get().evmVersion(), | ||||||
| 	ErrorReporter errorReporter(errors); | 		m_yul ? AssemblyStack::Language::Yul : AssemblyStack::Language::StrictAssembly | ||||||
| 	shared_ptr<Scanner> scanner = make_shared<Scanner>(CharStream(m_source, "")); | 	); | ||||||
| 	m_ast = yul::Parser(errorReporter, m_dialect).parse(scanner, false); | 	if (!stack.parseAndAnalyze("", m_source) || !stack.errors().empty()) | ||||||
| 	if (!m_ast || !errorReporter.errors().empty()) |  | ||||||
| 	{ | 	{ | ||||||
| 		AnsiColorized(_stream, _formatted, {formatting::BOLD, formatting::RED}) << _linePrefix << "Error parsing source." << endl; | 		AnsiColorized(_stream, _formatted, {formatting::BOLD, formatting::RED}) << _linePrefix << "Error parsing source." << endl; | ||||||
| 		printErrors(_stream, errorReporter.errors()); | 		printErrors(_stream, stack.errors()); | ||||||
| 		return false; |  | ||||||
| 	} |  | ||||||
| 	m_analysisInfo = make_shared<yul::AsmAnalysisInfo>(); |  | ||||||
| 	yul::AsmAnalyzer analyzer( |  | ||||||
| 		*m_analysisInfo, |  | ||||||
| 		errorReporter, |  | ||||||
| 		dev::test::Options::get().evmVersion(), |  | ||||||
| 		boost::none, |  | ||||||
| 		m_dialect |  | ||||||
| 	); |  | ||||||
| 	if (!analyzer.analyze(*m_ast) || !errorReporter.errors().empty()) |  | ||||||
| 	{ |  | ||||||
| 		AnsiColorized(_stream, _formatted, {formatting::BOLD, formatting::RED}) << _linePrefix << "Error analyzing source." << endl; |  | ||||||
| 		printErrors(_stream, errorReporter.errors()); |  | ||||||
| 		return false; | 		return false; | ||||||
| 	} | 	} | ||||||
|  | 	m_dialect = m_yul ? Dialect::yul() : EVMDialect::strictAssemblyForEVMObjects(); | ||||||
|  | 	m_ast = stack.parserResult()->code; | ||||||
|  | 	m_analysisInfo = stack.parserResult()->analysisInfo; | ||||||
| 	return true; | 	return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user