Sha256: f95e852cfe794863f26465221dfffe656dda14033ffe0ed304838acf5f0ec3b1
Contents?: true
Size: 658 Bytes
Versions: 2
Compression:
Stored size: 658 Bytes
Contents
# frozen_string_literal: true require 'concurrent/promise' require 'dry/effects/provider' module Dry module Effects module Providers class Parallel < Provider[:parallel] option :executor, default: -> { :io } attr_reader :stack def par stack = self.stack.dup proc do |&block| ::Concurrent::Promise.execute(executor: executor) do Handler.spawn_fiber(stack, &block) end end end def join(xs) xs.map(&:value!) end def call(stack) @stack = stack super end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
dry-effects-0.1.0.alpha2 | lib/dry/effects/providers/parallel.rb |
dry-effects-0.1.0.alpha | lib/dry/effects/providers/parallel.rb |