module RedisClient::ConnectionMixin

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