Class: Multipart::Post::CompositeReadIO

Inherits:
Object
  • Object
show all
Defined in:
lib/multipart/post/composite_read_io.rb

Overview

Concatenate together multiple IO objects into a single, composite IO object for purposes of reading as a single stream.

Examples:

crio = CompositeReadIO.new(StringIO.new('one'),
                           StringIO.new('two'),
                           StringIO.new('three'))
puts crio.read # => "onetwothree"

Instance Method Summary collapse

Constructor Details

#initialize(*ios) ⇒ CompositeReadIO

Create a new composite-read IO from the arguments, all of which should respond to #read in a manner consistent with IO.



31
32
33
34
# File 'lib/multipart/post/composite_read_io.rb', line 31

def initialize(*ios)
  @ios = ios.flatten
  @index = 0
end

Instance Method Details

#read(length = nil, outbuf = nil) ⇒ Object

Read from IOs in order until ‘length` bytes have been received.



37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
# File 'lib/multipart/post/composite_read_io.rb', line 37

def read(length = nil, outbuf = nil)
  got_result = false
  outbuf = outbuf ? outbuf.replace("") : String.new

  while io = current_io
    if result = io.read(length)
      got_result ||= !result.nil?
      result.force_encoding("BINARY") if result.respond_to?(:force_encoding)
      outbuf << result
      length -= result.length if length
      break if length == 0
    end
    advance_io
  end
  (!got_result && length) ? nil : outbuf
end

#rewindObject



54
55
56
57
# File 'lib/multipart/post/composite_read_io.rb', line 54

def rewind
  @ios.each { |io| io.rewind }
  @index = 0
end