Skip to content

Commit

Permalink
Only warn about unused return in low-level functions.
Browse files Browse the repository at this point in the history
  • Loading branch information
chriseth committed Jun 26, 2016
1 parent cc6314c commit 25a64c7
Show file tree
Hide file tree
Showing 2 changed files with 64 additions and 7 deletions.
21 changes: 15 additions & 6 deletions libsolidity/analysis/TypeChecker.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -831,12 +831,21 @@ void TypeChecker::endVisit(ExpressionStatement const& _statement)
if (!dynamic_cast<RationalNumberType const&>(*type(_statement.expression())).mobileType())
typeError(_statement.expression().location(), "Invalid rational number.");

bool unusedReturnValue = true;
if (auto t = dynamic_cast<TupleType const*>(type(_statement.expression()).get()))
if (t->components().empty())
unusedReturnValue = false;
if (unusedReturnValue)
warning(_statement.location(), "Unused return value.");
if (auto call = dynamic_cast<FunctionCall const*>(&_statement.expression()))
{
if (auto callType = dynamic_cast<FunctionType const*>(type(call->expression()).get()))
{
using Location = FunctionType::Location;
Location location = callType->location();
if (
location == Location::Bare ||
location == Location::BareCallCode ||
location == Location::BareDelegateCall ||
location == Location::Send
)
warning(_statement.location(), "Return value of low-level calls not used.");
}
}
}

bool TypeChecker::visit(Conditional const& _conditional)
Expand Down
50 changes: 49 additions & 1 deletion test/libsolidity/SolidityNameAndTypeResolution.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3760,7 +3760,7 @@ BOOST_AUTO_TEST_CASE(unused_return_value)
}
}
)";
BOOST_CHECK(expectError(text, true) == Error::Type::Warning);
BOOST_CHECK(success(text));
}

BOOST_AUTO_TEST_CASE(unused_return_value_send)
Expand All @@ -3775,6 +3775,54 @@ BOOST_AUTO_TEST_CASE(unused_return_value_send)
BOOST_CHECK(expectError(text, true) == Error::Type::Warning);
}

BOOST_AUTO_TEST_CASE(unused_return_value_call)
{
char const* text = R"(
contract test {
function f() {
address(0x12).call("abc");
}
}
)";
BOOST_CHECK(expectError(text, true) == Error::Type::Warning);
}

BOOST_AUTO_TEST_CASE(unused_return_value_call_value)
{
char const* text = R"(
contract test {
function f() {
address(0x12).call.value(2)("abc");
}
}
)";
BOOST_CHECK(expectError(text, true) == Error::Type::Warning);
}

BOOST_AUTO_TEST_CASE(unused_return_value_callcode)
{
char const* text = R"(
contract test {
function f() {
address(0x12).callcode("abc");
}
}
)";
BOOST_CHECK(expectError(text, true) == Error::Type::Warning);
}

BOOST_AUTO_TEST_CASE(unused_return_value_delegatecall)
{
char const* text = R"(
contract test {
function f() {
address(0x12).delegatecall("abc");
}
}
)";
BOOST_CHECK(expectError(text, true) == Error::Type::Warning);
}

BOOST_AUTO_TEST_SUITE_END()

}
Expand Down

0 comments on commit 25a64c7

Please sign in to comment.