Actions
Bug #21260
closedduping stringio objects shares cursors
    Bug #21260:
    duping stringio objects shares cursors
  
Status:
Feedback
Assignee:
-
Target version:
-
ruby -v:
ruby 3.4.2 (2025-02-15 revision d2930f8e7a) +PRISM [x86_64-darwin23]
Description
I've found that, if I .dup a stringio, when I read one of the objects, the cursor also moves internally on the other:
require "stringio"
s1 = StringIO.new("test")
s2 = s1.dup
s1.read #=> "test"
s2.read #=> ""
s1.rewind
s2.rewind
s2.read #=> "test"
s1.read #=> ""
s1.pos #=> 4
s2.pos #=> 4
        
           Updated by jeremyevans0 (Jeremy Evans) 7 months ago
          Updated by jeremyevans0 (Jeremy Evans) 7 months ago
          
          
        
        
      
      This is how IO#dup works. What would be the benefit of StringIO#dup behaving differently?
f = File.open('filename.rb')
f2 = f.dup
f2.pos # => 0
f.read 4
f2.pos # => 4
        
           Updated by nobu (Nobuyoshi Nakada) 7 months ago
          Updated by nobu (Nobuyoshi Nakada) 7 months ago
          
          
        
        
      
      - Status changed from Open to Feedback
        
           Updated by chucke (Tiago Cardoso) 7 months ago
          Updated by chucke (Tiago Cardoso) 7 months ago
          
          
        
        
      
      I see. Alignment with File makes sense. At least my expectation was that, by dup'ing the IO object, I'd receive a separate independent object with which to traverse the file. But perhaps that does not make sense, as at least in the case of File, that'd mean a second OS file descriptor, and that's heavy? Also not sure whether this expectation is general.
Actions