[#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:55083] Re: [ruby-trunk - Feature #8426][Open] Implement class hierarchy method caching

From: Charlie Somerville <charlie@...>
Date: 2013-05-20 09:21:45 UTC
List: ruby-core #55083
On Monday, 20 May 2013 at 1:35 PM, SASADA Koichi wrote:
> Could you explain the data stracture? Patch seems to introduce new data
> structure `sparse array'. What is this and how to use it on this patch?
> 
> 

funny_falcon explained this well. It's significantly faster in this case when compared to st_table.
 
> And another consern is verification mechanism of the result. Complex
> methoc caching mechanism introduces bugs because:
> - Everyone make bugs.
> - If someone who doesn't care method cache mechanism adds new
> core feature such as refinement and so on, it will break assumption
> about method caching.
> And this bug is difficult to find out because they may be rare.
> 
> My proposal is to add verify mode (on/off by macro, of course off as
> default) which check the cached result using a naive method search.
> 
> #define verify 0
> result = ...
> #if verify
> if (naive_method_search() != result) rb_bug(...);
> #endif
> 
> It will help debugging.
I think this is a reasonable proposal. I'll add it. 
 
> # minor comment: `sa_' prefix is too short :P
What would you suggest? Ruby already exports symbols with short prefixes, eg. st_. 
 
> # minor comment: change of ext/extmk.rb seems not needed
> https://github.com/charliesome/ruby/compare/trunk...klasscache-trunk#L4L219
> 
> 

Whoops, fixed! Thanks for pointing this out. 
 
> # minor comment: using uint64_t directly is not preferable.
> for example:
> #if HAVE_UINT64_T
> typedef version_t uint64_t;
> #else
> typedef version_t uint_t;
> #endif
> 
> 

This is also a reasonable suggestion. I have introduced a new vm_state_version_t typedef.

Thanks for your feedback!

In This Thread