Class: Remap::Mapper::Xor

Inherits:
Binary show all
Defined in:
lib/remap/mapper/xor.rb

Overview

Represents two mappers that are combined with the ^ operator

Examples:

Combine two mappers

class Mapper1 < Remap::Base
  contract do
    required(:a1)
  end
end

class Mapper2 < Remap::Base
  contract do
    required(:a2)
  end
end

state = Remap::State.call({ a2: 2 })
output = (Mapper1 ^ Mapper2).call!(state)
output.fetch(:value) # => { a2: 2 }

Instance Method Summary collapse

Methods inherited from Binary

#validate?

Methods included from API

#call, #validate?

Methods included from Operations

#&, #^, #|

Instance Method Details

#call!(state) {|if| ... } ⇒ Result

Succeeds if left or right succeeds, but not both

Parameters:

Yield Parameters:

Yield Returns:

Returns:

  • (Result)


34
35
36
37
38
39
40
41
42
43
44
45
46
# File 'lib/remap/mapper/xor.rb', line 34

def call!(state, &error)
  state1 = left.call!(state) do |failure1|
    return right.call!(state) do |failure2|
      return error[failure1.merge(failure2)]
    end
  end

  state2 = right.call!(state) do
    return state1
  end

  state1.combine(state2).failure("Both left and right passed xor operation").then(&error)
end

#inspectString Also known as: to_s

Returns:

  • (String)


49
50
51
# File 'lib/remap/mapper/xor.rb', line 49

def inspect
  "%s ^ %s" % [left, right]
end