diff options
| author | knu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-04-22 12:42:57 +0000 |
|---|---|---|
| committer | knu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-04-22 12:42:57 +0000 |
| commit | a2b186bee4d4a8aec91cfd46b135f3448f731c54 (patch) | |
| tree | 47500471349bff02a59339d19d7b846572aef0e8 | |
| parent | 185e2676afec07e07dc2cbe09db0c8a1965b50af (diff) | |
* eval.c (rb_proc_new): Turn the BLOCK_LAMBDA flag on.
* object.c (sym_to_proc), test/ruby/test_symbol.rb: Add back
Symbol#to_proc, now that it passes the tests.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@16150 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 7 | ||||
| -rw-r--r-- | NEWS | 4 | ||||
| -rw-r--r-- | eval.c | 1 | ||||
| -rw-r--r-- | object.c | 30 | ||||
| -rw-r--r-- | test/ruby/test_symbol.rb | 7 |
5 files changed, 49 insertions, 0 deletions
@@ -1,3 +1,10 @@ +Tue Apr 22 21:24:32 2008 Akinori MUSHA <knu@iDaemons.org> + + * eval.c (rb_proc_new): Turn the BLOCK_LAMBDA flag on. + + * object.c (sym_to_proc), test/ruby/test_symbol.rb: Add back + Symbol#to_proc, now that it passes the tests. + Tue Apr 22 19:35:03 2008 Akinori MUSHA <knu@iDaemons.org> * enumerator.c (enumerator_initialize): Remove an undocumented @@ -232,6 +232,10 @@ with all sufficient information, see the ChangeLog file. Return an enumerator if no block is given. + * Symbol#to_proc + + New method. + * __method__ New global function that returns the name of the current method as @@ -9636,6 +9636,7 @@ rb_proc_new(func, val) Data_Get_Struct(proc, struct BLOCK, data); data->body->nd_state = YIELD_FUNC_AVALUE; + data->flags |= BLOCK_LAMBDA; return proc; } @@ -1212,6 +1212,35 @@ sym_to_sym(sym) } +static VALUE +sym_call(args, mid) + VALUE args, mid; +{ + VALUE obj; + + if (RARRAY(args)->len < 1) { + rb_raise(rb_eArgError, "no receiver given"); + } + obj = rb_ary_shift(args); + return rb_apply(obj, (ID)mid, args); +} + +/* + * call-seq: + * sym.to_proc + * + * Returns a _Proc_ object which respond to the given method by _sym_. + * + * (1..3).collect(&:to_s) #=> ["1", "2", "3"] + */ + +static VALUE +sym_to_proc(VALUE sym) +{ + return rb_proc_new(sym_call, (VALUE)SYM2ID(sym)); +} + + /*********************************************************************** * * Document-class: Module @@ -2755,6 +2784,7 @@ Init_Object() rb_define_method(rb_cSymbol, "to_s", sym_to_s, 0); rb_define_method(rb_cSymbol, "id2name", sym_to_s, 0); rb_define_method(rb_cSymbol, "to_sym", sym_to_sym, 0); + rb_define_method(rb_cSymbol, "to_proc", sym_to_proc, 0); rb_define_method(rb_cSymbol, "===", rb_obj_equal, 1); rb_define_method(rb_cModule, "freeze", rb_mod_freeze, 0); diff --git a/test/ruby/test_symbol.rb b/test/ruby/test_symbol.rb index 2ccfe64c92..ac73dc9137 100644 --- a/test/ruby/test_symbol.rb +++ b/test/ruby/test_symbol.rb @@ -74,4 +74,11 @@ class TestSymbol < Test::Unit::TestCase assert_inspect_evaled(':$0') assert_inspect_evaled(':$1') end + + def test_to_proc + assert_equal %w(1 2 3), (1..3).map(&:to_s) + assert_nothing_raised(ArgumentError) { :object_id.to_proc.call([]) } + assert_nothing_raised(ArgumentError) { :object_id.to_proc.call([1]) } + assert_nothing_raised(ArgumentError) { :object_id.to_proc.call([1,2]) } + end end |
