[#54738] [ruby-trunk - Bug #8358][Open] TestSprintf#test_float test failuer on mingw32 — "phasis68 (Heesob Park)" <phasis@...>

36 messages 2013/05/02

[#54749] [ruby-trunk - Feature #8361][Open] Alternative syntax for block parameter — "alexeymuranov (Alexey Muranov)" <redmine@...>

12 messages 2013/05/02

[#54798] [ruby-trunk - Bug #8370][Open] Constants MAX_MULTIPART_LENGTH in cgi\core.rb — "xibbar (Takeyuki FUJIOKA)" <xibbar@...>

17 messages 2013/05/05

[#54850] [ruby-trunk - Feature #8377][Open] Deprecate :: for method calls in 2.1 — "charliesome (Charlie Somerville)" <charliesome@...>

27 messages 2013/05/07

[#54881] [ruby-trunk - Bug #8384][Open] Cannot build ruby against OpenSSL build with "no-ec2m" — "vo.x (Vit Ondruch)" <v.ondruch@...>

16 messages 2013/05/09

[#54921] [ruby-trunk - Bug #8393][Open] A class who's parent class is in a module can go wrong if files are required in the wrong order — "eLobato (Daniel Lobato Garcia)" <elobatocs@...>

15 messages 2013/05/12

[#54939] [ruby-trunk - Bug #8399][Open] Remove usage of RARRAY_PTR in C extensions when not needed — "dbussink (Dirkjan Bussink)" <d.bussink@...>

32 messages 2013/05/12

[#55053] [ruby-trunk - Feature #8426][Open] Implement class hierarchy method caching — "charliesome (Charlie Somerville)" <charliesome@...>

21 messages 2013/05/19

[#55096] [ruby-trunk - Feature #8430][Open] Rational number literal — "mrkn (Kenta Murata)" <muraken@...>

28 messages 2013/05/21

[#55197] [ruby-trunk - Feature #8461][Open] Easy way to disable certificate checking in XMLRPC::Client — "herwinw (Herwin Weststrate)" <herwin@...>

11 messages 2013/05/29

[ruby-core:55085] Re: [ruby-trunk - Feature #8426][Open] Implement class hierarchy method caching

From: SASADA Koichi <ko1@...>
Date: 2013-05-20 09:39:57 UTC
List: ruby-core #55085
(2013/05/20 18:21), Charlie Somerville wrote:
> funny_falcon explained this well. It's significantly faster in this case
> when compared to st_table.

Thanks guys, I understand. Maybe it is used to implement weak reference
from super class to sub classes, right?

>> It will help debugging.
> I think this is a reasonable proposal. I'll add it. 

Thanks.

>> # minor comment: `sa_' prefix is too short :P
> What would you suggest? Ruby already exports symbols with short
> prefixes, eg. st_. 

I prefer `st_' related name. But not strong opinion.

One more:

    if (LIKELY(GET_METHOD_STATE_VERSION() == ci->vmstat &&
        RCLASS_EXT(klass)->seq == ci->seq &&
        klass == ci->klass)) {

should be:

    if (LIKELY(GET_METHOD_STATE_VERSION() == ci->vmstat &&
        klass == ci->klass &&
        RCLASS_EXT(klass)->seq == ci->seq) {

...?
why you use vmstat?

     if (klass == ci->klass &&
         RCLASS_EXT(klass)->seq == ci->seq) {

is not enough?

Ah, you only use for re-def BasicObject, Object and Kernel.

+  if (klass == rb_cBasicObject || klass == rb_cObject || klass ==
rb_mKernel) {
+      INC_METHOD_STATE_VERSION();
+  } else {

Is it huge performance bottleneck? I think branch on inline cache should
be removed.

-- 
// SASADA Koichi at atdot dot net

In This Thread