summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-09-13 14:31:46 +0000
committernagachika <nagachika@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-09-13 14:31:46 +0000
commit81a807b1a26044b08520df4d3c510cb7d0252dc1 (patch)
tree4b3fdf814300284f4888f476eaca25419864c83c
parent4dbca94e9ecc96cf5ee14f200eaaa5178b6eccbf (diff)
merge revision(s) 42541: [Backport #8903]
* object.c (Init_Object): undef Module#prepend_features on Class, as well as Module#append_features. [Fixes GH-376] * test_class.rb: Added test for above. And ensure type checking on similar methods as module_function. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@42936 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog8
-rw-r--r--object.c1
-rw-r--r--test/ruby/test_class.rb26
-rw-r--r--version.h2
4 files changed, 36 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 298b6fabc1..198f520daa 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+Fri Sep 13 23:20:29 2013 Kenichi Kamiya <kachick1@gmail.com>
+
+ * object.c (Init_Object): undef Module#prepend_features on Class, as
+ well as Module#append_features. [Fixes GH-376]
+
+ * test_class.rb: Added test for above. And ensure type checking
+ on similar methods as module_function.
+
Fri Sep 13 23:16:12 2013 Zachary Scott <e@zzak.io>
* enumerator.c: [DOC] Remove reference to Enumerator::Lazy#cycle
diff --git a/object.c b/object.c
index dc606db067..350418e68b 100644
--- a/object.c
+++ b/object.c
@@ -3163,6 +3163,7 @@ Init_Object(void)
rb_define_alloc_func(rb_cClass, rb_class_s_alloc);
rb_undef_method(rb_cClass, "extend_object");
rb_undef_method(rb_cClass, "append_features");
+ rb_undef_method(rb_cClass, "prepend_features");
/*
* Document-class: Data
diff --git a/test/ruby/test_class.rb b/test/ruby/test_class.rb
index ef7d4fa922..3eaf103fd5 100644
--- a/test/ruby/test_class.rb
+++ b/test/ruby/test_class.rb
@@ -105,6 +105,32 @@ class TestClass < Test::Unit::TestCase
end
end
+ def test_extend_object
+ c = Class.new
+ assert_raise(TypeError) do
+ Module.instance_method(:extend_object).bind(c).call(Object.new)
+ end
+ end
+
+ def test_append_features
+ c = Class.new
+ assert_raise(TypeError) do
+ Module.instance_method(:append_features).bind(c).call(Module.new)
+ end
+ end
+
+ def test_prepend_features
+ c = Class.new
+ assert_raise(TypeError) do
+ Module.instance_method(:prepend_features).bind(c).call(Module.new)
+ end
+ end
+
+ def test_module_specific_methods
+ assert_empty(Class.private_instance_methods(true) &
+ [:module_function, :extend_object, :append_features, :prepend_features])
+ end
+
def test_method_redefinition
feature2155 = '[ruby-dev:39400]'
diff --git a/version.h b/version.h
index 69c33068d0..d14f291176 100644
--- a/version.h
+++ b/version.h
@@ -1,6 +1,6 @@
#define RUBY_VERSION "2.0.0"
#define RUBY_RELEASE_DATE "2013-09-13"
-#define RUBY_PATCHLEVEL 311
+#define RUBY_PATCHLEVEL 312
#define RUBY_RELEASE_YEAR 2013
#define RUBY_RELEASE_MONTH 9