[#44776] [ruby-trunk - Bug #6385][Open] mtime vie File.stat(filename).utime vs File.open(filename, 'r').mtime in Windows — "kolmanv (Kolman Vornovitsky)" <kolmanv@...>

9 messages 2012/05/01

[#44782] [ruby-trunk - Bug #6387][Open] 1.9.3p194 crashed on require in ubuntu — "ywen (Yi Wen)" <hayafirst@...>

12 messages 2012/05/01

[#44795] [ruby-trunk - Bug #6391][Open] Segment Fault while execute make_encmake.rb for Ruby 1.9.3 P194 ( MinGW64) — "raylinn@... (ray linn)" <raylinn@...>

13 messages 2012/05/02

[#44911] [ruby-trunk - Bug #6408][Open] DelegateClass#eql? and <=> don't work as expected — "tenderlovemaking (Aaron Patterson)" <aaron@...>

11 messages 2012/05/06

[#44951] [ruby-trunk - Feature #6414][Open] Destructuring Assignment — "edtsech (Edward Tsech)" <edtsech@...>

14 messages 2012/05/08

[#44958] [ruby-trunk - Feature #6418][Assigned] Supporing a subset of ANSI escape code on Windows — "usa (Usaku NAKAMURA)" <usa@...>

11 messages 2012/05/09

[#45035] [ruby-trunk - Bug #6433][Open] rb_thread_blocking_region(): ubf() function is executed with GVL — ibc (Iñaki Baz Castillo) <ibc@...>

12 messages 2012/05/14

[#45180] [ruby-trunk - Feature #6478][Open] BasicObject#__class__ — "trans (Thomas Sawyer)" <transfire@...>

14 messages 2012/05/22

[#45193] [ruby-trunk - Feature #6482][Open] Add URI requested to Net::HTTP request and response objects — "drbrain (Eric Hodel)" <drbrain@...7.net>

16 messages 2012/05/23

[#45198] [ruby-trunk - Feature #6483][Open] parametric map — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

14 messages 2012/05/23

[#45222] [ruby-trunk - Feature #6492][Open] Inflate all HTTP Content-Encoding: deflate, gzip, x-gzip responses by default — "drbrain (Eric Hodel)" <drbrain@...7.net>

23 messages 2012/05/24

[#45252] [ruby-trunk - Feature #6499][Open] Array::zip — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

14 messages 2012/05/26

[#45272] [ruby-trunk - Feature #6503][Open] Support for the NPN extension to TLS/SSL — "igrigorik (Ilya Grigorik)" <ilya@...>

13 messages 2012/05/27

[#45316] [ruby-trunk - Feature #6515][Open] array.c: added method that verifies if an Array is part of another — "lellisga (Li Ellis Galardo)" <lellisga@...>

14 messages 2012/05/30

[ruby-core:45142] Re: [ruby-trunk - Bug #6408][Assigned] DelegateClass#eql? and <=> don't work as expected

From: Aaron Patterson <tenderlove@...>
Date: 2012-05-19 20:27:28 UTC
List: ruby-core #45142
On Thu, May 17, 2012 at 12:10:56AM +0900, mame (Yusuke Endoh) wrote:
>=20
> Issue #6408 has been updated by mame (Yusuke Endoh).
>=20
> Status changed from Open to Assigned
> Assignee set to tenderlovemaking (Aaron Patterson)
> Target version set to 3.0
>=20
> Hello, Aaron
>=20
> What do you think about Jeremy's opinion?

I agree with Jeremy's opinion.  I think that changing to is_a? would
probably be be better, but I think my patch should be applied for Ruby
2.0.

> I'm just wondering but why do you want to delegate #eql? ?
> I guess that is because you are inserting Delegate objects
> to a Hash.  Such a code is still dangerous even if the
> patch is applied:
>=20
>   require "delegate"
>  =20
>   class Foo; end
>   class Bar < DelegateClass(Foo); end
>   foo =3D Foo.new
>   bar =3D Bar.new(foo)
>  =20
>   p foo.eql?(foo)  #=3D> true
>   p bar.eql?(foo)  #=3D> true
>   p bar.eql?(bar)  #=3D> false (this returns true with your patch)

Yes, this is the bug I'm trying to fix.

>   p foo.eql?(bar)  #=3D> false (this is NOT fixed)

Yes, you are correct.  I'm not sure how or if we should fix this.

>   h =3D { bar =3D> 42 }
>   p h[foo] #=3D> nil, not 42
>=20
> I think it is difficult to "fix."

It's difficult to "fix" 100%, yes.  However, we can at least reduce our
broken windows. :-)

> The same holds for #<=3D>.
> You should not sort an Array that includes Delegate objects.

I agree.  The problem is that people can create delegate objects, then
feed the delegate object to third party code (say some gem, or some
library in stdlib) and expect it to work.

I think we should either make it work as best we can, or remove
DelegateClass from stdlib.  It should not be a requirement that
DelegateClass users understand how all third party code interacts with
their delegate object (I think).

--=20
Aaron Patterson
http://tenderlovemaking.com/

In This Thread