[#35631] [Ruby 1.9 - Bug #4558][Open] TestSocket#test_closed_read fails after r31230 — Tomoyuki Chikanaga <redmine@...>

23 messages 2011/04/06

[#35632] [Ruby 1.9 - Bug #4559][Open] Proc#== does not match the documented behaviour — Adam Prescott <redmine@...>

13 messages 2011/04/06

[#35637] [Ruby 1.9 - Bug #4561][Open] 1.9.2 requires parentheses around argument of method call in an array, where 1.8.7 did not — Dave Schweisguth <redmine@...>

9 messages 2011/04/07

[#35666] caching of the ancestor chain — Xavier Noria <fxn@...>

Why does Ruby cache the ancestors chain? I mean, not why the implementation implies that, but why it works that way conceptually.

9 messages 2011/04/09

[#35734] [Ruby 1.9 - Feature #4574][Open] Numeric#within — redmine@...

16 messages 2011/04/13

[#35753] [Ruby 1.9 - Bug #4576][Open] Range#step miss the last value, if end-exclusive and has float number — redmine@...

61 messages 2011/04/14
[#39566] [Ruby 1.9 - Bug #4576] Range#step miss the last value, if end-exclusive and has float number — Marc-Andre Lafortune <ruby-core@...> 2011/09/15

[#39590] [Ruby 1.9 - Bug #4576] Range#step miss the last value, if end-exclusive and has float number — Marc-Andre Lafortune <ruby-core@...> 2011/09/16

[#39593] Re: [Ruby 1.9 - Bug #4576] Range#step miss the last value, if end-exclusive and has float number — Tanaka Akira <akr@...> 2011/09/16

2011/9/17 Marc-Andre Lafortune <ruby-core@marc-andre.ca>:

[#39608] Re: [Ruby 1.9 - Bug #4576] Range#step miss the last value, if end-exclusive and has float number — Masahiro TANAKA <masa16.tanaka@...> 2011/09/17

I have not been watching ruby-core, but let me give a comment for this issue.

[#35765] [Ruby 1.9 - Bug #4579][Open] SecureRandom + OpenSSL may repeat with fork — redmine@...

27 messages 2011/04/15

[#35866] [Ruby 1.9 - Bug #4603][Open] lib/csv.rb: when the :encoding parameter is not provided, the encoding of CSV data is treated as ASCII-8BIT — yu nobuoka <nobuoka@...>

13 messages 2011/04/24

[#35879] [Ruby 1.9 - Bug #4610][Open] Proc#curry behavior is inconsistent with lambdas containing default argument values — Joshua Ballanco <jballanc@...>

11 messages 2011/04/25

[#35883] [Ruby 1.9 - Bug #4611][Open] [BUG] Segementation fault reported — Deryl Doucette <me@...>

15 messages 2011/04/25

[#35895] [Ruby 1.9 - Feature #4614][Open] [RFC/PATCH] thread_pthread.c: lower RUBY_STACK_MIN_LIMIT to 64K — Eric Wong <normalperson@...>

10 messages 2011/04/25

[ruby-core:35720] Re: caching of the ancestor chain

From: Xavier Noria <fxn@...>
Date: 2011-04-12 08:53:23 UTC
List: ruby-core #35720
On Mon, Apr 11, 2011 at 1:08 AM, Charles Oliver Nutter
<headius@headius.com> wrote:

> Am I misunderstanding the original question?

Since MRI inserts proxies in the ancestor chain that point to the
actual modules and adjusts the parent pointers to have a linear
ancestor chain (by linear I mean that you follow the pointers up and
you're done), you get this

    module M
    end

    class C
      include M
    end

    module N
      def doesnt
        p :doesnt
      end
    end

    module M
      include N

      def works
        p :works
      end
    end

    p C.ancestors # => [C, M, Object, Kernel, BasicObject]
    p M.ancestors # => [M, N]

That linear ancestor chain is not updated if the ancestors chain of
involved modules is modified. That's what I meant by "caching".

Both the #works method and the N module augment the M module after
inclusion in C. Thanks to the pointer to M in the ancestor chain (via
the proxy) instances of C respond to #works. But because of the
implementation N does not belong to the ancestor chain of C, while it
belongs to the ancestor chain of M. In consequence

    C.new.works
    C.new.doesnt

raises an exception in the second line.

I think that module proxies are implementation, and that conceptually
they do not belong to the object model (please correct me if that's
wrong!). So, conceptually, mixin methods are not copied into classes,
modules are "linked" to classes and inspected at call time to offer a
method dispatch that supports dynamic stuff as shown above. But that
metaphor does not extend to modules mixed-in later.

Question was whether this was a conscious design/implementation
decision on behalf of speed.

Charles I know you know all of this, just wanted to clarify my question :).

In This Thread