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
This commit is contained in:
parent
da786437a7
commit
7fa5e608d3
@ -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>
|
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
|
* array.c (rb_ary_sort_bang): must not be modified once frozen even in
|
||||||
|
1
array.c
1
array.c
@ -3981,6 +3981,7 @@ rb_ary_uniq_bang(VALUE ary)
|
|||||||
if (RARRAY_LEN(ary) == (i = RHASH_SIZE(hash))) {
|
if (RARRAY_LEN(ary) == (i = RHASH_SIZE(hash))) {
|
||||||
return Qnil;
|
return Qnil;
|
||||||
}
|
}
|
||||||
|
rb_ary_modify(ary);
|
||||||
ARY_SET_LEN(ary, 0);
|
ARY_SET_LEN(ary, 0);
|
||||||
if (ARY_SHARED_P(ary) && !ARY_EMBED_P(ary)) {
|
if (ARY_SHARED_P(ary) && !ARY_EMBED_P(ary)) {
|
||||||
rb_ary_unshare(ary);
|
rb_ary_unshare(ary);
|
||||||
|
@ -1569,6 +1569,15 @@ class TestArray < Test::Unit::TestCase
|
|||||||
assert_equal(nil, b)
|
assert_equal(nil, b)
|
||||||
end
|
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
|
def test_unshift
|
||||||
a = @cls[]
|
a = @cls[]
|
||||||
assert_equal(@cls['cat'], a.unshift('cat'))
|
assert_equal(@cls['cat'], a.unshift('cat'))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user