aboutsummaryrefslogtreecommitdiffstats
path: root/InterfaceHandler.cpp
diff options
context:
space:
mode:
authorLefteris Karapetsas <lefteris@refu.co>2015-01-23 23:37:06 +0800
committerLefteris Karapetsas <lefteris@refu.co>2015-01-29 04:46:16 +0800
commit5c7359aa09c46eb7fc27a70e328adde93d4844ab (patch)
treedf6c6146f6d3b417fdc7312faac11df2374487bc /InterfaceHandler.cpp
parent3cc04923015cc3f40ad285fba5ed71464bd9ff2a (diff)
downloaddexon-solidity-5c7359aa09c46eb7fc27a70e328adde93d4844ab.tar
dexon-solidity-5c7359aa09c46eb7fc27a70e328adde93d4844ab.tar.gz
dexon-solidity-5c7359aa09c46eb7fc27a70e328adde93d4844ab.tar.bz2
dexon-solidity-5c7359aa09c46eb7fc27a70e328adde93d4844ab.tar.lz
dexon-solidity-5c7359aa09c46eb7fc27a70e328adde93d4844ab.tar.xz
dexon-solidity-5c7359aa09c46eb7fc27a70e328adde93d4844ab.tar.zst
dexon-solidity-5c7359aa09c46eb7fc27a70e328adde93d4844ab.zip
State variable accessors code is now more organized
- FunctionDescription is the abstraction of what should describe a function. It can either be a VariableDeclaration of a FunctionDefinition. - ParamDescription is what FunctionDescription uses to describe its parameters for outside use purposes with a pair of (name, type) strings - Modified code around Solidity and especially interface handler to adapt to this change
Diffstat (limited to 'InterfaceHandler.cpp')
-rw-r--r--InterfaceHandler.cpp37
1 files changed, 18 insertions, 19 deletions
diff --git a/InterfaceHandler.cpp b/InterfaceHandler.cpp
index 1adce8cb..9b632778 100644
--- a/InterfaceHandler.cpp
+++ b/InterfaceHandler.cpp
@@ -45,23 +45,23 @@ std::unique_ptr<std::string> InterfaceHandler::getABIInterface(ContractDefinitio
Json::Value inputs(Json::arrayValue);
Json::Value outputs(Json::arrayValue);
- auto populateParameters = [](std::vector<ASTPointer<VariableDeclaration>> const& _vars)
+ auto populateParameters = [](vector<ParamDescription> const& _params)
{
Json::Value params(Json::arrayValue);
- for (ASTPointer<VariableDeclaration> const& var: _vars)
+ for (auto const& param: _params)
{
Json::Value input;
- input["name"] = var->getName();
- input["type"] = var->getType()->toString();
+ input["name"] = param.getName();
+ input["type"] = param.getType();
params.append(input);
}
return params;
};
- method["name"] = it.second->getName();
- method["constant"] = it.second->isDeclaredConst();
- method["inputs"] = populateParameters(it.second->getParameters());
- method["outputs"] = populateParameters(it.second->getReturnParameters());
+ method["name"] = it.second.getName();
+ method["constant"] = it.second.isConstant();
+ method["inputs"] = populateParameters(it.second.getParameters());
+ method["outputs"] = populateParameters(it.second.getReturnParameters());
methods.append(method);
}
return std::unique_ptr<std::string>(new std::string(m_writer.write(methods)));
@@ -72,17 +72,16 @@ unique_ptr<string> InterfaceHandler::getABISolidityInterface(ContractDefinition
string ret = "contract " + _contractDef.getName() + "{";
for (auto const& it: _contractDef.getInterfaceFunctions())
{
- FunctionDefinition const* f = it.second;
- auto populateParameters = [](vector<ASTPointer<VariableDeclaration>> const& _vars)
+ auto populateParameters = [](vector<ParamDescription> const& _params)
{
string r = "";
- for (ASTPointer<VariableDeclaration> const& var: _vars)
- r += (r.size() ? "," : "(") + var->getType()->toString() + " " + var->getName();
+ for (auto const& param: _params)
+ r += (r.size() ? "," : "(") + param.getType() + " " + param.getName();
return r.size() ? r + ")" : "()";
};
- ret += "function " + f->getName() + populateParameters(f->getParameters()) + (f->isDeclaredConst() ? "constant " : "");
- if (f->getReturnParameters().size())
- ret += "returns" + populateParameters(f->getReturnParameters());
+ ret += "function " + it.second.getName() + populateParameters(it.second.getParameters()) + (it.second.isConstant() ? "constant " : "");
+ if (it.second.getReturnParameters().size())
+ ret += "returns" + populateParameters(it.second.getReturnParameters());
else if (ret.back() == ' ')
ret.pop_back();
ret += "{}";
@@ -98,7 +97,7 @@ std::unique_ptr<std::string> InterfaceHandler::getUserDocumentation(ContractDefi
for (auto const& it: _contractDef.getInterfaceFunctions())
{
Json::Value user;
- auto strPtr = it.second->getDocumentation();
+ auto strPtr = it.second.getDocumentation();
if (strPtr)
{
resetUser();
@@ -106,7 +105,7 @@ std::unique_ptr<std::string> InterfaceHandler::getUserDocumentation(ContractDefi
if (!m_notice.empty())
{// since @notice is the only user tag if missing function should not appear
user["notice"] = Json::Value(m_notice);
- methods[it.second->getCanonicalSignature()] = user;
+ methods[it.second.getSignature()] = user;
}
}
}
@@ -139,7 +138,7 @@ std::unique_ptr<std::string> InterfaceHandler::getDevDocumentation(ContractDefin
for (auto const& it: _contractDef.getInterfaceFunctions())
{
Json::Value method;
- auto strPtr = it.second->getDocumentation();
+ auto strPtr = it.second.getDocumentation();
if (strPtr)
{
resetDev();
@@ -162,7 +161,7 @@ std::unique_ptr<std::string> InterfaceHandler::getDevDocumentation(ContractDefin
method["return"] = m_return;
if (!method.empty()) // add the function, only if we have any documentation to add
- methods[it.second->getCanonicalSignature()] = method;
+ methods[it.second.getSignature()] = method;
}
}
doc["methods"] = methods;