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