Sha256: df8ab0dcca2dc7dc48b6d3497d536da5e35596f02515f17476b9829ae348f1d5
Contents?: true
Size: 830 Bytes
Versions: 2
Compression:
Stored size: 830 Bytes
Contents
# frozen_string_literal: true require "concurrent/promise" require "dry/effects/provider" require "dry/effects/frame" module Dry module Effects module Providers class Parallel < Provider[:parallel] include ::Dry::Equalizer(:executor, inspect: false) option :executor, default: -> { :io } attr_reader :stack def par stack = self.stack.dup proc do |&block| ::Concurrent::Promise.execute(executor: executor) do Frame.spawn_fiber(stack, &block) end end end def join(xs) xs.map(&:value!) end # Yield the block with the handler installed # # @api private def call @stack = Frame.stack yield end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
dry-effects-0.3.0 | lib/dry/effects/providers/parallel.rb |
dry-effects-0.2.0 | lib/dry/effects/providers/parallel.rb |