[#23657] [Bug #1550] String#lstrip! raises RuntimeError on Frozen String Despite Making No Changes — Run Paint Run Run <redmine@...>

Bug #1550: String#lstrip! raises RuntimeError on Frozen String Despite Making No Changes

13 messages 2009/06/01

[#23729] [Bug #1583] Time + String no Longer Raises TypeError? — Run Paint Run Run <redmine@...>

Bug #1583: Time + String no Longer Raises TypeError?

14 messages 2009/06/05

[#23770] [Bug #1595] rake unusable on windows install — Robert Gonzalez <redmine@...>

Bug #1595: rake unusable on windows install

10 messages 2009/06/09

[#23869] [Bug #1640] [PATCH] Documentation for the Rational Class — Run Paint Run Run <redmine@...>

Bug #1640: [PATCH] Documentation for the Rational Class

12 messages 2009/06/16

[#23903] [Bug #1648] Rational#div Raises NoMethodError for Invalid Argument — Run Paint Run Run <redmine@...>

Bug #1648: Rational#div Raises NoMethodError for Invalid Argument

9 messages 2009/06/17

[#23977] [ANN] meeting log of RubyDeveloperKaigi20090622 — "Yugui (Yuki Sonoda)" <yugui@...>

Hi,

41 messages 2009/06/23
[#23979] Re: [ANN] meeting log of RubyDeveloperKaigi20090622 — Run Paint Run Run <runrun@...> 2009/06/23

Thanks for the update. :-)

[#24173] Re: [ANN] meeting log of RubyDeveloperKaigi20090622 — "NARUSE, Yui" <naruse@...> 2009/07/07

Sorry for late response,

[#24174] Re: [ANN] meeting log of RubyDeveloperKaigi20090622 — Luis Lavena <luislavena@...> 2009/07/07

On Tue, Jul 7, 2009 at 12:12 AM, NARUSE, Yui<naruse@airemix.jp> wrote:

[#24242] Re: [ANN] meeting log of RubyDeveloperKaigi20090622 — Charles Oliver Nutter <headius@...> 2009/07/09

On Mon, Jul 6, 2009 at 10:18 PM, Luis Lavena<luislavena@gmail.com> wrote:

[#24010] [Bug #1685] Some windows unicode path issues remain — B Kelly <redmine@...>

Bug #1685: Some windows unicode path issues remain

26 messages 2009/06/24
[#29189] [Bug #1685] Some windows unicode path issues remain — Yuki Sonoda <redmine@...> 2010/04/01

Issue #1685 has been updated by Yuki Sonoda.

[#29200] Re: [Bug #1685] Some windows unicode path issues remain — Bill Kelly <billk@...> 2010/04/01

Yuki Sonoda wrote:

[#29892] Re: [Bug #1685] Some windows unicode path issues remain — Bill Kelly <billk@...> 2010/04/29

Hi,

[#24058] [Bug #1696] http downloads are unuseably slow — Steven Hartland <redmine@...>

Bug #1696: http downloads are unuseably slow

19 messages 2009/06/27

[#24063] [Feature #1697] Object#<=> — Marc-Andre Lafortune <redmine@...>

Feature #1697: Object#<=>

15 messages 2009/06/28

[ruby-core:23789] Re: Ducktyping interface

From: brian ford <brixen@...>
Date: 2009-06-10 18:21:39 UTC
List: ruby-core #23789
Hi,

On Sat, Jun 6, 2009 at 5:30 PM, Yehuda Katz<wycats@gmail.com> wrote:
> I should add that further examination reveals that people who make proxy
> objects (Drb, Rails Association Proxy) expect that their respond_to? will
> work correctly. If implementations were allowed to do internal checks only,
> proxies would need to explicitly define all coercion methods, something they
> do not currently do.
> -- Yehuda

To illustrate a bit more why I believe calling #respond_to? is an
implementation detail, consider the following:

$ irb
>> fake = Object.new
=> #<Object:0x5f12fc>
>> fake == 1
=> false
>> fake <=> 1
NoMethodError: undefined method `<=>' for #<Object:0x5f12fc>
        from (irb):3
>> fake.extend Comparable
=> #<Object:0x5f12fc>
>> fake == 1
=> nil
>> def fake.<=>(other)
>> 0 if other == 1
>> end
=> nil
>> fake == 1
=> true
>> fake == 2
=> nil

And this is the MRI C code that performs the magic (compar.c):

static VALUE
cmp_eq(a)
    VALUE *a;
{
    VALUE c = rb_funcall(a[0], cmp, 1, a[1]);

    if (NIL_P(c)) return Qnil;
    if (rb_cmpint(c, a[0], a[1]) == 0) return Qtrue;
    return Qfalse;
}

static VALUE
cmp_failed()
{
    return Qnil;
}

/*
 *  call-seq:
 *     obj == other    => true or false
 *
 *  Compares two objects based on the receiver's <code><=></code>
 *  method, returning true if it returns 0. Also returns true if
 *  _obj_ and _other_ are the same object.
 */

static VALUE
cmp_equal(x, y)
    VALUE x, y;
{
    VALUE a[2];

    if (x == y) return Qtrue;

    a[0] = x; a[1] = y;
    return rb_rescue(cmp_eq, (VALUE)a, cmp_failed, 0);
}

In this case, MRI does not call #respond_to?. And I would argue that a
more valid implementation in general is to dispatch and rescue if
necessary, as this MRI code demonstrates.

Thanks,
Brian

>
> On Sat, Jun 6, 2009 at 5:12 PM, Yehuda Katz <wycats@gmail.com> wrote:
>>
>> Matz,
>> I've been working on adding some specs to RubySpec related to the
>> ducktyping interface. I have observed the following behavior and want to
>> know whether or not it's intentional. Let's use the #to_s coercion as an
>> example:
>> 1. If the object has a method #to_s, it's called.
>> 2. If #to_s returns something that is not a String, a TypeError is
>> raised.
>> In MRI, the mechanism for determining if an object has a method #to_s is
>> to call respond_to?. This means that even if the method does not exist,
>> #to_s will get called, and fall through to #method_missing, if the
>> #respond_to method returns true for :to_s. As a result, when using MRI, it
>> is possible to implement the duck-typing interface without defining #to_s,
>> but instead defining a combination of #respond_to? and #method_missing that
>> returns a String.
>> Is this intentional? Would it be ok for an alternative implementation to
>> look up the #to_s method using an internal check instead of calling the
>> user-defined #respond_to?, as MRI does?
>> In other words, is the only "correct" way to enlist in Ruby coercion to
>> define to_s explicitly, or is another correct way to define respond_to? and
>> method_missing to return an appropriate response?
>> --
>> Yehuda Katz
>> Developer | Engine Yard
>> (ph) 718.877.1325
>
>
>
> --
> Yehuda Katz
> Developer | Engine Yard
> (ph) 718.877.1325
>

In This Thread

Prev Next