lib/axiom/relation/operation/set.rb

Summary

Maintainability
A
0 mins
Test Coverage
# encoding: utf-8

module Axiom
  class Relation
    module Operation

      # A mixin for Set relations
      module Set
        include Binary

        # Hook called when module is included
        #
        # @param [Module] descendant
        #   the module or class including Set
        #
        # @return [undefined]
        #
        # @api private
        def self.included(descendant)
          super
          descendant.extend(ClassMethods)
        end

        private_class_method :included

        # Initialize a Set
        #
        # @param [Relation] _left
        # @param [Relation] _right
        #
        # @return [undefined]
        #
        # @api private
        def initialize(_left, _right)
          super
          @header = left.header
        end

        module ClassMethods

          # Instantiate a new Set relation
          #
          # @example
          #   set = SetRelation.new(left, right)
          #
          # @param [Array(Relation, Relation)] args
          #
          # @return [Set]
          #
          # @api public
          def new(*args)
            assert_equivalent_headers(*args)
            super
          end

        private

          # Assert that left and right have equivalent headers
          #
          # @param [Relation] left
          # @param [Relation] right
          #
          # @return [undefined]
          #
          # @raise [InvalidHeaderError]
          #   raised if the headers are not equivalent
          #
          # @api private
          def assert_equivalent_headers(left, right)
            return if left.header == right.header
            fail InvalidHeaderError, 'the headers must be equivalent'
          end

        end # module ClassMethods
      end # module Set
    end # module Operation
  end # class Relation
end # module Axiom