mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* array.c (rb_ary_nitems, Init_Array): Axe Array#nitems().
cf. [ruby-dev:34676]-[ruby-dev:34713] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@16675 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
e2db8af8a3
commit
8f706b2d44
4 changed files with 7 additions and 54 deletions
|
@ -1,3 +1,8 @@
|
|||
Wed May 28 18:05:28 2008 Akinori MUSHA <knu@iDaemons.org>
|
||||
|
||||
* array.c (rb_ary_nitems, Init_Array): Axe Array#nitems().
|
||||
cf. [ruby-dev:34676]-[ruby-dev:34713]
|
||||
|
||||
Wed May 28 17:50:32 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* win32/mkexports.rb (Exports#objdump, Exports#each_line): extracted.
|
||||
|
|
41
array.c
41
array.c
|
@ -2745,46 +2745,6 @@ rb_ary_compact(VALUE ary)
|
|||
return ary;
|
||||
}
|
||||
|
||||
/*
|
||||
* call-seq:
|
||||
* array.nitems -> int
|
||||
* array.nitems { |item| block } -> int
|
||||
*
|
||||
* Returns the number of non-<code>nil</code> elements in _self_.
|
||||
* If a block is given, the elements yielding a true value are
|
||||
* counted.
|
||||
*
|
||||
* May be zero.
|
||||
*
|
||||
* [ 1, nil, 3, nil, 5 ].nitems #=> 3
|
||||
* [5,6,7,8,9].nitems { |x| x % 2 != 0 } #=> 3
|
||||
*/
|
||||
|
||||
static VALUE
|
||||
rb_ary_nitems(VALUE ary)
|
||||
{
|
||||
long n = 0;
|
||||
|
||||
if (rb_block_given_p()) {
|
||||
long i;
|
||||
|
||||
for (i=0; i<RARRAY_LEN(ary); i++) {
|
||||
VALUE v = RARRAY_PTR(ary)[i];
|
||||
if (RTEST(rb_yield(v))) n++;
|
||||
}
|
||||
}
|
||||
else {
|
||||
VALUE *p = RARRAY_PTR(ary);
|
||||
VALUE *pend = p + RARRAY_LEN(ary);
|
||||
|
||||
while (p < pend) {
|
||||
if (!NIL_P(*p)) n++;
|
||||
p++;
|
||||
}
|
||||
}
|
||||
return LONG2NUM(n);
|
||||
}
|
||||
|
||||
/*
|
||||
* call-seq:
|
||||
* array.count(obj) -> int
|
||||
|
@ -3519,7 +3479,6 @@ Init_Array(void)
|
|||
rb_define_method(rb_cArray, "compact!", rb_ary_compact_bang, 0);
|
||||
rb_define_method(rb_cArray, "flatten", rb_ary_flatten, -1);
|
||||
rb_define_method(rb_cArray, "flatten!", rb_ary_flatten_bang, -1);
|
||||
rb_define_method(rb_cArray, "nitems", rb_ary_nitems, 0);
|
||||
rb_define_method(rb_cArray, "count", rb_ary_count, -1);
|
||||
rb_define_method(rb_cArray, "shuffle!", rb_ary_shuffle_bang, 0);
|
||||
rb_define_method(rb_cArray, "shuffle", rb_ary_shuffle, 0);
|
||||
|
|
3
doc/NEWS
3
doc/NEWS
|
@ -7,6 +7,8 @@ Incompatible (Severe)
|
|||
o Block arguments
|
||||
o New semantics for block arguments
|
||||
o Block local variables
|
||||
* Array
|
||||
o Array#nitems was removed (use count {|i| i})
|
||||
* String
|
||||
o No longer an Enumerable
|
||||
o ?c semantics
|
||||
|
@ -33,7 +35,6 @@ Incompatible (Trivial)
|
|||
o SecurityError
|
||||
o Removed Exception#to_str [Ruby2]
|
||||
* Array
|
||||
o Array#nitems
|
||||
o Array#[m,n] = nil places nil in the array.
|
||||
* Hash
|
||||
o Hash#to_s is equivalent to Hash#inspect
|
||||
|
|
|
@ -827,14 +827,6 @@ class TestArray < Test::Unit::TestCase
|
|||
assert_equal(@cls[], a)
|
||||
end
|
||||
|
||||
def test_nitems
|
||||
assert_equal(0, @cls[].nitems)
|
||||
assert_equal(1, @cls[1].nitems)
|
||||
assert_equal(1, @cls[1, nil].nitems)
|
||||
assert_equal(1, @cls[nil, 1].nitems)
|
||||
assert_equal(3, @cls[1, nil, nil, 2, nil, 3, nil].nitems)
|
||||
end
|
||||
|
||||
def test_pack
|
||||
a = @cls[*%w( cat wombat x yy)]
|
||||
assert_equal("catwomx yy ", a.pack("A3A3A3A3"))
|
||||
|
@ -1513,10 +1505,6 @@ class TestArray < Test::Unit::TestCase
|
|||
assert_equal(a.hash, b.hash)
|
||||
end
|
||||
|
||||
def test_nitems2
|
||||
assert_equal(3, [5,6,7,8,9].nitems { |x| x % 2 != 0 })
|
||||
end
|
||||
|
||||
def test_flatten2
|
||||
a = []
|
||||
a << a
|
||||
|
|
Loading…
Reference in a new issue