Issue #19375 has been updated by luke-gru (Luke Gruber).
Subject changed from File objects are currently shareable to File objects are currently
shareable, as are other extension objects that shouldn't be.
The issue is with `Ractor.make_shareable`
The same issue occurs with Dir, Tempfile, IO objects, the ENV hash. StringIO and CSV have
this problem too. Sockets I think have the issue.
For example, the issue with StringIO is that it needs an initialize_clone method that
dup's the string. The underlying issue, though, is that it's a TypedData and
doesn't
store its internals in instance variables to be checked by the sharing logic.
```ruby
require 'stringio'
str = "string".dup
stringio = StringIO.new(str)
rs = 100.times.map do
Ractor.new do
strio = receive
p strio.string.object_id
end
end
p stringio.string.object_id
rs.each do |r|
r.send(stringio)
end
rs.each(&:take)
```
----------------------------------------
Bug #19375: File objects are currently shareable, as are other extension objects that
shouldn't be.
https://bugs.ruby-lang.org/issues/19375#change-101446
* Author: luke-gru (Luke Gruber)
* Status: Open
* Priority: Normal
* Backport: 2.7: UNKNOWN, 3.0: UNKNOWN, 3.1: UNKNOWN, 3.2: UNKNOWN
----------------------------------------
I don't know the internals of file.c but I don't think files are thread-safe.
--
https://bugs.ruby-lang.org/