houdini/lib/parallel_ar.rb
2019-08-02 19:07:29 +02:00

17 lines
438 B
Ruby

# frozen_string_literal: true
# License: AGPL-3.0-or-later WITH Web-Template-Output-Additional-Permission-3.0-or-later
require 'parallel'
module ParallelAr
def self.reduce(arr, accum, &block)
Parallel.each(arr, in_threads: 8) do |elem|
ActiveRecord::Base.connection_pool.with_connection do
ActiveRecord::Base.transaction do
accum = block.call(accum, elem)
end
end
end
accum
end
end