mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Rename ASTJsonConverter to ASTJsonExporter
given that we have an ASTJsonImporter this name makes more sense.
This commit is contained in:
parent
b80f4baae2
commit
c88c74ceb8
@ -53,8 +53,8 @@ set(sources
|
|||||||
ast/ASTAnnotations.h
|
ast/ASTAnnotations.h
|
||||||
ast/ASTEnums.h
|
ast/ASTEnums.h
|
||||||
ast/ASTForward.h
|
ast/ASTForward.h
|
||||||
ast/ASTJsonConverter.cpp
|
ast/ASTJsonExporter.cpp
|
||||||
ast/ASTJsonConverter.h
|
ast/ASTJsonExporter.h
|
||||||
ast/ASTUtils.cpp
|
ast/ASTUtils.cpp
|
||||||
ast/ASTUtils.h
|
ast/ASTUtils.h
|
||||||
ast/ASTJsonImporter.cpp
|
ast/ASTJsonImporter.cpp
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
* Converts the AST into json format
|
* Converts the AST into json format
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <libsolidity/ast/ASTJsonConverter.h>
|
#include <libsolidity/ast/ASTJsonExporter.h>
|
||||||
|
|
||||||
#include <libsolidity/ast/AST.h>
|
#include <libsolidity/ast/AST.h>
|
||||||
#include <libsolidity/ast/TypeProvider.h>
|
#include <libsolidity/ast/TypeProvider.h>
|
||||||
@ -74,27 +74,27 @@ void addIfSet(std::vector<pair<string, Json::Value>>& _attributes, string const&
|
|||||||
namespace solidity::frontend
|
namespace solidity::frontend
|
||||||
{
|
{
|
||||||
|
|
||||||
ASTJsonConverter::ASTJsonConverter(CompilerStack::State _stackState, map<string, unsigned> _sourceIndices):
|
ASTJsonExporter::ASTJsonExporter(CompilerStack::State _stackState, map<string, unsigned> _sourceIndices):
|
||||||
m_stackState(_stackState),
|
m_stackState(_stackState),
|
||||||
m_sourceIndices(std::move(_sourceIndices))
|
m_sourceIndices(std::move(_sourceIndices))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void ASTJsonConverter::setJsonNode(
|
void ASTJsonExporter::setJsonNode(
|
||||||
ASTNode const& _node,
|
ASTNode const& _node,
|
||||||
string const& _nodeName,
|
string const& _nodeName,
|
||||||
initializer_list<pair<string, Json::Value>>&& _attributes
|
initializer_list<pair<string, Json::Value>>&& _attributes
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
ASTJsonConverter::setJsonNode(
|
ASTJsonExporter::setJsonNode(
|
||||||
_node,
|
_node,
|
||||||
_nodeName,
|
_nodeName,
|
||||||
std::vector<pair<string, Json::Value>>(std::move(_attributes))
|
std::vector<pair<string, Json::Value>>(std::move(_attributes))
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ASTJsonConverter::setJsonNode(
|
void ASTJsonExporter::setJsonNode(
|
||||||
ASTNode const& _node,
|
ASTNode const& _node,
|
||||||
string const& _nodeType,
|
string const& _nodeType,
|
||||||
std::vector<pair<string, Json::Value>>&& _attributes
|
std::vector<pair<string, Json::Value>>&& _attributes
|
||||||
@ -111,7 +111,7 @@ void ASTJsonConverter::setJsonNode(
|
|||||||
m_currentValue[e.first] = std::move(e.second);
|
m_currentValue[e.first] = std::move(e.second);
|
||||||
}
|
}
|
||||||
|
|
||||||
optional<size_t> ASTJsonConverter::sourceIndexFromLocation(SourceLocation const& _location) const
|
optional<size_t> ASTJsonExporter::sourceIndexFromLocation(SourceLocation const& _location) const
|
||||||
{
|
{
|
||||||
if (_location.sourceName && m_sourceIndices.count(*_location.sourceName))
|
if (_location.sourceName && m_sourceIndices.count(*_location.sourceName))
|
||||||
return m_sourceIndices.at(*_location.sourceName);
|
return m_sourceIndices.at(*_location.sourceName);
|
||||||
@ -119,7 +119,7 @@ optional<size_t> ASTJsonConverter::sourceIndexFromLocation(SourceLocation const&
|
|||||||
return nullopt;
|
return nullopt;
|
||||||
}
|
}
|
||||||
|
|
||||||
string ASTJsonConverter::sourceLocationToString(SourceLocation const& _location) const
|
string ASTJsonExporter::sourceLocationToString(SourceLocation const& _location) const
|
||||||
{
|
{
|
||||||
optional<size_t> sourceIndexOpt = sourceIndexFromLocation(_location);
|
optional<size_t> sourceIndexOpt = sourceIndexFromLocation(_location);
|
||||||
int length = -1;
|
int length = -1;
|
||||||
@ -128,12 +128,12 @@ string ASTJsonConverter::sourceLocationToString(SourceLocation const& _location)
|
|||||||
return to_string(_location.start) + ":" + to_string(length) + ":" + (sourceIndexOpt.has_value() ? to_string(sourceIndexOpt.value()) : "-1");
|
return to_string(_location.start) + ":" + to_string(length) + ":" + (sourceIndexOpt.has_value() ? to_string(sourceIndexOpt.value()) : "-1");
|
||||||
}
|
}
|
||||||
|
|
||||||
string ASTJsonConverter::namePathToString(std::vector<ASTString> const& _namePath)
|
string ASTJsonExporter::namePathToString(std::vector<ASTString> const& _namePath)
|
||||||
{
|
{
|
||||||
return boost::algorithm::join(_namePath, ".");
|
return boost::algorithm::join(_namePath, ".");
|
||||||
}
|
}
|
||||||
|
|
||||||
Json::Value ASTJsonConverter::typePointerToJson(Type const* _tp, bool _short)
|
Json::Value ASTJsonExporter::typePointerToJson(Type const* _tp, bool _short)
|
||||||
{
|
{
|
||||||
Json::Value typeDescriptions(Json::objectValue);
|
Json::Value typeDescriptions(Json::objectValue);
|
||||||
typeDescriptions["typeString"] = _tp ? Json::Value(_tp->toString(_short)) : Json::nullValue;
|
typeDescriptions["typeString"] = _tp ? Json::Value(_tp->toString(_short)) : Json::nullValue;
|
||||||
@ -141,7 +141,7 @@ Json::Value ASTJsonConverter::typePointerToJson(Type const* _tp, bool _short)
|
|||||||
return typeDescriptions;
|
return typeDescriptions;
|
||||||
|
|
||||||
}
|
}
|
||||||
Json::Value ASTJsonConverter::typePointerToJson(std::optional<FuncCallArguments> const& _tps)
|
Json::Value ASTJsonExporter::typePointerToJson(std::optional<FuncCallArguments> const& _tps)
|
||||||
{
|
{
|
||||||
if (_tps)
|
if (_tps)
|
||||||
{
|
{
|
||||||
@ -154,7 +154,7 @@ Json::Value ASTJsonConverter::typePointerToJson(std::optional<FuncCallArguments>
|
|||||||
return Json::nullValue;
|
return Json::nullValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ASTJsonConverter::appendExpressionAttributes(
|
void ASTJsonExporter::appendExpressionAttributes(
|
||||||
std::vector<pair<string, Json::Value>>& _attributes,
|
std::vector<pair<string, Json::Value>>& _attributes,
|
||||||
ExpressionAnnotation const& _annotation
|
ExpressionAnnotation const& _annotation
|
||||||
)
|
)
|
||||||
@ -174,7 +174,7 @@ void ASTJsonConverter::appendExpressionAttributes(
|
|||||||
_attributes += exprAttributes;
|
_attributes += exprAttributes;
|
||||||
}
|
}
|
||||||
|
|
||||||
Json::Value ASTJsonConverter::inlineAssemblyIdentifierToJson(pair<yul::Identifier const*, InlineAssemblyAnnotation::ExternalIdentifierInfo> _info) const
|
Json::Value ASTJsonExporter::inlineAssemblyIdentifierToJson(pair<yul::Identifier const*, InlineAssemblyAnnotation::ExternalIdentifierInfo> _info) const
|
||||||
{
|
{
|
||||||
Json::Value tuple(Json::objectValue);
|
Json::Value tuple(Json::objectValue);
|
||||||
tuple["src"] = sourceLocationToString(nativeLocationOf(*_info.first));
|
tuple["src"] = sourceLocationToString(nativeLocationOf(*_info.first));
|
||||||
@ -190,18 +190,18 @@ Json::Value ASTJsonConverter::inlineAssemblyIdentifierToJson(pair<yul::Identifie
|
|||||||
return tuple;
|
return tuple;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ASTJsonConverter::print(ostream& _stream, ASTNode const& _node, util::JsonFormat const& _format)
|
void ASTJsonExporter::print(ostream& _stream, ASTNode const& _node, util::JsonFormat const& _format)
|
||||||
{
|
{
|
||||||
_stream << util::jsonPrint(toJson(_node), _format);
|
_stream << util::jsonPrint(toJson(_node), _format);
|
||||||
}
|
}
|
||||||
|
|
||||||
Json::Value ASTJsonConverter::toJson(ASTNode const& _node)
|
Json::Value ASTJsonExporter::toJson(ASTNode const& _node)
|
||||||
{
|
{
|
||||||
_node.accept(*this);
|
_node.accept(*this);
|
||||||
return util::removeNullMembers(std::move(m_currentValue));
|
return util::removeNullMembers(std::move(m_currentValue));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(SourceUnit const& _node)
|
bool ASTJsonExporter::visit(SourceUnit const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("license", _node.licenseString() ? Json::Value(*_node.licenseString()) : Json::nullValue),
|
make_pair("license", _node.licenseString() ? Json::Value(*_node.licenseString()) : Json::nullValue),
|
||||||
@ -228,7 +228,7 @@ bool ASTJsonConverter::visit(SourceUnit const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(PragmaDirective const& _node)
|
bool ASTJsonExporter::visit(PragmaDirective const& _node)
|
||||||
{
|
{
|
||||||
Json::Value literals(Json::arrayValue);
|
Json::Value literals(Json::arrayValue);
|
||||||
for (auto const& literal: _node.literals())
|
for (auto const& literal: _node.literals())
|
||||||
@ -239,7 +239,7 @@ bool ASTJsonConverter::visit(PragmaDirective const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ImportDirective const& _node)
|
bool ASTJsonExporter::visit(ImportDirective const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("file", _node.path()),
|
make_pair("file", _node.path()),
|
||||||
@ -267,7 +267,7 @@ bool ASTJsonConverter::visit(ImportDirective const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ContractDefinition const& _node)
|
bool ASTJsonExporter::visit(ContractDefinition const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("name", _node.name()),
|
make_pair("name", _node.name()),
|
||||||
@ -292,7 +292,7 @@ bool ASTJsonConverter::visit(ContractDefinition const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(IdentifierPath const& _node)
|
bool ASTJsonExporter::visit(IdentifierPath const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "IdentifierPath", {
|
setJsonNode(_node, "IdentifierPath", {
|
||||||
make_pair("name", namePathToString(_node.path())),
|
make_pair("name", namePathToString(_node.path())),
|
||||||
@ -301,7 +301,7 @@ bool ASTJsonConverter::visit(IdentifierPath const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(InheritanceSpecifier const& _node)
|
bool ASTJsonExporter::visit(InheritanceSpecifier const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "InheritanceSpecifier", {
|
setJsonNode(_node, "InheritanceSpecifier", {
|
||||||
make_pair("baseName", toJson(_node.name())),
|
make_pair("baseName", toJson(_node.name())),
|
||||||
@ -310,7 +310,7 @@ bool ASTJsonConverter::visit(InheritanceSpecifier const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(UsingForDirective const& _node)
|
bool ASTJsonExporter::visit(UsingForDirective const& _node)
|
||||||
{
|
{
|
||||||
vector<pair<string, Json::Value>> attributes = {
|
vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("typeName", _node.typeName() ? toJson(*_node.typeName()) : Json::nullValue)
|
make_pair("typeName", _node.typeName() ? toJson(*_node.typeName()) : Json::nullValue)
|
||||||
@ -335,7 +335,7 @@ bool ASTJsonConverter::visit(UsingForDirective const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(StructDefinition const& _node)
|
bool ASTJsonExporter::visit(StructDefinition const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("name", _node.name()),
|
make_pair("name", _node.name()),
|
||||||
@ -352,7 +352,7 @@ bool ASTJsonConverter::visit(StructDefinition const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(EnumDefinition const& _node)
|
bool ASTJsonExporter::visit(EnumDefinition const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("name", _node.name()),
|
make_pair("name", _node.name()),
|
||||||
@ -367,7 +367,7 @@ bool ASTJsonConverter::visit(EnumDefinition const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(EnumValue const& _node)
|
bool ASTJsonExporter::visit(EnumValue const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "EnumValue", {
|
setJsonNode(_node, "EnumValue", {
|
||||||
make_pair("name", _node.name()),
|
make_pair("name", _node.name()),
|
||||||
@ -376,7 +376,7 @@ bool ASTJsonConverter::visit(EnumValue const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(UserDefinedValueTypeDefinition const& _node)
|
bool ASTJsonExporter::visit(UserDefinedValueTypeDefinition const& _node)
|
||||||
{
|
{
|
||||||
solAssert(_node.underlyingType(), "");
|
solAssert(_node.underlyingType(), "");
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
@ -391,7 +391,7 @@ bool ASTJsonConverter::visit(UserDefinedValueTypeDefinition const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ParameterList const& _node)
|
bool ASTJsonExporter::visit(ParameterList const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "ParameterList", {
|
setJsonNode(_node, "ParameterList", {
|
||||||
make_pair("parameters", toJson(_node.parameters()))
|
make_pair("parameters", toJson(_node.parameters()))
|
||||||
@ -399,7 +399,7 @@ bool ASTJsonConverter::visit(ParameterList const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(OverrideSpecifier const& _node)
|
bool ASTJsonExporter::visit(OverrideSpecifier const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "OverrideSpecifier", {
|
setJsonNode(_node, "OverrideSpecifier", {
|
||||||
make_pair("overrides", toJson(_node.overrides()))
|
make_pair("overrides", toJson(_node.overrides()))
|
||||||
@ -407,7 +407,7 @@ bool ASTJsonConverter::visit(OverrideSpecifier const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(FunctionDefinition const& _node)
|
bool ASTJsonExporter::visit(FunctionDefinition const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("name", _node.name()),
|
make_pair("name", _node.name()),
|
||||||
@ -445,7 +445,7 @@ bool ASTJsonConverter::visit(FunctionDefinition const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(VariableDeclaration const& _node)
|
bool ASTJsonExporter::visit(VariableDeclaration const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("name", _node.name()),
|
make_pair("name", _node.name()),
|
||||||
@ -473,7 +473,7 @@ bool ASTJsonConverter::visit(VariableDeclaration const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ModifierDefinition const& _node)
|
bool ASTJsonExporter::visit(ModifierDefinition const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("name", _node.name()),
|
make_pair("name", _node.name()),
|
||||||
@ -491,7 +491,7 @@ bool ASTJsonConverter::visit(ModifierDefinition const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ModifierInvocation const& _node)
|
bool ASTJsonExporter::visit(ModifierInvocation const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes{
|
std::vector<pair<string, Json::Value>> attributes{
|
||||||
make_pair("modifierName", toJson(_node.name())),
|
make_pair("modifierName", toJson(_node.name())),
|
||||||
@ -508,7 +508,7 @@ bool ASTJsonConverter::visit(ModifierInvocation const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(EventDefinition const& _node)
|
bool ASTJsonExporter::visit(EventDefinition const& _node)
|
||||||
{
|
{
|
||||||
m_inEvent = true;
|
m_inEvent = true;
|
||||||
std::vector<pair<string, Json::Value>> _attributes = {
|
std::vector<pair<string, Json::Value>> _attributes = {
|
||||||
@ -529,7 +529,7 @@ bool ASTJsonConverter::visit(EventDefinition const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ErrorDefinition const& _node)
|
bool ASTJsonExporter::visit(ErrorDefinition const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> _attributes = {
|
std::vector<pair<string, Json::Value>> _attributes = {
|
||||||
make_pair("name", _node.name()),
|
make_pair("name", _node.name()),
|
||||||
@ -544,7 +544,7 @@ bool ASTJsonConverter::visit(ErrorDefinition const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ElementaryTypeName const& _node)
|
bool ASTJsonExporter::visit(ElementaryTypeName const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("name", _node.typeName().toString()),
|
make_pair("name", _node.typeName().toString()),
|
||||||
@ -558,7 +558,7 @@ bool ASTJsonConverter::visit(ElementaryTypeName const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(UserDefinedTypeName const& _node)
|
bool ASTJsonExporter::visit(UserDefinedTypeName const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "UserDefinedTypeName", {
|
setJsonNode(_node, "UserDefinedTypeName", {
|
||||||
make_pair("pathNode", toJson(_node.pathNode())),
|
make_pair("pathNode", toJson(_node.pathNode())),
|
||||||
@ -568,7 +568,7 @@ bool ASTJsonConverter::visit(UserDefinedTypeName const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(FunctionTypeName const& _node)
|
bool ASTJsonExporter::visit(FunctionTypeName const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "FunctionTypeName", {
|
setJsonNode(_node, "FunctionTypeName", {
|
||||||
make_pair("visibility", Declaration::visibilityToString(_node.visibility())),
|
make_pair("visibility", Declaration::visibilityToString(_node.visibility())),
|
||||||
@ -580,7 +580,7 @@ bool ASTJsonConverter::visit(FunctionTypeName const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(Mapping const& _node)
|
bool ASTJsonExporter::visit(Mapping const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "Mapping", {
|
setJsonNode(_node, "Mapping", {
|
||||||
make_pair("keyType", toJson(_node.keyType())),
|
make_pair("keyType", toJson(_node.keyType())),
|
||||||
@ -590,7 +590,7 @@ bool ASTJsonConverter::visit(Mapping const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ArrayTypeName const& _node)
|
bool ASTJsonExporter::visit(ArrayTypeName const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "ArrayTypeName", {
|
setJsonNode(_node, "ArrayTypeName", {
|
||||||
make_pair("baseType", toJson(_node.baseType())),
|
make_pair("baseType", toJson(_node.baseType())),
|
||||||
@ -600,7 +600,7 @@ bool ASTJsonConverter::visit(ArrayTypeName const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(InlineAssembly const& _node)
|
bool ASTJsonExporter::visit(InlineAssembly const& _node)
|
||||||
{
|
{
|
||||||
vector<pair<string, Json::Value>> externalReferences;
|
vector<pair<string, Json::Value>> externalReferences;
|
||||||
|
|
||||||
@ -638,7 +638,7 @@ bool ASTJsonConverter::visit(InlineAssembly const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(Block const& _node)
|
bool ASTJsonExporter::visit(Block const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, _node.unchecked() ? "UncheckedBlock" : "Block", {
|
setJsonNode(_node, _node.unchecked() ? "UncheckedBlock" : "Block", {
|
||||||
make_pair("statements", toJson(_node.statements()))
|
make_pair("statements", toJson(_node.statements()))
|
||||||
@ -646,13 +646,13 @@ bool ASTJsonConverter::visit(Block const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(PlaceholderStatement const& _node)
|
bool ASTJsonExporter::visit(PlaceholderStatement const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "PlaceholderStatement", {});
|
setJsonNode(_node, "PlaceholderStatement", {});
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(IfStatement const& _node)
|
bool ASTJsonExporter::visit(IfStatement const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "IfStatement", {
|
setJsonNode(_node, "IfStatement", {
|
||||||
make_pair("condition", toJson(_node.condition())),
|
make_pair("condition", toJson(_node.condition())),
|
||||||
@ -662,7 +662,7 @@ bool ASTJsonConverter::visit(IfStatement const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(TryCatchClause const& _node)
|
bool ASTJsonExporter::visit(TryCatchClause const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "TryCatchClause", {
|
setJsonNode(_node, "TryCatchClause", {
|
||||||
make_pair("errorName", _node.errorName()),
|
make_pair("errorName", _node.errorName()),
|
||||||
@ -672,7 +672,7 @@ bool ASTJsonConverter::visit(TryCatchClause const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(TryStatement const& _node)
|
bool ASTJsonExporter::visit(TryStatement const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "TryStatement", {
|
setJsonNode(_node, "TryStatement", {
|
||||||
make_pair("externalCall", toJson(_node.externalCall())),
|
make_pair("externalCall", toJson(_node.externalCall())),
|
||||||
@ -681,7 +681,7 @@ bool ASTJsonConverter::visit(TryStatement const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(WhileStatement const& _node)
|
bool ASTJsonExporter::visit(WhileStatement const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(
|
setJsonNode(
|
||||||
_node,
|
_node,
|
||||||
@ -694,7 +694,7 @@ bool ASTJsonConverter::visit(WhileStatement const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ForStatement const& _node)
|
bool ASTJsonExporter::visit(ForStatement const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "ForStatement", {
|
setJsonNode(_node, "ForStatement", {
|
||||||
make_pair("initializationExpression", toJsonOrNull(_node.initializationExpression())),
|
make_pair("initializationExpression", toJsonOrNull(_node.initializationExpression())),
|
||||||
@ -705,19 +705,19 @@ bool ASTJsonConverter::visit(ForStatement const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(Continue const& _node)
|
bool ASTJsonExporter::visit(Continue const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "Continue", {});
|
setJsonNode(_node, "Continue", {});
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(Break const& _node)
|
bool ASTJsonExporter::visit(Break const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "Break", {});
|
setJsonNode(_node, "Break", {});
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(Return const& _node)
|
bool ASTJsonExporter::visit(Return const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "Return", {
|
setJsonNode(_node, "Return", {
|
||||||
make_pair("expression", toJsonOrNull(_node.expression())),
|
make_pair("expression", toJsonOrNull(_node.expression())),
|
||||||
@ -726,13 +726,13 @@ bool ASTJsonConverter::visit(Return const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(Throw const& _node)
|
bool ASTJsonExporter::visit(Throw const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "Throw", {});
|
setJsonNode(_node, "Throw", {});
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(EmitStatement const& _node)
|
bool ASTJsonExporter::visit(EmitStatement const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "EmitStatement", {
|
setJsonNode(_node, "EmitStatement", {
|
||||||
make_pair("eventCall", toJson(_node.eventCall()))
|
make_pair("eventCall", toJson(_node.eventCall()))
|
||||||
@ -740,7 +740,7 @@ bool ASTJsonConverter::visit(EmitStatement const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(RevertStatement const& _node)
|
bool ASTJsonExporter::visit(RevertStatement const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "RevertStatement", {
|
setJsonNode(_node, "RevertStatement", {
|
||||||
make_pair("errorCall", toJson(_node.errorCall()))
|
make_pair("errorCall", toJson(_node.errorCall()))
|
||||||
@ -748,7 +748,7 @@ bool ASTJsonConverter::visit(RevertStatement const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(VariableDeclarationStatement const& _node)
|
bool ASTJsonExporter::visit(VariableDeclarationStatement const& _node)
|
||||||
{
|
{
|
||||||
Json::Value varDecs(Json::arrayValue);
|
Json::Value varDecs(Json::arrayValue);
|
||||||
for (auto const& v: _node.declarations())
|
for (auto const& v: _node.declarations())
|
||||||
@ -761,7 +761,7 @@ bool ASTJsonConverter::visit(VariableDeclarationStatement const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ExpressionStatement const& _node)
|
bool ASTJsonExporter::visit(ExpressionStatement const& _node)
|
||||||
{
|
{
|
||||||
setJsonNode(_node, "ExpressionStatement", {
|
setJsonNode(_node, "ExpressionStatement", {
|
||||||
make_pair("expression", toJson(_node.expression()))
|
make_pair("expression", toJson(_node.expression()))
|
||||||
@ -769,7 +769,7 @@ bool ASTJsonConverter::visit(ExpressionStatement const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(Conditional const& _node)
|
bool ASTJsonExporter::visit(Conditional const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("condition", toJson(_node.condition())),
|
make_pair("condition", toJson(_node.condition())),
|
||||||
@ -781,7 +781,7 @@ bool ASTJsonConverter::visit(Conditional const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(Assignment const& _node)
|
bool ASTJsonExporter::visit(Assignment const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("operator", TokenTraits::toString(_node.assignmentOperator())),
|
make_pair("operator", TokenTraits::toString(_node.assignmentOperator())),
|
||||||
@ -793,7 +793,7 @@ bool ASTJsonConverter::visit(Assignment const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(TupleExpression const& _node)
|
bool ASTJsonExporter::visit(TupleExpression const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("isInlineArray", Json::Value(_node.isInlineArray())),
|
make_pair("isInlineArray", Json::Value(_node.isInlineArray())),
|
||||||
@ -804,7 +804,7 @@ bool ASTJsonConverter::visit(TupleExpression const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(UnaryOperation const& _node)
|
bool ASTJsonExporter::visit(UnaryOperation const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("prefix", _node.isPrefixOperation()),
|
make_pair("prefix", _node.isPrefixOperation()),
|
||||||
@ -816,7 +816,7 @@ bool ASTJsonConverter::visit(UnaryOperation const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(BinaryOperation const& _node)
|
bool ASTJsonExporter::visit(BinaryOperation const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("operator", TokenTraits::toString(_node.getOperator())),
|
make_pair("operator", TokenTraits::toString(_node.getOperator())),
|
||||||
@ -829,7 +829,7 @@ bool ASTJsonConverter::visit(BinaryOperation const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(FunctionCall const& _node)
|
bool ASTJsonExporter::visit(FunctionCall const& _node)
|
||||||
{
|
{
|
||||||
Json::Value names(Json::arrayValue);
|
Json::Value names(Json::arrayValue);
|
||||||
for (auto const& name: _node.names())
|
for (auto const& name: _node.names())
|
||||||
@ -852,7 +852,7 @@ bool ASTJsonConverter::visit(FunctionCall const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(FunctionCallOptions const& _node)
|
bool ASTJsonExporter::visit(FunctionCallOptions const& _node)
|
||||||
{
|
{
|
||||||
Json::Value names(Json::arrayValue);
|
Json::Value names(Json::arrayValue);
|
||||||
for (auto const& name: _node.names())
|
for (auto const& name: _node.names())
|
||||||
@ -869,7 +869,7 @@ bool ASTJsonConverter::visit(FunctionCallOptions const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(NewExpression const& _node)
|
bool ASTJsonExporter::visit(NewExpression const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("typeName", toJson(_node.typeName()))
|
make_pair("typeName", toJson(_node.typeName()))
|
||||||
@ -879,7 +879,7 @@ bool ASTJsonConverter::visit(NewExpression const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(MemberAccess const& _node)
|
bool ASTJsonExporter::visit(MemberAccess const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("memberName", _node.memberName()),
|
make_pair("memberName", _node.memberName()),
|
||||||
@ -891,7 +891,7 @@ bool ASTJsonConverter::visit(MemberAccess const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(IndexAccess const& _node)
|
bool ASTJsonExporter::visit(IndexAccess const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("baseExpression", toJson(_node.baseExpression())),
|
make_pair("baseExpression", toJson(_node.baseExpression())),
|
||||||
@ -902,7 +902,7 @@ bool ASTJsonConverter::visit(IndexAccess const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(IndexRangeAccess const& _node)
|
bool ASTJsonExporter::visit(IndexRangeAccess const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("baseExpression", toJson(_node.baseExpression())),
|
make_pair("baseExpression", toJson(_node.baseExpression())),
|
||||||
@ -914,7 +914,7 @@ bool ASTJsonConverter::visit(IndexRangeAccess const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(Identifier const& _node)
|
bool ASTJsonExporter::visit(Identifier const& _node)
|
||||||
{
|
{
|
||||||
Json::Value overloads(Json::arrayValue);
|
Json::Value overloads(Json::arrayValue);
|
||||||
for (auto const& dec: _node.annotation().overloadedDeclarations)
|
for (auto const& dec: _node.annotation().overloadedDeclarations)
|
||||||
@ -929,7 +929,7 @@ bool ASTJsonConverter::visit(Identifier const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(ElementaryTypeNameExpression const& _node)
|
bool ASTJsonExporter::visit(ElementaryTypeNameExpression const& _node)
|
||||||
{
|
{
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
make_pair("typeName", toJson(_node.type()))
|
make_pair("typeName", toJson(_node.type()))
|
||||||
@ -939,7 +939,7 @@ bool ASTJsonConverter::visit(ElementaryTypeNameExpression const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(Literal const& _node)
|
bool ASTJsonExporter::visit(Literal const& _node)
|
||||||
{
|
{
|
||||||
Json::Value value{_node.value()};
|
Json::Value value{_node.value()};
|
||||||
if (!util::validateUTF8(_node.value()))
|
if (!util::validateUTF8(_node.value()))
|
||||||
@ -961,7 +961,7 @@ bool ASTJsonConverter::visit(Literal const& _node)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ASTJsonConverter::visit(StructuredDocumentation const& _node)
|
bool ASTJsonExporter::visit(StructuredDocumentation const& _node)
|
||||||
{
|
{
|
||||||
Json::Value text{*_node.text()};
|
Json::Value text{*_node.text()};
|
||||||
std::vector<pair<string, Json::Value>> attributes = {
|
std::vector<pair<string, Json::Value>> attributes = {
|
||||||
@ -973,12 +973,12 @@ bool ASTJsonConverter::visit(StructuredDocumentation const& _node)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void ASTJsonConverter::endVisit(EventDefinition const&)
|
void ASTJsonExporter::endVisit(EventDefinition const&)
|
||||||
{
|
{
|
||||||
m_inEvent = false;
|
m_inEvent = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
string ASTJsonConverter::location(VariableDeclaration::Location _location)
|
string ASTJsonExporter::location(VariableDeclaration::Location _location)
|
||||||
{
|
{
|
||||||
switch (_location)
|
switch (_location)
|
||||||
{
|
{
|
||||||
@ -995,7 +995,7 @@ string ASTJsonConverter::location(VariableDeclaration::Location _location)
|
|||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
string ASTJsonConverter::contractKind(ContractKind _kind)
|
string ASTJsonExporter::contractKind(ContractKind _kind)
|
||||||
{
|
{
|
||||||
switch (_kind)
|
switch (_kind)
|
||||||
{
|
{
|
||||||
@ -1011,7 +1011,7 @@ string ASTJsonConverter::contractKind(ContractKind _kind)
|
|||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
string ASTJsonConverter::functionCallKind(FunctionCallKind _kind)
|
string ASTJsonExporter::functionCallKind(FunctionCallKind _kind)
|
||||||
{
|
{
|
||||||
switch (_kind)
|
switch (_kind)
|
||||||
{
|
{
|
||||||
@ -1026,7 +1026,7 @@ string ASTJsonConverter::functionCallKind(FunctionCallKind _kind)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
string ASTJsonConverter::literalTokenKind(Token _token)
|
string ASTJsonExporter::literalTokenKind(Token _token)
|
||||||
{
|
{
|
||||||
switch (_token)
|
switch (_token)
|
||||||
{
|
{
|
||||||
@ -1046,12 +1046,12 @@ string ASTJsonConverter::literalTokenKind(Token _token)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
string ASTJsonConverter::type(Expression const& _expression)
|
string ASTJsonExporter::type(Expression const& _expression)
|
||||||
{
|
{
|
||||||
return _expression.annotation().type ? _expression.annotation().type->toString() : "Unknown";
|
return _expression.annotation().type ? _expression.annotation().type->toString() : "Unknown";
|
||||||
}
|
}
|
||||||
|
|
||||||
string ASTJsonConverter::type(VariableDeclaration const& _varDecl)
|
string ASTJsonExporter::type(VariableDeclaration const& _varDecl)
|
||||||
{
|
{
|
||||||
return _varDecl.annotation().type ? _varDecl.annotation().type->toString() : "Unknown";
|
return _varDecl.annotation().type ? _varDecl.annotation().type->toString() : "Unknown";
|
||||||
}
|
}
|
@ -48,13 +48,13 @@ namespace solidity::frontend
|
|||||||
/**
|
/**
|
||||||
* Converter of the AST into JSON format
|
* Converter of the AST into JSON format
|
||||||
*/
|
*/
|
||||||
class ASTJsonConverter: public ASTConstVisitor
|
class ASTJsonExporter: public ASTConstVisitor
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/// Create a converter to JSON for the given abstract syntax tree.
|
/// Create a converter to JSON for the given abstract syntax tree.
|
||||||
/// @a _stackState state of the compiler stack to avoid outputting incomplete data
|
/// @a _stackState state of the compiler stack to avoid outputting incomplete data
|
||||||
/// @a _sourceIndices is used to abbreviate source names in source locations.
|
/// @a _sourceIndices is used to abbreviate source names in source locations.
|
||||||
explicit ASTJsonConverter(
|
explicit ASTJsonExporter(
|
||||||
CompilerStack::State _stackState,
|
CompilerStack::State _stackState,
|
||||||
std::map<std::string, unsigned> _sourceIndices = std::map<std::string, unsigned>()
|
std::map<std::string, unsigned> _sourceIndices = std::map<std::string, unsigned>()
|
||||||
);
|
);
|
@ -24,7 +24,7 @@
|
|||||||
#include <libsolidity/interface/StandardCompiler.h>
|
#include <libsolidity/interface/StandardCompiler.h>
|
||||||
#include <libsolidity/interface/ImportRemapper.h>
|
#include <libsolidity/interface/ImportRemapper.h>
|
||||||
|
|
||||||
#include <libsolidity/ast/ASTJsonConverter.h>
|
#include <libsolidity/ast/ASTJsonExporter.h>
|
||||||
#include <libyul/YulStack.h>
|
#include <libyul/YulStack.h>
|
||||||
#include <libyul/Exceptions.h>
|
#include <libyul/Exceptions.h>
|
||||||
#include <libyul/optimiser/Suite.h>
|
#include <libyul/optimiser/Suite.h>
|
||||||
@ -1254,7 +1254,7 @@ Json::Value StandardCompiler::compileSolidity(StandardCompiler::InputsAndSetting
|
|||||||
Json::Value sourceResult = Json::objectValue;
|
Json::Value sourceResult = Json::objectValue;
|
||||||
sourceResult["id"] = sourceIndex++;
|
sourceResult["id"] = sourceIndex++;
|
||||||
if (isArtifactRequested(_inputsAndSettings.outputSelection, sourceName, "", "ast", wildcardMatchesExperimental))
|
if (isArtifactRequested(_inputsAndSettings.outputSelection, sourceName, "", "ast", wildcardMatchesExperimental))
|
||||||
sourceResult["ast"] = ASTJsonConverter(compilerStack.state(), compilerStack.sourceIndices()).toJson(compilerStack.ast(sourceName));
|
sourceResult["ast"] = ASTJsonExporter(compilerStack.state(), compilerStack.sourceIndices()).toJson(compilerStack.ast(sourceName));
|
||||||
output["sources"][sourceName] = sourceResult;
|
output["sources"][sourceName] = sourceResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
#include "solidity/BuildInfo.h"
|
#include "solidity/BuildInfo.h"
|
||||||
|
|
||||||
#include <libsolidity/interface/Version.h>
|
#include <libsolidity/interface/Version.h>
|
||||||
#include <libsolidity/ast/ASTJsonConverter.h>
|
#include <libsolidity/ast/ASTJsonExporter.h>
|
||||||
#include <libsolidity/ast/ASTJsonImporter.h>
|
#include <libsolidity/ast/ASTJsonImporter.h>
|
||||||
#include <libsolidity/analysis/NameAndTypeResolver.h>
|
#include <libsolidity/analysis/NameAndTypeResolver.h>
|
||||||
#include <libsolidity/interface/CompilerStack.h>
|
#include <libsolidity/interface/CompilerStack.h>
|
||||||
@ -863,7 +863,7 @@ void CommandLineInterface::handleCombinedJSON()
|
|||||||
output[g_strSources] = Json::Value(Json::objectValue);
|
output[g_strSources] = Json::Value(Json::objectValue);
|
||||||
for (auto const& sourceCode: m_fileReader.sourceUnits())
|
for (auto const& sourceCode: m_fileReader.sourceUnits())
|
||||||
{
|
{
|
||||||
ASTJsonConverter converter(m_compiler->state(), m_compiler->sourceIndices());
|
ASTJsonExporter converter(m_compiler->state(), m_compiler->sourceIndices());
|
||||||
output[g_strSources][sourceCode.first] = Json::Value(Json::objectValue);
|
output[g_strSources][sourceCode.first] = Json::Value(Json::objectValue);
|
||||||
output[g_strSources][sourceCode.first]["AST"] = converter.toJson(m_compiler->ast(sourceCode.first));
|
output[g_strSources][sourceCode.first]["AST"] = converter.toJson(m_compiler->ast(sourceCode.first));
|
||||||
}
|
}
|
||||||
@ -893,7 +893,7 @@ void CommandLineInterface::handleAst()
|
|||||||
{
|
{
|
||||||
stringstream data;
|
stringstream data;
|
||||||
string postfix = "";
|
string postfix = "";
|
||||||
ASTJsonConverter(m_compiler->state(), m_compiler->sourceIndices()).print(data, m_compiler->ast(sourceCode.first), m_options.formatting.json);
|
ASTJsonExporter(m_compiler->state(), m_compiler->sourceIndices()).print(data, m_compiler->ast(sourceCode.first), m_options.formatting.json);
|
||||||
postfix += "_json";
|
postfix += "_json";
|
||||||
boost::filesystem::path path(sourceCode.first);
|
boost::filesystem::path path(sourceCode.first);
|
||||||
createFile(path.filename().string() + postfix + ".ast", data.str());
|
createFile(path.filename().string() + postfix + ".ast", data.str());
|
||||||
@ -905,7 +905,7 @@ void CommandLineInterface::handleAst()
|
|||||||
for (auto const& sourceCode: m_fileReader.sourceUnits())
|
for (auto const& sourceCode: m_fileReader.sourceUnits())
|
||||||
{
|
{
|
||||||
sout() << endl << "======= " << sourceCode.first << " =======" << endl;
|
sout() << endl << "======= " << sourceCode.first << " =======" << endl;
|
||||||
ASTJsonConverter(m_compiler->state(), m_compiler->sourceIndices()).print(sout(), m_compiler->ast(sourceCode.first), m_options.formatting.json);
|
ASTJsonExporter(m_compiler->state(), m_compiler->sourceIndices()).print(sout(), m_compiler->ast(sourceCode.first), m_options.formatting.json);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
// SPDX-License-Identifier: GPL-3.0
|
// SPDX-License-Identifier: GPL-3.0
|
||||||
|
|
||||||
#include <liblangutil/SourceReferenceFormatter.h>
|
#include <liblangutil/SourceReferenceFormatter.h>
|
||||||
#include <libsolidity/ast/ASTJsonConverter.h>
|
#include <libsolidity/ast/ASTJsonExporter.h>
|
||||||
#include <libsolutil/AnsiColorized.h>
|
#include <libsolutil/AnsiColorized.h>
|
||||||
#include <libsolutil/CommonIO.h>
|
#include <libsolutil/CommonIO.h>
|
||||||
#include <libsolutil/JSON.h>
|
#include <libsolutil/JSON.h>
|
||||||
@ -249,7 +249,7 @@ bool ASTJSONTest::runTest(
|
|||||||
for (size_t i = 0; i < m_sources.size(); i++)
|
for (size_t i = 0; i < m_sources.size(); i++)
|
||||||
{
|
{
|
||||||
ostringstream result;
|
ostringstream result;
|
||||||
ASTJsonConverter(_compiler.state(), _sourceIndices).print(result, _compiler.ast(m_sources[i].first), JsonFormat{ JsonFormat::Pretty });
|
ASTJsonExporter(_compiler.state(), _sourceIndices).print(result, _compiler.ast(m_sources[i].first), JsonFormat{ JsonFormat::Pretty });
|
||||||
_variant.result += result.str();
|
_variant.result += result.str();
|
||||||
if (i != m_sources.size() - 1)
|
if (i != m_sources.size() - 1)
|
||||||
_variant.result += ",";
|
_variant.result += ",";
|
||||||
|
Loading…
Reference in New Issue
Block a user