2019-07-30 21:29:24 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2020-06-12 20:03:43 +00:00
|
|
|
# License: AGPL-3.0-or-later WITH WTO-AP-3.0-or-later
|
|
|
|
# Full license explanation at https://github.com/houdiniproject/houdini/blob/master/LICENSE
|
2018-03-25 17:30:42 +00:00
|
|
|
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
|
2019-07-30 21:29:24 +00:00
|
|
|
accum
|
2018-03-25 17:30:42 +00:00
|
|
|
end
|
|
|
|
end
|