=begin
遠藤です。
元々は特異クラスのメソッドは引数が false でも列挙されていたのですが、
#2993 のために特異クラスのメソッドが列挙されなくなったことが原因です。
Module#public_instance_methods(false): 特異クラスのメソッドを列挙しない
Object#public_methods(false): 特異クラスのメソッドを列挙をする
とするパッチを書いてみました。ややこしいですね。
テストのエラーは増えず、このチケットで報告されているコードは従来通りの
挙動になります。反対がなければコミットします。
diff --git a/class.c b/class.c
index 9a3984a..b6f0999 100644
--- a/class.c
+++ b/class.c
@@ -833,7 +833,7 @@ method_entry(ID key, const rb_method_entry_t *me, st_table *list)
}
static VALUE
-class_instance_method_list(int argc, VALUE *argv, VALUE mod, int (*func) (ID, long, VALUE))
+class_instance_method_list(int argc, VALUE *argv, VALUE mod, int obj, int (*func) (ID, long, VALUE))
{
VALUE ary;
int recur;
@@ -852,6 +852,7 @@ class_instance_method_list(int argc, VALUE *argv, VALUE mod, int (*func) (ID, lo
for (; mod; mod = RCLASS_SUPER(mod)) {
st_foreach(RCLASS_M_TBL(mod), method_entry, (st_data_t)list);
if (BUILTIN_TYPE(mod) == T_ICLASS) continue;
- if (obj && FL_TEST(mod, FL_SINGLETON)) continue;
if (!recur) break;
}
ary = rb_ary_new();
@@ -891,7 +892,7 @@ class_instance_method_list(int argc, VALUE *argv, VALUE mod, int (*func) (ID, lo
VALUE
rb_class_instance_methods(int argc, VALUE *argv, VALUE mod)
{
- return class_instance_method_list(argc, argv, mod, ins_methods_i);
- return class_instance_method_list(argc, argv, mod, 0, ins_methods_i);
}
/*
@@ -906,7 +907,7 @@ rb_class_instance_methods(int argc, VALUE *argv, VALUE mod)
VALUE
rb_class_protected_instance_methods(int argc, VALUE *argv, VALUE mod)
{
- return class_instance_method_list(argc, argv, mod, ins_methods_prot_i);
- return class_instance_method_list(argc, argv, mod, 0, ins_methods_prot_i);
}
/*
@@ -929,7 +930,7 @@ rb_class_protected_instance_methods(int argc, VALUE *argv, VALUE mod)
VALUE
rb_class_private_instance_methods(int argc, VALUE *argv, VALUE mod)
{
- return class_instance_method_list(argc, argv, mod, ins_methods_priv_i);
- return class_instance_method_list(argc, argv, mod, 0, ins_methods_priv_i);
}
/*
@@ -944,7 +945,93 @@ rb_class_private_instance_methods(int argc, VALUE *argv, VALUE mod)
VALUE
rb_class_public_instance_methods(int argc, VALUE *argv, VALUE mod)
{
- return class_instance_method_list(argc, argv, mod, ins_methods_pub_i);
- return class_instance_method_list(argc, argv, mod, 0, ins_methods_pub_i);
+}
-
+/*
-
-
-
-
- Returns a list of the names of methods publicly accessible in
-
-
obj. This will include all the methods accessible in
-
-
-
-
-
-
-
-
-
k.methods[0..9] #=> [:kMethod, :freeze, :nil?, :is_a?,
-
-
-
- */
-
+VALUE
+rb_obj_methods(int argc, VALUE *argv, VALUE obj)
+{
- retry:
- if (argc == 0) {
- VALUE args[1];
-
- args[0] = Qtrue;
- return class_instance_method_list(argc, argv, CLASS_OF(obj), 1, ins_methods_i);
- }
- else {
- VALUE recur;
-
- rb_scan_args(argc, argv, "1", &recur);
- if (RTEST(recur)) {
-
argc = 0;
-
goto retry;
- }
- return rb_obj_singleton_methods(argc, argv, obj);
- }
+}
-
+/*
-
-
-
-
- Returns the list of protected methods accessible to obj. If
-
- the all parameter is set to
false
, only those methods
-
- in the receiver will be listed.
- */
-
+VALUE
+rb_obj_protected_methods(int argc, VALUE *argv, VALUE obj)
+{
- return class_instance_method_list(argc, argv, CLASS_OF(obj), 1, ins_methods_prot_i);
+}
-
+/*
-
-
-
-
- Returns the list of private methods accessible to obj. If
-
- the all parameter is set to
false
, only those methods
-
- in the receiver will be listed.
- */
-
+VALUE
+rb_obj_private_methods(int argc, VALUE *argv, VALUE obj)
+{
- return class_instance_method_list(argc, argv, CLASS_OF(obj), 1, ins_methods_priv_i);
+}
-
+/*
-
-
-
-
- Returns the list of public methods accessible to obj. If
-
- the all parameter is set to
false
, only those methods
-
- in the receiver will be listed.
- */
-
+VALUE
+rb_obj_public_methods(int argc, VALUE *argv, VALUE obj)
+{
- return class_instance_method_list(argc, argv, CLASS_OF(obj), 1, ins_methods_pub_i);
}
/*
diff --git a/object.c b/object.c
index 414c3a9..f52522d 100644
--- a/object.c
+++ b/object.c
@@ -1751,109 +1751,10 @@ rb_mod_const_defined(int argc, VALUE *argv, VALUE mod)
return RTEST(recur) ? rb_const_defined(mod, id) : rb_const_defined_at(mod, id);
}
-/*
-
-
-
-
- Returns a list of the names of methods publicly accessible in
-
-
obj. This will include all the methods accessible in
-
-
-
-
-
-
-
-
-
k.methods[0..9] #=> [:kMethod, :freeze, :nil?, :is_a?,
-
-
-
- */
-
-static VALUE
-rb_obj_methods(int argc, VALUE *argv, VALUE obj)
-{
- retry:
- if (argc == 0) {
- VALUE args[1];
-
- args[0] = Qtrue;
- return rb_class_instance_methods(1, args, CLASS_OF(obj));
- }
- else {
- VALUE recur;
-
- rb_scan_args(argc, argv, "1", &recur);
- if (RTEST(recur)) {
-
argc = 0;
-
goto retry;
- }
- return rb_obj_singleton_methods(argc, argv, obj);
- }
-}
-
-/*
-
-
-
-
- Returns the list of protected methods accessible to obj. If
-
- the all parameter is set to
false
, only those methods
-
- in the receiver will be listed.
- */
-
-static VALUE
-rb_obj_protected_methods(int argc, VALUE *argv, VALUE obj)
-{
- if (argc == 0) { /* hack to stop warning */
- VALUE args[1];
-
- args[0] = Qtrue;
- return rb_class_protected_instance_methods(1, args, CLASS_OF(obj));
- }
- return rb_class_protected_instance_methods(argc, argv, CLASS_OF(obj));
-}
-
-/*
-
-
-
-
- Returns the list of private methods accessible to obj. If
-
- the all parameter is set to
false
, only those methods
-
- in the receiver will be listed.
- */
-
-static VALUE
-rb_obj_private_methods(int argc, VALUE *argv, VALUE obj)
-{
- if (argc == 0) { /* hack to stop warning */
- VALUE args[1];
-
- args[0] = Qtrue;
- return rb_class_private_instance_methods(1, args, CLASS_OF(obj));
- }
- return rb_class_private_instance_methods(argc, argv, CLASS_OF(obj));
-}
-
-/*
-
-
-
-
- Returns the list of public methods accessible to obj. If
-
- the all parameter is set to
false
, only those methods
-
- in the receiver will be listed.
- */
-
-static VALUE
-rb_obj_public_methods(int argc, VALUE *argv, VALUE obj)
-{
- if (argc == 0) { /* hack to stop warning */
- VALUE args[1];
-
- args[0] = Qtrue;
- return rb_class_public_instance_methods(1, args, CLASS_OF(obj));
- }
- return rb_class_public_instance_methods(argc, argv, CLASS_OF(obj));
-}
+VALUE rb_obj_methods(int argc, VALUE *argv, VALUE obj);
+VALUE rb_obj_protected_methods(int argc, VALUE *argv, VALUE obj);
+VALUE rb_obj_private_methods(int argc, VALUE *argv, VALUE obj);
+VALUE rb_obj_public_methods(int argc, VALUE *argv, VALUE obj);
/*
--
Yusuke Endoh mame@tsg.ne.jp
=end