mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Raise error when using unimplemented internal library functions.
This commit is contained in:
parent
bea37e5682
commit
1ada48f61e
@ -9,6 +9,7 @@ Bugfixes:
|
|||||||
* Type Checker: Constructors must be implemented if declared.
|
* Type Checker: Constructors must be implemented if declared.
|
||||||
* Type Checker: Do not mark overloaded functions as shadowing other functions.
|
* Type Checker: Do not mark overloaded functions as shadowing other functions.
|
||||||
* Type Checker: Disallow the ``.gas()`` modifier on ``ecrecover``, ``sha256`` and ``ripemd160``.
|
* Type Checker: Disallow the ``.gas()`` modifier on ``ecrecover``, ``sha256`` and ``ripemd160``.
|
||||||
|
* Type Checker: Raise error when using unimplemented internal library functions.
|
||||||
|
|
||||||
### 0.4.14 (2017-07-31)
|
### 0.4.14 (2017-07-31)
|
||||||
|
|
||||||
|
@ -1403,6 +1403,21 @@ bool TypeChecker::visit(FunctionCall const& _functionCall)
|
|||||||
else
|
else
|
||||||
_functionCall.annotation().type = make_shared<TupleType>(functionType->returnParameterTypes());
|
_functionCall.annotation().type = make_shared<TupleType>(functionType->returnParameterTypes());
|
||||||
|
|
||||||
|
// Internal library functions must be implemented, because of inlining rules.
|
||||||
|
if (
|
||||||
|
functionType->kind() == FunctionType::Kind::Internal &&
|
||||||
|
functionType->hasDeclaration() &&
|
||||||
|
dynamic_cast<FunctionDefinition const*>(&functionType->declaration())
|
||||||
|
)
|
||||||
|
{
|
||||||
|
FunctionDefinition const* function = dynamic_cast<FunctionDefinition const*>(&functionType->declaration());
|
||||||
|
bool isLibraryFunction =
|
||||||
|
dynamic_cast<ContractDefinition const*>(function->scope()) &&
|
||||||
|
dynamic_cast<ContractDefinition const*>(function->scope())->isLibrary();
|
||||||
|
if (!function->isImplemented() && isLibraryFunction)
|
||||||
|
m_errorReporter.typeError(_functionCall.location(), "Inlined library function is lacking implementation.");
|
||||||
|
}
|
||||||
|
|
||||||
TypePointers parameterTypes = functionType->parameterTypes();
|
TypePointers parameterTypes = functionType->parameterTypes();
|
||||||
if (!functionType->takesArbitraryParameters() && parameterTypes.size() != arguments.size())
|
if (!functionType->takesArbitraryParameters() && parameterTypes.size() != arguments.size())
|
||||||
{
|
{
|
||||||
|
@ -6536,6 +6536,30 @@ BOOST_AUTO_TEST_CASE(constructor_without_implementation)
|
|||||||
CHECK_ERROR(text, TypeError, "Constructor must be implemented if declared.");
|
CHECK_ERROR(text, TypeError, "Constructor must be implemented if declared.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(calling_unimplemented_internal_functions)
|
||||||
|
{
|
||||||
|
char const* text = R"(
|
||||||
|
contract C {
|
||||||
|
function f() internal;
|
||||||
|
function g() { f(); }
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
CHECK_SUCCESS_NO_WARNINGS(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(calling_unimplemented_internal_library_functions)
|
||||||
|
{
|
||||||
|
char const* text = R"(
|
||||||
|
library L {
|
||||||
|
function f() internal;
|
||||||
|
}
|
||||||
|
contract C {
|
||||||
|
function g() { L.f(); }
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
CHECK_ERROR(text, TypeError, "Inlined library function is lacking implementation.");
|
||||||
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE_END()
|
BOOST_AUTO_TEST_SUITE_END()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user