module RedisClient::ConnectionMixin

def call(command, timeout)

def call(command, timeout)
  @pending_reads += 1
  write(command)
  result = read(connection_timeout(timeout))
  @pending_reads -= 1
  if result.is_a?(Error)
    result._set_command(command)
    result._set_config(config)
    raise result
  else
    result
  end
end

def call_pipelined(commands, timeouts, exception: true)

def call_pipelined(commands, timeouts, exception: true)
  first_exception = nil
  size = commands.size
  results = Array.new(commands.size)
  @pending_reads += size
  write_multi(commands)
  size.times do |index|
    timeout = timeouts && timeouts[index]
    result = read(connection_timeout(timeout))
    @pending_reads -= 1
    # A multi/exec command can return an array of results.
    # An error from a multi/exec command is handled in Multi#_coerce!.
    if result.is_a?(Array)
      result.each do |res|
        res._set_config(config) if res.is_a?(Error)
      end
    elsif result.is_a?(Error)
      result._set_command(commands[index])
      result._set_config(config)
      first_exception ||= result
    end
    results[index] = result
  end
  if first_exception && exception
    raise first_exception
  else
    results
  end
end

def close

def close
  @pending_reads = 0
  nil
end

def connection_timeout(timeout)

def connection_timeout(timeout)
  return timeout unless timeout && timeout > 0
  # Can't use the command timeout argument as the connection timeout
  # otherwise it would be very racy. So we add the regular read_timeout on top
  # to account for the network delay.
  timeout + config.read_timeout
end

def initialize

def initialize
  @pending_reads = 0
end

def reconnect

def reconnect
  close
  connect
end

def revalidate

def revalidate
  if @pending_reads > 0
    close
    false
  else
    connected?
  end
end