ruby-changes:44013
From: nobu <ko1@a...>
Date: Wed, 7 Sep 2016 16:35:50 +0900 (JST)
Subject: [ruby-changes:44013] nobu:r56086 (trunk): class.c: instance method conditions
nobu 2016-09-07 16:35:45 +0900 (Wed, 07 Sep 2016) New Revision: 56086 https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=56086 Log: class.c: instance method conditions * class.c (ins_methods_i, ins_methods_prot_i, ins_methods_priv_i), (ins_methods_pub_i): check for each conditions to match. Modified files: trunk/class.c Index: class.c =================================================================== --- class.c (revision 56085) +++ class.c (revision 56086) @@ -1090,46 +1090,51 @@ rb_mod_ancestors(VALUE mod) https://github.com/ruby/ruby/blob/trunk/class.c#L1090 return ary; } -static int -ins_methods_push(ID name, rb_method_visibility_t visi, VALUE ary, rb_method_visibility_t expected_visi) +static void +ins_methods_push(st_data_t name, st_data_t ary) { - if (visi == METHOD_VISI_UNDEF) return ST_CONTINUE; + rb_ary_push((VALUE)ary, ID2SYM((ID)name)); +} - switch (expected_visi) { +static int +ins_methods_i(st_data_t name, st_data_t type, st_data_t ary) +{ + switch ((rb_method_visibility_t)type) { case METHOD_VISI_UNDEF: - if (visi != METHOD_VISI_PRIVATE) rb_ary_push(ary, ID2SYM(name)); - break; case METHOD_VISI_PRIVATE: - case METHOD_VISI_PROTECTED: - case METHOD_VISI_PUBLIC: - if (visi == expected_visi) rb_ary_push(ary, ID2SYM(name)); + break; + default: /* everything but private */ + ins_methods_push(name, ary); break; } return ST_CONTINUE; } static int -ins_methods_i(st_data_t name, st_data_t type, st_data_t ary) -{ - return ins_methods_push((ID)name, (rb_method_visibility_t)type, (VALUE)ary, METHOD_VISI_UNDEF); /* everything but private */ -} - -static int ins_methods_prot_i(st_data_t name, st_data_t type, st_data_t ary) { - return ins_methods_push((ID)name, (rb_method_visibility_t)type, (VALUE)ary, METHOD_VISI_PROTECTED); + if ((rb_method_visibility_t)type == METHOD_VISI_PROTECTED) { + ins_methods_push(name, ary); + } + return ST_CONTINUE; } static int ins_methods_priv_i(st_data_t name, st_data_t type, st_data_t ary) { - return ins_methods_push((ID)name, (rb_method_visibility_t)type, (VALUE)ary, METHOD_VISI_PRIVATE); + if ((rb_method_visibility_t)type == METHOD_VISI_PRIVATE) { + ins_methods_push(name, ary); + } + return ST_CONTINUE; } static int ins_methods_pub_i(st_data_t name, st_data_t type, st_data_t ary) { - return ins_methods_push((ID)name, (rb_method_visibility_t)type, (VALUE)ary, METHOD_VISI_PUBLIC); + if ((rb_method_visibility_t)type == METHOD_VISI_PUBLIC) { + ins_methods_push(name, ary); + } + return ST_CONTINUE; } struct method_entry_arg { -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/