aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/interface/AssemblyStack.cpp
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2017-06-08 21:45:41 +0800
committerGitHub <noreply@github.com>2017-06-08 21:45:41 +0800
commit21e0b69dcb189fb52ac4e38959801582e02ca8fd (patch)
treeb920c140d2bbedabfec3d5c401bc99968ddac91f /libsolidity/interface/AssemblyStack.cpp
parent51fcfbcf3f689ea8816e05b1ff9d17f391bc28e7 (diff)
parentaa310f9fec9bba90da2f1f57d77270dab673c6f4 (diff)
downloaddexon-solidity-21e0b69dcb189fb52ac4e38959801582e02ca8fd.tar
dexon-solidity-21e0b69dcb189fb52ac4e38959801582e02ca8fd.tar.gz
dexon-solidity-21e0b69dcb189fb52ac4e38959801582e02ca8fd.tar.bz2
dexon-solidity-21e0b69dcb189fb52ac4e38959801582e02ca8fd.tar.lz
dexon-solidity-21e0b69dcb189fb52ac4e38959801582e02ca8fd.tar.xz
dexon-solidity-21e0b69dcb189fb52ac4e38959801582e02ca8fd.tar.zst
dexon-solidity-21e0b69dcb189fb52ac4e38959801582e02ca8fd.zip
Merge pull request #2348 from ethereum/asmstack-analyze
Add analyze() to AssemblyStack
Diffstat (limited to 'libsolidity/interface/AssemblyStack.cpp')
-rw-r--r--libsolidity/interface/AssemblyStack.cpp17
1 files changed, 17 insertions, 0 deletions
diff --git a/libsolidity/interface/AssemblyStack.cpp b/libsolidity/interface/AssemblyStack.cpp
index b027ac3c..347de350 100644
--- a/libsolidity/interface/AssemblyStack.cpp
+++ b/libsolidity/interface/AssemblyStack.cpp
@@ -43,6 +43,7 @@ Scanner const& AssemblyStack::scanner() const
bool AssemblyStack::parseAndAnalyze(std::string const& _sourceName, std::string const& _source)
{
+ m_errors.clear();
m_analysisSuccessful = false;
m_scanner = make_shared<Scanner>(CharStream(_source), _sourceName);
m_parserResult = assembly::Parser(m_errorReporter, m_language == Language::JULIA).parse(m_scanner);
@@ -50,6 +51,22 @@ bool AssemblyStack::parseAndAnalyze(std::string const& _sourceName, std::string
return false;
solAssert(m_parserResult, "");
+ return analyzeParsed();
+}
+
+bool AssemblyStack::analyze(assembly::Block const& _block, Scanner const* _scanner)
+{
+ m_errors.clear();
+ m_analysisSuccessful = false;
+ if (_scanner)
+ m_scanner = make_shared<Scanner>(*_scanner);
+ m_parserResult = make_shared<assembly::Block>(_block);
+
+ return analyzeParsed();
+}
+
+bool AssemblyStack::analyzeParsed()
+{
m_analysisInfo = make_shared<assembly::AsmAnalysisInfo>();
assembly::AsmAnalyzer analyzer(*m_analysisInfo, m_errorReporter);
m_analysisSuccessful = analyzer.analyze(*m_parserResult);