aboutsummaryrefslogtreecommitdiffstats
path: root/AST.cpp
diff options
context:
space:
mode:
authorChristian <c@ethdev.com>2014-12-15 23:09:50 +0800
committerChristian <c@ethdev.com>2014-12-15 23:09:50 +0800
commitc40725c22adaa2159bd06894740f7559733afbb4 (patch)
tree979ec3f5ba0d4540097e56fd08f809880f35b7de /AST.cpp
parent40f7c32e57cf8b09d45f52935b8726f5baef5358 (diff)
downloaddexon-solidity-c40725c22adaa2159bd06894740f7559733afbb4.tar
dexon-solidity-c40725c22adaa2159bd06894740f7559733afbb4.tar.gz
dexon-solidity-c40725c22adaa2159bd06894740f7559733afbb4.tar.bz2
dexon-solidity-c40725c22adaa2159bd06894740f7559733afbb4.tar.lz
dexon-solidity-c40725c22adaa2159bd06894740f7559733afbb4.tar.xz
dexon-solidity-c40725c22adaa2159bd06894740f7559733afbb4.tar.zst
dexon-solidity-c40725c22adaa2159bd06894740f7559733afbb4.zip
Check that constructor does not have "returns" directive.
Diffstat (limited to 'AST.cpp')
-rw-r--r--AST.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/AST.cpp b/AST.cpp
index 3fcf8ba0..5e344ead 100644
--- a/AST.cpp
+++ b/AST.cpp
@@ -39,6 +39,17 @@ TypeError ASTNode::createTypeError(string const& _description) const
return TypeError() << errinfo_sourceLocation(getLocation()) << errinfo_comment(_description);
}
+void ContractDefinition::checkTypeRequirements()
+{
+ FunctionDefinition const* constructor = getConstructor();
+ if (constructor && !constructor->getReturnParameters().empty())
+ BOOST_THROW_EXCEPTION(constructor->getReturnParameterList()->createTypeError(
+ "Non-empty \"returns\" directive for constructor."));
+
+ for (ASTPointer<FunctionDefinition> const& function: getDefinedFunctions())
+ function->checkTypeRequirements();
+}
+
vector<FunctionDefinition const*> ContractDefinition::getInterfaceFunctions() const
{
vector<FunctionDefinition const*> exportedFunctions;