Sha256: c0e9dfcbe9787aa5453907acdf906657feb52147b6127acdb8daecc651341642

Contents?: true

Size: 1.87 KB

Versions: 12

Compression:

Stored size: 1.87 KB

Contents

# frozen_string_literal: true

require 'set'

module Leftovers
  module MatcherBuilders
    module Or
      def self.each_or_self(value, &block)
        case value
        when nil then nil
        when Array then build(value.map(&block))
        else build([yield(value)])
        end
      end

      def self.build(matchers)
        matchers = compact(matchers)
        case matchers.length
          # :nocov:
        when 0 then nil
          # :nocov:
        when 1 then matchers.first
        when 2 then ::Leftovers::Matchers::Or.new(matchers.first, matchers[1])
        else ::Leftovers::Matchers::Any.new(matchers.dup)
        end
      end

      def self.flatten(value) # rubocop:disable Metrics/MethodLength
        case value
        when ::Leftovers::Matchers::Or
          [*flatten(value.lhs), *flatten(value.rhs)]
        when ::Leftovers::Matchers::Any
          flatten(value.matchers)
        when Array
          ret = value.map { |v| flatten(v) }
          ret.flatten!(1)
          ret
        else
          value
        end
      end

      def self.compact(matchers) # rubocop:disable Metrics/MethodLength, Metrics/CyclomaticComplexity, Metrics/AbcSize,
        return matchers if matchers.length <= 1

        set = Set.new
        regexps = []
        uncompactable = []

        matchers = flatten(matchers)

        matchers.each do |matcher|
          case matcher
          when nil then nil
          when ::Integer, ::Symbol then set << matcher
          # when ::Set then set.merge(matcher) # may not be necessary
          when ::Regexp then regexps << matcher
          else uncompactable << matcher
          end
        end

        set = set.first if set.length <= 1
        regexps = if regexps.length <= 1
          regexps.first
        else
          Regexp.union(regexps)
        end

        [set, regexps].compact.concat(uncompactable)
      end
    end
  end
end

Version data entries

12 entries across 12 versions & 1 rubygems

Version Path
leftovers-0.7.0 lib/leftovers/matcher_builders/or.rb
leftovers-0.6.0 lib/leftovers/matcher_builders/or.rb
leftovers-0.5.5 lib/leftovers/matcher_builders/or.rb
leftovers-0.5.4 lib/leftovers/matcher_builders/or.rb
leftovers-0.5.3 lib/leftovers/matcher_builders/or.rb
leftovers-0.5.2 lib/leftovers/matcher_builders/or.rb
leftovers-0.5.1 lib/leftovers/matcher_builders/or.rb
leftovers-0.5.0 lib/leftovers/matcher_builders/or.rb
leftovers-0.4.3 lib/leftovers/matcher_builders/or.rb
leftovers-0.4.2 lib/leftovers/matcher_builders/or.rb
leftovers-0.4.1 lib/leftovers/matcher_builders/or.rb
leftovers-0.4.0 lib/leftovers/matcher_builders/or.rb