aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Sinyagin <sinyagin.alexander@gmail.com>2016-08-17 23:20:17 +0800
committerAlex Sinyagin <sinyagin.alexander@gmail.com>2016-08-18 20:30:00 +0800
commit406f3a4b5d3827f09e5f1035b79627dcc0e907d9 (patch)
tree0a77440fc171dcfb69fb7de94bef08f019bf1af3
parente9c894c9f80b4a30560c1b88614cbd767abd908b (diff)
downloaddexon-solidity-406f3a4b5d3827f09e5f1035b79627dcc0e907d9.tar
dexon-solidity-406f3a4b5d3827f09e5f1035b79627dcc0e907d9.tar.gz
dexon-solidity-406f3a4b5d3827f09e5f1035b79627dcc0e907d9.tar.bz2
dexon-solidity-406f3a4b5d3827f09e5f1035b79627dcc0e907d9.tar.lz
dexon-solidity-406f3a4b5d3827f09e5f1035b79627dcc0e907d9.tar.xz
dexon-solidity-406f3a4b5d3827f09e5f1035b79627dcc0e907d9.tar.zst
dexon-solidity-406f3a4b5d3827f09e5f1035b79627dcc0e907d9.zip
Add ast json converter for PlaceholderStatement
-rw-r--r--libsolidity/ast/ASTJsonConverter.cpp11
-rw-r--r--libsolidity/ast/ASTJsonConverter.h2
-rw-r--r--test/libsolidity/ASTJSON.cpp13
3 files changed, 26 insertions, 0 deletions
diff --git a/libsolidity/ast/ASTJsonConverter.cpp b/libsolidity/ast/ASTJsonConverter.cpp
index e839a8ca..fc5ad498 100644
--- a/libsolidity/ast/ASTJsonConverter.cpp
+++ b/libsolidity/ast/ASTJsonConverter.cpp
@@ -236,6 +236,12 @@ bool ASTJsonConverter::visit(Block const& _node)
return true;
}
+bool ASTJsonConverter::visit(PlaceholderStatement const& _node)
+{
+ addJsonNode(_node, "Placeholder", {}, true);
+ return true;
+}
+
bool ASTJsonConverter::visit(IfStatement const& _node)
{
addJsonNode(_node, "IfStatement", {}, true);
@@ -480,6 +486,11 @@ void ASTJsonConverter::endVisit(Block const&)
goUp();
}
+void ASTJsonConverter::endVisit(PlaceholderStatement const&)
+{
+ goUp();
+}
+
void ASTJsonConverter::endVisit(IfStatement const&)
{
goUp();
diff --git a/libsolidity/ast/ASTJsonConverter.h b/libsolidity/ast/ASTJsonConverter.h
index 14e4d3ae..4f7e9e77 100644
--- a/libsolidity/ast/ASTJsonConverter.h
+++ b/libsolidity/ast/ASTJsonConverter.h
@@ -71,6 +71,7 @@ public:
bool visit(ArrayTypeName const& _node) override;
bool visit(InlineAssembly const& _node) override;
bool visit(Block const& _node) override;
+ bool visit(PlaceholderStatement const& _node) override;
bool visit(IfStatement const& _node) override;
bool visit(WhileStatement const& _node) override;
bool visit(ForStatement const& _node) override;
@@ -113,6 +114,7 @@ public:
void endVisit(ArrayTypeName const&) override;
void endVisit(InlineAssembly const&) override;
void endVisit(Block const&) override;
+ void endVisit(PlaceholderStatement const&) override;
void endVisit(IfStatement const&) override;
void endVisit(WhileStatement const&) override;
void endVisit(ForStatement const&) override;
diff --git a/test/libsolidity/ASTJSON.cpp b/test/libsolidity/ASTJSON.cpp
index 1a213b23..53222f65 100644
--- a/test/libsolidity/ASTJSON.cpp
+++ b/test/libsolidity/ASTJSON.cpp
@@ -182,6 +182,19 @@ BOOST_AUTO_TEST_CASE(array_type_name)
BOOST_CHECK_EQUAL(array["src"], "13:6:1");
}
+BOOST_AUTO_TEST_CASE(placeholder_statement)
+{
+ CompilerStack c;
+ c.addSource("a", "contract C { modifier M { _ } }");
+ c.parse();
+ map<string, unsigned> sourceIndices;
+ sourceIndices["a"] = 1;
+ Json::Value astJson = ASTJsonConverter(c.ast("a"), sourceIndices).json();
+ Json::Value placeholder = astJson["children"][0]["children"][0]["children"][1]["children"][0];
+ BOOST_CHECK_EQUAL(placeholder["name"], "Placeholder");
+ BOOST_CHECK_EQUAL(placeholder["src"], "26:1:1");
+}
+
BOOST_AUTO_TEST_SUITE_END()
}