mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
warn unused blocks with Enumerable#all? any? one? none?
[Fix GH-1953] From: Koji Onishi <fursich0@gmail.com> git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@64733 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
cff6bdfcba
commit
384fda18b8
4 changed files with 77 additions and 0 deletions
3
array.c
3
array.c
|
@ -5809,6 +5809,9 @@ rb_ary_any_p(int argc, VALUE *argv, VALUE ary)
|
||||||
rb_check_arity(argc, 0, 1);
|
rb_check_arity(argc, 0, 1);
|
||||||
if (!len) return Qfalse;
|
if (!len) return Qfalse;
|
||||||
if (argc) {
|
if (argc) {
|
||||||
|
if (rb_block_given_p()) {
|
||||||
|
rb_warn("given block not used");
|
||||||
|
}
|
||||||
for (i = 0; i < RARRAY_LEN(ary); ++i) {
|
for (i = 0; i < RARRAY_LEN(ary); ++i) {
|
||||||
if (RTEST(rb_funcall(argv[0], idEqq, 1, RARRAY_AREF(ary, i)))) return Qtrue;
|
if (RTEST(rb_funcall(argv[0], idEqq, 1, RARRAY_AREF(ary, i)))) return Qtrue;
|
||||||
}
|
}
|
||||||
|
|
11
enum.c
11
enum.c
|
@ -1212,6 +1212,12 @@ name##_eqq(RB_BLOCK_CALL_FUNC_ARGLIST(i, memo)) \
|
||||||
static VALUE \
|
static VALUE \
|
||||||
enum_##name##_func(VALUE result, struct MEMO *memo)
|
enum_##name##_func(VALUE result, struct MEMO *memo)
|
||||||
|
|
||||||
|
#define WARN_UNUSED_BLOCK(argc) do { \
|
||||||
|
if ((argc) > 0 && rb_block_given_p()) { \
|
||||||
|
rb_warn("given block not used"); \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
DEFINE_ENUMFUNCS(all)
|
DEFINE_ENUMFUNCS(all)
|
||||||
{
|
{
|
||||||
if (!RTEST(result)) {
|
if (!RTEST(result)) {
|
||||||
|
@ -1249,6 +1255,7 @@ static VALUE
|
||||||
enum_all(int argc, VALUE *argv, VALUE obj)
|
enum_all(int argc, VALUE *argv, VALUE obj)
|
||||||
{
|
{
|
||||||
struct MEMO *memo = MEMO_ENUM_NEW(Qtrue);
|
struct MEMO *memo = MEMO_ENUM_NEW(Qtrue);
|
||||||
|
WARN_UNUSED_BLOCK(argc);
|
||||||
rb_block_call(obj, id_each, 0, 0, ENUMFUNC(all), (VALUE)memo);
|
rb_block_call(obj, id_each, 0, 0, ENUMFUNC(all), (VALUE)memo);
|
||||||
return memo->v1;
|
return memo->v1;
|
||||||
}
|
}
|
||||||
|
@ -1290,6 +1297,7 @@ static VALUE
|
||||||
enum_any(int argc, VALUE *argv, VALUE obj)
|
enum_any(int argc, VALUE *argv, VALUE obj)
|
||||||
{
|
{
|
||||||
struct MEMO *memo = MEMO_ENUM_NEW(Qfalse);
|
struct MEMO *memo = MEMO_ENUM_NEW(Qfalse);
|
||||||
|
WARN_UNUSED_BLOCK(argc);
|
||||||
rb_block_call(obj, id_each, 0, 0, ENUMFUNC(any), (VALUE)memo);
|
rb_block_call(obj, id_each, 0, 0, ENUMFUNC(any), (VALUE)memo);
|
||||||
return memo->v1;
|
return memo->v1;
|
||||||
}
|
}
|
||||||
|
@ -1557,6 +1565,7 @@ enum_one(int argc, VALUE *argv, VALUE obj)
|
||||||
struct MEMO *memo = MEMO_ENUM_NEW(Qundef);
|
struct MEMO *memo = MEMO_ENUM_NEW(Qundef);
|
||||||
VALUE result;
|
VALUE result;
|
||||||
|
|
||||||
|
WARN_UNUSED_BLOCK(argc);
|
||||||
rb_block_call(obj, id_each, 0, 0, ENUMFUNC(one), (VALUE)memo);
|
rb_block_call(obj, id_each, 0, 0, ENUMFUNC(one), (VALUE)memo);
|
||||||
result = memo->v1;
|
result = memo->v1;
|
||||||
if (result == Qundef) return Qfalse;
|
if (result == Qundef) return Qfalse;
|
||||||
|
@ -1598,6 +1607,8 @@ static VALUE
|
||||||
enum_none(int argc, VALUE *argv, VALUE obj)
|
enum_none(int argc, VALUE *argv, VALUE obj)
|
||||||
{
|
{
|
||||||
struct MEMO *memo = MEMO_ENUM_NEW(Qtrue);
|
struct MEMO *memo = MEMO_ENUM_NEW(Qtrue);
|
||||||
|
|
||||||
|
WARN_UNUSED_BLOCK(argc);
|
||||||
rb_block_call(obj, id_each, 0, 0, ENUMFUNC(none), (VALUE)memo);
|
rb_block_call(obj, id_each, 0, 0, ENUMFUNC(none), (VALUE)memo);
|
||||||
return memo->v1;
|
return memo->v1;
|
||||||
}
|
}
|
||||||
|
|
3
hash.c
3
hash.c
|
@ -3034,6 +3034,9 @@ rb_hash_any_p(int argc, VALUE *argv, VALUE hash)
|
||||||
rb_check_arity(argc, 0, 1);
|
rb_check_arity(argc, 0, 1);
|
||||||
if (RHASH_EMPTY_P(hash)) return Qfalse;
|
if (RHASH_EMPTY_P(hash)) return Qfalse;
|
||||||
if (argc) {
|
if (argc) {
|
||||||
|
if (rb_block_given_p()) {
|
||||||
|
rb_warn("given block not used");
|
||||||
|
}
|
||||||
args[1] = argv[0];
|
args[1] = argv[0];
|
||||||
|
|
||||||
rb_hash_foreach(hash, any_p_i_pattern, (VALUE)args);
|
rb_hash_foreach(hash, any_p_i_pattern, (VALUE)args);
|
||||||
|
|
|
@ -314,6 +314,21 @@ class TestEnumerable < Test::Unit::TestCase
|
||||||
assert_equal(false, @obj.all?(1..2))
|
assert_equal(false, @obj.all?(1..2))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_all_with_unused_block
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
[1, 2].all?(1) {|x| x == 3 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
(1..2).all?(1) {|x| x == 3 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
3.times.all?(1) {|x| x == 3 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
{a: 1, b: 2}.all?([:b, 2]) {|x| x == 4 }
|
||||||
|
EOS
|
||||||
|
end
|
||||||
|
|
||||||
def test_any
|
def test_any
|
||||||
assert_equal(true, @obj.any? {|x| x >= 3 })
|
assert_equal(true, @obj.any? {|x| x >= 3 })
|
||||||
assert_equal(false, @obj.any? {|x| x > 3 })
|
assert_equal(false, @obj.any? {|x| x > 3 })
|
||||||
|
@ -329,6 +344,21 @@ class TestEnumerable < Test::Unit::TestCase
|
||||||
assert_equal(true, {a: 1, b: 2}.any?(->(kv) { kv == [:b, 2] }))
|
assert_equal(true, {a: 1, b: 2}.any?(->(kv) { kv == [:b, 2] }))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_any_with_unused_block
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
[1, 23].any?(1) {|x| x == 1 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
(1..2).any?(34) {|x| x == 2 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
3.times.any?(1) {|x| x == 3 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
{a: 1, b: 2}.any?([:b, 2]) {|x| x == 4 }
|
||||||
|
EOS
|
||||||
|
end
|
||||||
|
|
||||||
def test_one
|
def test_one
|
||||||
assert(@obj.one? {|x| x == 3 })
|
assert(@obj.one? {|x| x == 3 })
|
||||||
assert(!(@obj.one? {|x| x == 1 }))
|
assert(!(@obj.one? {|x| x == 1 }))
|
||||||
|
@ -348,6 +378,21 @@ class TestEnumerable < Test::Unit::TestCase
|
||||||
assert([ nil, true, 99 ].one?(Integer))
|
assert([ nil, true, 99 ].one?(Integer))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_one_with_unused_block
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
[1, 2].one?(1) {|x| x == 3 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
(1..2).one?(1) {|x| x == 3 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
3.times.one?(1) {|x| x == 3 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
{a: 1, b: 2}.one?([:b, 2]) {|x| x == 4 }
|
||||||
|
EOS
|
||||||
|
end
|
||||||
|
|
||||||
def test_none
|
def test_none
|
||||||
assert(@obj.none? {|x| x == 4 })
|
assert(@obj.none? {|x| x == 4 })
|
||||||
assert(!(@obj.none? {|x| x == 1 }))
|
assert(!(@obj.none? {|x| x == 1 }))
|
||||||
|
@ -365,6 +410,21 @@ class TestEnumerable < Test::Unit::TestCase
|
||||||
assert(@empty.none?)
|
assert(@empty.none?)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_none_with_unused_block
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
[1, 2].none?(1) {|x| x == 3 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
(1..2).none?(1) {|x| x == 3 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
3.times.none?(1) {|x| x == 3 }
|
||||||
|
EOS
|
||||||
|
assert_in_out_err [], <<-EOS, [], ["-:1: warning: given block not used"]
|
||||||
|
{a: 1, b: 2}.none?([:b, 2]) {|x| x == 4 }
|
||||||
|
EOS
|
||||||
|
end
|
||||||
|
|
||||||
def test_min
|
def test_min
|
||||||
assert_equal(1, @obj.min)
|
assert_equal(1, @obj.min)
|
||||||
assert_equal(3, @obj.min {|a,b| b <=> a })
|
assert_equal(3, @obj.min {|a,b| b <=> a })
|
||||||
|
|
Loading…
Add table
Reference in a new issue