From: dblock@...
Date: 2016-04-06T18:26:27+00:00
Subject: [ruby-core:74833] [Ruby trunk Bug#12136] OpenStruct.new(format: :bar).send :format # => too few arguments

Issue #12136 has been updated by Daniel Doubrovkine.


> a) Keep behavior the same and rubyists can alleviate these by using `public_send` instead of `send`

It doesn't seem that swapping `send` by `public_send` has any effect.

Is there a workaround for existing code that would make things work the way it worked in Ruby 2.2.x?

----------------------------------------
Bug #12136: OpenStruct.new(format: :bar).send :format # => too few arguments
https://bugs.ruby-lang.org/issues/12136#change-57964

* Author: Niko Dittmann
* Status: Open
* Priority: Normal
* Assignee: 
* ruby -v: ruby 2.3.0p0 (2015-12-25 revision 53290) [x86_64-linux]
* Backport: 2.1: UNKNOWN, 2.2: UNKNOWN, 2.3: UNKNOWN
----------------------------------------
#send(:format) to an OpenStruct with a field named :format raises an ArgumentError in Ruby 2.3.0:

~~~
OpenStruct.new(format: :bar).send :format
ArgumentError: too few arguments
~~~

It works as expected in ruby 2.2.1p85 (2015-02-26 revision 49769) [x86_64-linux] and with any other method name I tried:

~~~
OpenStruct.new(f: :bar).send :f
=> :bar
~~~

String or Symbol in the OpenStruct definition and as argument of #send make no difference.



-- 
https://bugs.ruby-lang.org/

Unsubscribe: <mailto:ruby-core-request@ruby-lang.org?subject=unsubscribe>
<http://lists.ruby-lang.org/cgi-bin/mailman/options/ruby-core>