Sha256: 5bb41976609f281bad2948eaeecc277e7e1ede00a9e9b928444142d53e22cea9

Contents?: true

Size: 767 Bytes

Versions: 1

Compression:

Stored size: 767 Bytes

Contents

# frozen_string_literal: true
module Speculation
  # @private
  class MergeSpec < SpecImpl
    include NamespacedSymbols
    S = Speculation

    def initialize(preds)
      @preds = preds
    end

    def conform(x)
      ms = @preds.map { |pred| S.dt(pred, x) }

      if ms.any?(&S.method(:invalid?))
        ns(S, :invalid)
      else
        ms.reduce(&:merge)
      end
    end

    def explain(path, via, inn, x)
      @preds.
        flat_map { |pred| S.explain1(pred, path, via, inn, x) }.
        compact
    end

    def gen(overrides, path, rmap)
      return @gen if @gen

      gens = @preds.
        map { |pred| S.gensub(pred, overrides, path, rmap) }

      ->(r) do
        gens.map { |gen| gen.call(r) }.reduce(&:merge)
      end
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
speculation-0.2.0 lib/speculation/spec_impl/merge_spec.rb