Actions
Bug #17545
closedCalling dup on a subclass of Proc returns a Proc and not the subclass
Description
Trivial example:
[1] pry(main)> class Test < Proc; end
=> nil
[3] pry(main)> Test.new { puts "foo" }.dup
=> #<Proc:0x00007f91a78913c8 (pry):3>
Also fairly trivial workaround:
[4] pry(main)> class Test < Proc
[4] pry(main)* def dup
[4] pry(main)* self.class.new(&super)
[4] pry(main)* end
[4] pry(main)* end
=> :dup
[5] pry(main)> Test.new { puts "foo" }.dup
=> #<Test:0x00007f91b8e73e38 (pry):9>
Seems like a bug though, Proc#dup is probably calling the ruby-c equivalent of Proc.new rather than self.class.new and bypassing subclassing
Updated by ko1 (Koichi Sasada) over 3 years ago
- Status changed from Open to Assigned
- Assignee set to ko1 (Koichi Sasada)
This behavior is from ruby 1.9.
Matz, is it a bug?
@all-ruby -e 'class Test < Proc; end; p Test.new { puts "foo" }.dup.class'
:ok: 1.8
Test
:ok: 1.9 -- 98e27016c9 (2021-01-29T07:22:12Z)
Proc
Updated by ko1 (Koichi Sasada) over 3 years ago
Fix is easy:
https://github.com/ruby/ruby/pull/4197
Updated by matz (Yukihiro Matsumoto) over 3 years ago
It should be an instance of the subclass for consistency. But considering that we discourage the use of subclass for the standard class, the fix should not be applied soon. Maybe 3.2 or later.
Matz.
Updated by ko1 (Koichi Sasada) over 2 years ago
- Status changed from Assigned to Closed
Applied in changeset git|7e21b77dc6bfefaf331a0dbf89782303b8cda05d.
T#dup (T < Proc) should return T's object
T#dup (T < Proc) returns Proc object (not T) from Ruby 1.9.
[Bug #17545]
Actions
Like0
Like0Like0Like0Like0