summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-06-12 03:04:11 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-06-12 03:04:11 +0000
commit7fa5e608d33d7b87763b37b4dc7793e2ae58c882 (patch)
tree94ff652cbd2984ef2505edf8d578db7785970153
parentda786437a7be37f8807410a82071ace6089df97e (diff)
array.c: freeze in callback
* array.c (rb_ary_uniq_bang): must not be modified once frozen even in a callback method. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@41247 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--array.c1
-rw-r--r--test/ruby/test_array.rb9
3 files changed, 15 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index f13688ec18..5df3c64ad5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Wed Jun 12 12:04:09 2013 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * array.c (rb_ary_uniq_bang): must not be modified once frozen even in
+ a callback method.
+
Wed Jun 12 12:03:43 2013 Nobuyoshi Nakada <nobu@ruby-lang.org>
* array.c (rb_ary_sort_bang): must not be modified once frozen even in
diff --git a/array.c b/array.c
index 9bdbe78d5c..f3076d7cf3 100644
--- a/array.c
+++ b/array.c
@@ -3981,6 +3981,7 @@ rb_ary_uniq_bang(VALUE ary)
if (RARRAY_LEN(ary) == (i = RHASH_SIZE(hash))) {
return Qnil;
}
+ rb_ary_modify(ary);
ARY_SET_LEN(ary, 0);
if (ARY_SHARED_P(ary) && !ARY_EMBED_P(ary)) {
rb_ary_unshare(ary);
diff --git a/test/ruby/test_array.rb b/test/ruby/test_array.rb
index 49628215b5..6807598054 100644
--- a/test/ruby/test_array.rb
+++ b/test/ruby/test_array.rb
@@ -1569,6 +1569,15 @@ class TestArray < Test::Unit::TestCase
assert_equal(nil, b)
end
+ def test_uniq_bang_with_freeze
+ ary = [1,2]
+ orig = ary.dup
+ assert_raise(RuntimeError, "frozen during comparison") {
+ ary.uniq! {|v| ary.freeze; 1}
+ }
+ assert_equal(orig, ary, "must not be modified once frozen")
+ end
+
def test_unshift
a = @cls[]
assert_equal(@cls['cat'], a.unshift('cat'))