mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
merge revision(s) 49088: [Backport #10685]
* vm_args.c (keyword_hash_p): fix non-symbol keys hash. rb_extract_keywords() returns 0 not Qnil when no symbol keys is included. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_2@49273 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
d40ee82b18
commit
81f257aa10
4 changed files with 17 additions and 2 deletions
|
@ -1,3 +1,9 @@
|
|||
Fri Jan 16 14:20:52 2015 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* vm_args.c (keyword_hash_p): fix non-symbol keys hash.
|
||||
rb_extract_keywords() returns 0 not Qnil when no symbol keys is
|
||||
included.
|
||||
|
||||
Fri Jan 16 11:06:17 2015 SHIBATA Hiroshi <shibata.hiroshi@gmail.com>
|
||||
|
||||
* lib/unicode_normalize.rb: typo fix. [ci skip]
|
||||
|
|
|
@ -559,4 +559,11 @@ class TestKeywordArguments < Test::Unit::TestCase
|
|||
assert_equal({:bar => "bar"}, obj.foo, bug10659)
|
||||
}
|
||||
end
|
||||
|
||||
def m(a) yield a end
|
||||
|
||||
def test_nonsymbol_key
|
||||
result = m(["a" => 10]) { |a = nil, **b| [a, b] }
|
||||
assert_equal([{"a" => 10}, {}], result)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
#define RUBY_VERSION "2.2.0"
|
||||
#define RUBY_RELEASE_DATE "2015-01-16"
|
||||
#define RUBY_PATCHLEVEL 9
|
||||
#define RUBY_PATCHLEVEL 10
|
||||
|
||||
#define RUBY_RELEASE_YEAR 2015
|
||||
#define RUBY_RELEASE_MONTH 1
|
||||
|
|
|
@ -179,7 +179,9 @@ keyword_hash_p(VALUE *kw_hash_ptr, VALUE *rest_hash_ptr, rb_thread_t *th, const
|
|||
th->mark_stack_len = msl;
|
||||
|
||||
if (!NIL_P(*rest_hash_ptr)) {
|
||||
*kw_hash_ptr = rb_extract_keywords(rest_hash_ptr);
|
||||
VALUE hash = rb_extract_keywords(rest_hash_ptr);
|
||||
if (!hash) hash = Qnil;
|
||||
*kw_hash_ptr = hash;
|
||||
return TRUE;
|
||||
}
|
||||
else {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue