aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/analysis/TypeChecker.cpp
diff options
context:
space:
mode:
authorAlex Beregszaszi <alex@rtfs.hu>2017-08-17 05:19:08 +0800
committerAlex Beregszaszi <alex@rtfs.hu>2017-08-21 18:03:55 +0800
commitfe25bcf350bfb65ddb69bc5e7d3f65dfa6d23fa7 (patch)
tree687f73c7e2b1a6b752960dd6e3580788b673279f /libsolidity/analysis/TypeChecker.cpp
parent83b90f3e8a3ee168ba00eff33c4443d00bbb8a57 (diff)
downloaddexon-solidity-fe25bcf350bfb65ddb69bc5e7d3f65dfa6d23fa7.tar
dexon-solidity-fe25bcf350bfb65ddb69bc5e7d3f65dfa6d23fa7.tar.gz
dexon-solidity-fe25bcf350bfb65ddb69bc5e7d3f65dfa6d23fa7.tar.bz2
dexon-solidity-fe25bcf350bfb65ddb69bc5e7d3f65dfa6d23fa7.tar.lz
dexon-solidity-fe25bcf350bfb65ddb69bc5e7d3f65dfa6d23fa7.tar.xz
dexon-solidity-fe25bcf350bfb65ddb69bc5e7d3f65dfa6d23fa7.tar.zst
dexon-solidity-fe25bcf350bfb65ddb69bc5e7d3f65dfa6d23fa7.zip
Library cannot have constructors
Diffstat (limited to 'libsolidity/analysis/TypeChecker.cpp')
-rw-r--r--libsolidity/analysis/TypeChecker.cpp3
1 files changed, 3 insertions, 0 deletions
diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp
index 0764bf67..e5660cde 100644
--- a/libsolidity/analysis/TypeChecker.cpp
+++ b/libsolidity/analysis/TypeChecker.cpp
@@ -546,6 +546,9 @@ bool TypeChecker::visit(FunctionDefinition const& _function)
if (_function.isConstructor())
m_errorReporter.typeError(_function.location(), "Constructor cannot be defined in interfaces.");
}
+ else if (m_scope->contractKind() == ContractDefinition::ContractKind::Library)
+ if (_function.isConstructor())
+ m_errorReporter.typeError(_function.location(), "Constructor cannot be defined in libraries.");
if (_function.isImplemented())
_function.body().accept(*this);
else if (_function.isConstructor())