aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/parsing/Parser.cpp
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2016-03-30 20:42:05 +0800
committerchriseth <c@ethdev.com>2016-03-30 20:42:05 +0800
commit9ca29aa508a25b5ccd9261ab7fd441df27d7da5f (patch)
treedaca1d62b8253827bf8086dba3bd8679404a8660 /libsolidity/parsing/Parser.cpp
parent8236732e9a5d2535afd3a3573a70d5aab3da3efe (diff)
parentb336f6261c2373cc769bcafb0466a251576f3fdd (diff)
downloaddexon-solidity-9ca29aa508a25b5ccd9261ab7fd441df27d7da5f.tar
dexon-solidity-9ca29aa508a25b5ccd9261ab7fd441df27d7da5f.tar.gz
dexon-solidity-9ca29aa508a25b5ccd9261ab7fd441df27d7da5f.tar.bz2
dexon-solidity-9ca29aa508a25b5ccd9261ab7fd441df27d7da5f.tar.lz
dexon-solidity-9ca29aa508a25b5ccd9261ab7fd441df27d7da5f.tar.xz
dexon-solidity-9ca29aa508a25b5ccd9261ab7fd441df27d7da5f.tar.zst
dexon-solidity-9ca29aa508a25b5ccd9261ab7fd441df27d7da5f.zip
Merge pull request #430 from chriseth/assembly
Inline Assembly
Diffstat (limited to 'libsolidity/parsing/Parser.cpp')
-rw-r--r--libsolidity/parsing/Parser.cpp21
1 files changed, 21 insertions, 0 deletions
diff --git a/libsolidity/parsing/Parser.cpp b/libsolidity/parsing/Parser.cpp
index 7bda3610..bb50f47f 100644
--- a/libsolidity/parsing/Parser.cpp
+++ b/libsolidity/parsing/Parser.cpp
@@ -20,11 +20,13 @@
* Solidity parser.
*/
+#include <ctype.h>
#include <vector>
#include <libdevcore/Log.h>
#include <libevmasm/SourceLocation.h>
#include <libsolidity/parsing/Parser.h>
#include <libsolidity/parsing/Scanner.h>
+#include <libsolidity/inlineasm/AsmParser.h>
#include <libsolidity/interface/Exceptions.h>
#include <libsolidity/interface/InterfaceHandler.h>
@@ -712,6 +714,8 @@ ASTPointer<Statement> Parser::parseStatement()
m_scanner->next();
break;
}
+ case Token::Assembly:
+ return parseInlineAssembly(docString);
case Token::Identifier:
if (m_insideModifier && m_scanner->currentLiteral() == "_")
{
@@ -727,6 +731,23 @@ ASTPointer<Statement> Parser::parseStatement()
return statement;
}
+ASTPointer<InlineAssembly> Parser::parseInlineAssembly(ASTPointer<ASTString> const& _docString)
+{
+ ASTNodeFactory nodeFactory(*this);
+ expectToken(Token::Assembly);
+ if (m_scanner->currentToken() == Token::StringLiteral)
+ {
+ if (m_scanner->currentLiteral() != "evmasm")
+ fatalParserError("Only \"evmasm\" supported.");
+ m_scanner->next();
+ }
+
+ assembly::Parser asmParser(m_errors);
+ shared_ptr<assembly::Block> block = asmParser.parse(m_scanner);
+ nodeFactory.markEndPosition();
+ return nodeFactory.createNode<InlineAssembly>(_docString, block);
+}
+
ASTPointer<IfStatement> Parser::parseIfStatement(ASTPointer<ASTString> const& _docString)
{
ASTNodeFactory nodeFactory(*this);