mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* enumerator.c: Introduce id_each to save rb_itern() and SYM2ID()
calls. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@21975 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
1d551324bb
commit
2654904a1a
2 changed files with 12 additions and 6 deletions
|
@ -1,3 +1,8 @@
|
|||
Mon Feb 2 20:49:24 2009 Akinori MUSHA <knu@iDaemons.org>
|
||||
|
||||
* enumerator.c: Introduce id_each to save rb_itern() and SYM2ID()
|
||||
calls.
|
||||
|
||||
Mon Feb 2 19:55:51 2009 Tanaka Akira <akr@fsij.org>
|
||||
|
||||
* test/socket/test_addrinfo.rb: use AddrInfo.getaddrinfo to generate
|
||||
|
|
13
enumerator.c
13
enumerator.c
|
@ -21,8 +21,8 @@
|
|||
* object.
|
||||
*/
|
||||
VALUE rb_cEnumerator;
|
||||
static ID id_rewind, id_each;
|
||||
static VALUE sym_each;
|
||||
static ID id_rewind;
|
||||
|
||||
VALUE rb_eStopIteration;
|
||||
|
||||
|
@ -154,7 +154,7 @@ enum_each_slice(VALUE obj, VALUE n)
|
|||
args[0] = rb_ary_new2(size);
|
||||
args[1] = (VALUE)size;
|
||||
|
||||
rb_block_call(obj, SYM2ID(sym_each), 0, 0, each_slice_i, (VALUE)args);
|
||||
rb_block_call(obj, id_each, 0, 0, each_slice_i, (VALUE)args);
|
||||
|
||||
ary = args[0];
|
||||
if (RARRAY_LEN(ary) > 0) rb_yield(ary);
|
||||
|
@ -211,7 +211,7 @@ enum_each_cons(VALUE obj, VALUE n)
|
|||
args[0] = rb_ary_new2(size);
|
||||
args[1] = (VALUE)size;
|
||||
|
||||
rb_block_call(obj, SYM2ID(sym_each), 0, 0, each_cons_i, (VALUE)args);
|
||||
rb_block_call(obj, id_each, 0, 0, each_cons_i, (VALUE)args);
|
||||
|
||||
return Qnil;
|
||||
}
|
||||
|
@ -242,7 +242,7 @@ enum_each_with_object(VALUE obj, VALUE memo)
|
|||
{
|
||||
RETURN_ENUMERATOR(obj, 1, &memo);
|
||||
|
||||
rb_block_call(obj, SYM2ID(sym_each), 0, 0, each_with_object_i, memo);
|
||||
rb_block_call(obj, id_each, 0, 0, each_with_object_i, memo);
|
||||
|
||||
return memo;
|
||||
}
|
||||
|
@ -480,7 +480,7 @@ next_i(VALUE curr, VALUE obj)
|
|||
struct enumerator *e = enumerator_ptr(obj);
|
||||
VALUE nil = Qnil;
|
||||
|
||||
rb_block_call(obj, rb_intern("each"), 0, 0, next_ii, obj);
|
||||
rb_block_call(obj, id_each, 0, 0, next_ii, obj);
|
||||
e->no_next = Qtrue;
|
||||
return rb_fiber_yield(1, &nil);
|
||||
}
|
||||
|
@ -866,8 +866,9 @@ Init_Enumerator(void)
|
|||
rb_define_method(rb_cYielder, "yield", yielder_yield, -2);
|
||||
rb_define_method(rb_cYielder, "<<", yielder_yield, -2);
|
||||
|
||||
sym_each = ID2SYM(rb_intern("each"));
|
||||
id_rewind = rb_intern("rewind");
|
||||
id_each = rb_intern("each");
|
||||
sym_each = ID2SYM(id_each);
|
||||
|
||||
rb_provide("enumerator.so"); /* for backward compatibility */
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue