[#50466] [ruby-trunk - Bug #7492][Open] Segmentation fault at DL::TestDL#test_call_double on x64 Windows 8 — "phasis68 (Heesob Park)" <phasis@...>

23 messages 2012/12/02

[#50558] [ruby-trunk - Feature #7511][Open] short-circuiting logical implication operator — "rits (First Last)" <redmine@...>

12 messages 2012/12/04

[#50575] [ruby-trunk - Feature #7517][Open] Fixnum::MIN,MAX — "matz (Yukihiro Matsumoto)" <matz@...>

20 messages 2012/12/05

[#50755] Becoming a committer — Charlie Somerville <charlie@...>

Hi ruby-core,

21 messages 2012/12/11
[#50759] Re: Becoming a committer — Yukihiro Matsumoto <matz@...> 2012/12/11

Hi,

[#50784] Re: Becoming a committer — Charles Oliver Nutter <headius@...> 2012/12/11

It's really this easy? If so, I'll send over my public key today :)

[#50795] Re: Becoming a committer — Yukihiro Matsumoto <matz@...> 2012/12/11

Hi,

[#50806] [ruby-trunk - Feature #7548][Open] Load and Require Callbacks — "trans (Thomas Sawyer)" <transfire@...>

12 messages 2012/12/12

[#50810] [ruby-trunk - Feature #7549][Open] A Ruby Design Process — "brixen (Brian Ford)" <brixen@...>

34 messages 2012/12/12

[#50867] [ruby-trunk - Bug #7556][Assigned] test error on refinement — "usa (Usaku NAKAMURA)" <usa@...>

14 messages 2012/12/13

[#50900] [ruby-trunk - Bug #7564][Open] r38175 introduces incompatibility — "tenderlovemaking (Aaron Patterson)" <aaron@...>

14 messages 2012/12/14

[#50951] [ruby-trunk - Bug #7584][Open] Ruby hangs when shutting down an ssl connection in gc finalization — "bpot (Bob Potter)" <bobby.potter@...>

12 messages 2012/12/17

[#51076] [ruby-trunk - Feature #7604][Open] Make === comparison operator ability to delegate comparison to an argument — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

12 messages 2012/12/22

[#51170] [ruby-trunk - Bug #7629][Open] Segmentation fault — "atd (Antonio Tapiador)" <atapiador@...>

13 messages 2012/12/28

[ruby-core:51103] Re: [ruby-trunk - Feature #7612] Enumerators take a proc

From: Perry Smith <pedzsan@...>
Date: 2012-12-23 19:40:32 UTC
List: ruby-core #51103
Great!  I tried something similar but I must have botched it somehow.

Oh.... I bet I tried e(&p1)

On Dec 23, 2012, at 1:15 PM, trans (Thomas Sawyer) wrote:

> 
> Issue #7612 has been updated by trans (Thomas Sawyer).
> 
> 
> =begin
> Use `&`:
> 
>  e.each(&p1)
>  e.each(&m2)
>  e.each(&p2)
> =end
> 
> ----------------------------------------
> Feature #7612: Enumerators take a proc
> https://bugs.ruby-lang.org/issues/7612#change-35034
> 
> Author: pedz (Perry Smith)
> Status: Open
> Priority: Normal
> Assignee: 
> Category: 
> Target version: 
> 
> 
> If there is already a clean syntax for this, I apologize.  I sure could not find it.
> 
> class Foo
>  def initialize
>    @inst = 18
>  end
> 
>  def meth(a, b)
>    puts "method #{@inst} #{a} #{b}"
>  end
> end
> 
> foo = Foo.new
> 
> e = %w{a b c}.each_with_index
> p1 = Proc.new { |a, b| puts "proc #{a} #{b}" }
> m2 = foo.method(:meth)
> p2 = m2.to_proc
> 
> # Current Syntax possibilities
> e.each { |a, b| puts "direct #{a} #{b}" }
> e.each { |a, b| foo.meth(a, b) }
> e.each { |a, b| p1.call(a,b) }
> e.each { |a, b| m2.call(a,b) }
> e.each { |a, b| p2.call(a,b) }
> 
> # Proposed Addition
> 
> e.each(p1) # same as e.each { |a, b| p1.call(a,b) }
> e.each(m2) # same as e.each { |a, b| m2.call(a,b) }
> e.each(p2) # same as e.each { |a, b| p2.call(a,b) }
> 
> # In the case of a method or lambda, the arguments are checked and possible errors thrown.
> # In the case of a proc, the proc "tricks" apply
> 
> To add readability, an "apply_to" method could be added:
> 
> e.apply_to(p1)
> 
> The extra "each" bothers me since the enumerator already has an "each" associated with it.
> 
> 
> 
> -- 
> http://bugs.ruby-lang.org/
> 


In This Thread

Prev Next