From 2054417ec66ffce4cd9b06cd2077f49487a3cd77 Mon Sep 17 00:00:00 2001 From: nagachika Date: Sun, 17 Jan 2016 15:59:36 +0000 Subject: [PATCH] merge revision(s) 53164: [Backport #11657] * vm_insnhelper.c (vm_call_method_each_type): should not set fastpath with keyword arguments for VM_METHOD_TYPE_ATTRSET type methods. Normally, we can not use keyword arguments for this kind of methods, (obj.foo = 1), but we can set alias names for them. [Bug #11657] * test/ruby/test_keyword.rb: add a test for this fix. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_2@53567 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 11 +++++++++++ test/ruby/test_keyword.rb | 20 ++++++++++++++++++++ version.h | 10 +++++----- vm_insnhelper.c | 2 +- 4 files changed, 37 insertions(+), 6 deletions(-) diff --git a/ChangeLog b/ChangeLog index 7aeec8de85..0d57814ddf 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,14 @@ +Mon Jan 18 00:34:41 2016 Koichi Sasada + + * vm_insnhelper.c (vm_call_method): should not set fastpath + with keyword arguments for VM_METHOD_TYPE_ATTRSET type methods. + + Normally, we can not use keyword arguments for this kind of methods, + (obj.foo = 1), but we can set alias names for them. + [Bug #11657] + + * test/ruby/test_keyword.rb: add a test for this fix. + Wed Dec 23 06:05:50 2015 Nobuyoshi Nakada * parse.y (parser_yylex): allow here documents in labeled diff --git a/test/ruby/test_keyword.rb b/test/ruby/test_keyword.rb index 9c76e15c38..764bd959b1 100644 --- a/test/ruby/test_keyword.rb +++ b/test/ruby/test_keyword.rb @@ -576,4 +576,24 @@ class TestKeywordArguments < Test::Unit::TestCase h = method_for_test_to_hash_call_during_setup_complex_parameters k1: "foo", k2: "bar", sym => "baz" assert_equal ["foo", "bar", {sym => "baz"}], h, '[Bug #11027]' end + + class AttrSetTest + attr_accessor :foo + alias set_foo :foo= + end + + def test_attr_set_method_cache + obj = AttrSetTest.new + h = {a: 1, b: 2} + 2.times{ + obj.foo = 1 + assert_equal(1, obj.foo) + obj.set_foo 2 + assert_equal(2, obj.foo) + obj.set_foo(x: 1, y: 2) + assert_equal({x: 1, y: 2}, obj.foo) + obj.set_foo(x: 1, y: 2, **h) + assert_equal({x: 1, y: 2, **h}, obj.foo) + } + end end diff --git a/version.h b/version.h index c8f0fb8154..3b9822ce66 100644 --- a/version.h +++ b/version.h @@ -1,10 +1,10 @@ #define RUBY_VERSION "2.2.5" -#define RUBY_RELEASE_DATE "2015-12-23" -#define RUBY_PATCHLEVEL 235 +#define RUBY_RELEASE_DATE "2016-01-18" +#define RUBY_PATCHLEVEL 236 -#define RUBY_RELEASE_YEAR 2015 -#define RUBY_RELEASE_MONTH 12 -#define RUBY_RELEASE_DAY 23 +#define RUBY_RELEASE_YEAR 2016 +#define RUBY_RELEASE_MONTH 1 +#define RUBY_RELEASE_DAY 18 #include "ruby/version.h" diff --git a/vm_insnhelper.c b/vm_insnhelper.c index fae13e82c3..e5c8df6df9 100644 --- a/vm_insnhelper.c +++ b/vm_insnhelper.c @@ -1691,7 +1691,7 @@ vm_call_method(rb_thread_t *th, rb_control_frame_t *cfp, rb_call_info_t *ci) CALLER_SETUP_ARG(cfp, ci); rb_check_arity(ci->argc, 1, 1); ci->aux.index = 0; - CI_SET_FASTPATH(ci, vm_call_attrset, enable_fastpath && !(ci->flag & VM_CALL_ARGS_SPLAT)); + CI_SET_FASTPATH(ci, vm_call_attrset, enable_fastpath && !(ci->flag & VM_CALL_ARGS_SPLAT) && ci->kw_arg == NULL); return vm_call_attrset(th, cfp, ci); } case VM_METHOD_TYPE_IVAR:{