class RedisClient::RubyConnection::BufferedIO

Experimental RBS support (using type sampling data from the type_fusion project).

# sig/redis_client/ruby_connection/buffered_io.rbs

class RedisClient::RubyConnection::BufferedIO
  def closed?: () -> untyped
  def ensure_remaining: (Integer bytes) -> untyped
  def fill_buffer: (true strict, ?Integer size) -> untyped
  def getbyte: () -> untyped
  def gets_chomp: () -> untyped
  def read_chomp: (Integer bytes) -> untyped
end

def close

def close
  @io.to_io.close
end

def closed?

Experimental RBS support (using type sampling data from the type_fusion project).

def closed?: () -> untyped

This signature was generated using 1 sample from 1 application.

def closed?
  @io.to_io.closed?
end

def ensure_remaining(bytes)

Experimental RBS support (using type sampling data from the type_fusion project).

def ensure_remaining: (Integer bytes) -> untyped

This signature was generated using 6 samples from 1 application.

def ensure_remaining(bytes)
  needed = bytes - (@buffer.bytesize - @offset)
  if needed > 0
    fill_buffer(true, needed)
  end
end

def eof?

def eof?
  @offset >= @buffer.bytesize && @io.eof?
end

def fill_buffer(strict, size = @chunk_size)

Experimental RBS support (using type sampling data from the type_fusion project).

def fill_buffer: (true strict, ?Integer size) -> untyped

This signature was generated using 1 sample from 1 application.

def fill_buffer(strict, size = @chunk_size)
  remaining = size
  empty_buffer = @offset >= @buffer.bytesize
  loop do
    bytes = if empty_buffer
      @io.read_nonblock([remaining, @chunk_size].max, @buffer, exception: false)
    else
      @io.read_nonblock([remaining, @chunk_size].max, exception: false)
    end
    case bytes
    when String
      if empty_buffer
        @offset = 0
        empty_buffer = false
      else
        @buffer << bytes
      end
      remaining -= bytes.bytesize
      return if !strict || remaining <= 0
    when :wait_readable
      unless @io.to_io.wait_readable(@read_timeout)
        raise ReadTimeoutError, "Waited #{@read_timeout} seconds" unless @blocking_reads
      end
    when :wait_writable
      @io.to_io.wait_writable(@write_timeout) or raise(WriteTimeoutError, "Waited #{@write_timeout} seconds")
    when nil
      raise EOFError
    else
      raise "Unexpected `read_nonblock` return: #{bytes.inspect}"
    end
  end
end

def getbyte

Experimental RBS support (using type sampling data from the type_fusion project).

def getbyte: () -> untyped

This signature was generated using 4 samples from 1 application.

def getbyte
  ensure_remaining(1)
  byte = @buffer.getbyte(@offset)
  @offset += 1
  byte
end

def gets_chomp

Experimental RBS support (using type sampling data from the type_fusion project).

def gets_chomp: () -> untyped

This signature was generated using 3 samples from 1 application.

def gets_chomp
  fill_buffer(false) if @offset >= @buffer.bytesize
  until eol_index = @buffer.index(EOL, @offset)
    fill_buffer(false)
  end
  line = @buffer.byteslice(@offset, eol_index - @offset)
  @offset = eol_index + EOL_SIZE
  line
end

def initialize(io, read_timeout:, write_timeout:, chunk_size: 4096)

def initialize(io, read_timeout:, write_timeout:, chunk_size: 4096)
  @io = io
  @buffer = "".b
  @offset = 0
  @chunk_size = chunk_size
  @read_timeout = read_timeout
  @write_timeout = write_timeout
  @blocking_reads = false
end

def read_chomp(bytes)

Experimental RBS support (using type sampling data from the type_fusion project).

def read_chomp: (Integer bytes) -> untyped

This signature was generated using 2 samples from 1 application.

def read_chomp(bytes)
  ensure_remaining(bytes + EOL_SIZE)
  str = @buffer.byteslice(@offset, bytes)
  @offset += bytes + EOL_SIZE
  str
end

def skip(offset)

def skip(offset)
  ensure_remaining(offset)
  @offset += offset
  nil
end

def with_timeout(new_timeout)

def with_timeout(new_timeout)
  new_timeout = false if new_timeout == 0
  previous_read_timeout = @read_timeout
  previous_blocking_reads = @blocking_reads
  if new_timeout
    @read_timeout = new_timeout
  else
    @blocking_reads = true
  end
  begin
    yield
  ensure
    @read_timeout = previous_read_timeout
    @blocking_reads = previous_blocking_reads
  end
end

def write(string)

def write(string)
  total = remaining = string.bytesize
  loop do
    case bytes_written = @io.write_nonblock(string, exception: false)
    when Integer
      remaining -= bytes_written
      if remaining > 0
        string = string.byteslice(bytes_written..-1)
      else
        return total
      end
    when :wait_readable
      @io.to_io.wait_readable(@read_timeout) or raise(ReadTimeoutError, "Waited #{@read_timeout} seconds")
    when :wait_writable
      @io.to_io.wait_writable(@write_timeout) or raise(WriteTimeoutError, "Waited #{@write_timeout} seconds")
    when nil
      raise Errno::ECONNRESET
    else
      raise "Unexpected `write_nonblock` return: #{bytes.inspect}"
    end
  end
end