diff --git a/ChangeLog b/ChangeLog index 8d973b6ffd..9534125b31 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Fri Mar 26 03:09:30 2010 Akinori MUSHA + + * object.c (rb_obj_singleton_class): new method + Kernel#singleton_class. [ruby-core:21702] + Thu Mar 25 03:52:45 2010 Nobuyoshi Nakada * ext/iconv/charset_alias.rb: update of URL. [ruby-dev:38360] diff --git a/NEWS b/NEWS index 57080c6ac1..13328c0760 100644 --- a/NEWS +++ b/NEWS @@ -82,6 +82,10 @@ with all sufficient information, see the ChangeLog file. Renamed from Hash#index. + * Kernel#singleton_class + + New method. + * ENV.key Renamed from ENV.index. diff --git a/object.c b/object.c index b34a57195a..976b94760a 100644 --- a/object.c +++ b/object.c @@ -160,6 +160,30 @@ rb_obj_class(obj) return rb_class_real(CLASS_OF(obj)); } +/* + * call-seq: + * obj.singleton_class => class + * + * Returns the singleton class of obj. This method creates + * a new singleton class if obj does not have it. + * + * If obj is nil, true, or + * false, it returns NilClass, TrueClass, or FalseClass, + * respectively. + * If obj is a Fixnum or a Symbol, it raises a TypeError. + * + * Object.new.singleton_class #=> #> + * String.singleton_class #=> # + * nil.singleton_class #=> NilClass + */ + +static VALUE +rb_obj_singleton_class(obj) + VALUE obj; +{ + return rb_singleton_class(obj); +} + static void init_copy(dest, obj) VALUE dest, obj; @@ -2746,6 +2770,7 @@ Init_Object() rb_define_method(rb_mKernel, "id", rb_obj_id_obsolete, 0); rb_define_method(rb_mKernel, "type", rb_obj_type, 0); rb_define_method(rb_mKernel, "class", rb_obj_class, 0); + rb_define_method(rb_mKernel, "singleton_class", rb_obj_singleton_class, 0); rb_define_method(rb_mKernel, "clone", rb_obj_clone, 0); rb_define_method(rb_mKernel, "dup", rb_obj_dup, 0);