diff options
author | chriseth <chris@ethereum.org> | 2018-03-22 02:07:15 +0800 |
---|---|---|
committer | chriseth <chris@ethereum.org> | 2018-04-12 06:10:25 +0800 |
commit | 7343c4028365d3fbc9fa46fca6078971a2bed426 (patch) | |
tree | 3044d8ea9bb6434f660305313002ad023f9ba185 /libsolidity | |
parent | c4a6a63f362f478414ac886ed6e5e159038460aa (diff) | |
download | dexon-solidity-7343c4028365d3fbc9fa46fca6078971a2bed426.tar dexon-solidity-7343c4028365d3fbc9fa46fca6078971a2bed426.tar.gz dexon-solidity-7343c4028365d3fbc9fa46fca6078971a2bed426.tar.bz2 dexon-solidity-7343c4028365d3fbc9fa46fca6078971a2bed426.tar.lz dexon-solidity-7343c4028365d3fbc9fa46fca6078971a2bed426.tar.xz dexon-solidity-7343c4028365d3fbc9fa46fca6078971a2bed426.tar.zst dexon-solidity-7343c4028365d3fbc9fa46fca6078971a2bed426.zip |
Check partial function parameters if rest is arbitrary.
Diffstat (limited to 'libsolidity')
-rw-r--r-- | libsolidity/analysis/TypeChecker.cpp | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp index 8b57fc15..df08598c 100644 --- a/libsolidity/analysis/TypeChecker.cpp +++ b/libsolidity/analysis/TypeChecker.cpp @@ -1688,7 +1688,19 @@ bool TypeChecker::visit(FunctionCall const& _functionCall) } } - if (!functionType->takesArbitraryParameters() && parameterTypes.size() != arguments.size()) + if (functionType->takesArbitraryParameters() && arguments.size() < parameterTypes.size()) + { + solAssert(_functionCall.annotation().kind == FunctionCallKind::FunctionCall, ""); + m_errorReporter.typeError( + _functionCall.location(), + "Need at least " + + toString(parameterTypes.size()) + + " arguments for function call, but provided only " + + toString(arguments.size()) + + "." + ); + } + else if (!functionType->takesArbitraryParameters() && parameterTypes.size() != arguments.size()) { bool isStructConstructorCall = _functionCall.annotation().kind == FunctionCallKind::StructConstructorCall; @@ -1711,11 +1723,10 @@ bool TypeChecker::visit(FunctionCall const& _functionCall) } else if (isPositionalCall) { - // call by positional arguments for (size_t i = 0; i < arguments.size(); ++i) { auto const& argType = type(*arguments[i]); - if (functionType->takesArbitraryParameters()) + if (functionType->takesArbitraryParameters() && i >= parameterTypes.size()) { bool errored = false; if (auto t = dynamic_cast<RationalNumberType const*>(argType.get())) |