mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Disallow payable internal functions.
This commit is contained in:
parent
f7a62c1e69
commit
925d674146
@ -95,7 +95,8 @@ void ReferencesResolver::endVisit(FunctionTypeName const& _typeName)
|
|||||||
typeError(_typeName.location(), "Invalid visibility, can only be \"external\" or \"internal\".");
|
typeError(_typeName.location(), "Invalid visibility, can only be \"external\" or \"internal\".");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Do we allow storage references for external functions?
|
if (_typeName.isPayable() && _typeName.visibility() != VariableDeclaration::Visibility::External)
|
||||||
|
fatalTypeError(_typeName.location(), "Only external function types can be payable.");
|
||||||
|
|
||||||
_typeName.annotation().type = make_shared<FunctionType>(_typeName);
|
_typeName.annotation().type = make_shared<FunctionType>(_typeName);
|
||||||
}
|
}
|
||||||
|
@ -1704,7 +1704,7 @@ TypePointer TupleType::closestTemporaryType(TypePointer const& _targetType) cons
|
|||||||
FunctionType::FunctionType(FunctionDefinition const& _function, bool _isInternal):
|
FunctionType::FunctionType(FunctionDefinition const& _function, bool _isInternal):
|
||||||
m_location(_isInternal ? Location::Internal : Location::External),
|
m_location(_isInternal ? Location::Internal : Location::External),
|
||||||
m_isConstant(_function.isDeclaredConst()),
|
m_isConstant(_function.isDeclaredConst()),
|
||||||
m_isPayable(_function.isPayable()),
|
m_isPayable(_isInternal ? false : _function.isPayable()),
|
||||||
m_declaration(&_function)
|
m_declaration(&_function)
|
||||||
{
|
{
|
||||||
TypePointers params;
|
TypePointers params;
|
||||||
@ -1810,6 +1810,8 @@ FunctionType::FunctionType(FunctionTypeName const& _typeName):
|
|||||||
m_isConstant(_typeName.isDeclaredConst()),
|
m_isConstant(_typeName.isDeclaredConst()),
|
||||||
m_isPayable(_typeName.isPayable())
|
m_isPayable(_typeName.isPayable())
|
||||||
{
|
{
|
||||||
|
if (_typeName.isPayable())
|
||||||
|
solAssert(m_location == Location::External, "Internal payable function type used.");
|
||||||
for (auto const& t: _typeName.parameterTypes())
|
for (auto const& t: _typeName.parameterTypes())
|
||||||
{
|
{
|
||||||
solAssert(t->annotation().type, "Type not set for parameter.");
|
solAssert(t->annotation().type, "Type not set for parameter.");
|
||||||
|
@ -4192,6 +4192,42 @@ BOOST_AUTO_TEST_CASE(public_function_type)
|
|||||||
BOOST_CHECK(expectError(text) == Error::Type::TypeError);
|
BOOST_CHECK(expectError(text) == Error::Type::TypeError);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(payable_internal_function_type)
|
||||||
|
{
|
||||||
|
char const* text = R"(
|
||||||
|
contract C {
|
||||||
|
function (uint) internal payable returns (uint) x;
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
BOOST_CHECK(expectError(text) == Error::Type::TypeError);
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(call_value_on_non_payable_function_type)
|
||||||
|
{
|
||||||
|
char const* text = R"(
|
||||||
|
contract C {
|
||||||
|
function (uint) external returns (uint) x;
|
||||||
|
function f() {
|
||||||
|
x.value(2)();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
BOOST_CHECK(expectError(text) == Error::Type::TypeError);
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(call_value_on_payable_function_type)
|
||||||
|
{
|
||||||
|
char const* text = R"(
|
||||||
|
contract C {
|
||||||
|
function (uint) external payable returns (uint) x;
|
||||||
|
function f() {
|
||||||
|
x.value(2)(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
BOOST_CHECK(success(text));
|
||||||
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(internal_function_as_external_parameter)
|
BOOST_AUTO_TEST_CASE(internal_function_as_external_parameter)
|
||||||
{
|
{
|
||||||
// It should not be possible to give internal functions
|
// It should not be possible to give internal functions
|
||||||
|
Loading…
Reference in New Issue
Block a user