Class: Cosmos::Processor

Inherits:
Object show all
Defined in:
lib/cosmos/processors/processor.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(value_type = :CONVERTED) ⇒ Processor

Create a new Processor

Parameters:

  • value_type (Symbol or String) (defaults to: :CONVERTED)

    the value type to process

Raises:

  • (ArgumentError)


26
27
28
29
30
31
32
# File 'lib/cosmos/processors/processor.rb', line 26

def initialize(value_type = :CONVERTED)
  @name = self.class.to_s.upcase
  value_type = value_type.to_s.upcase.intern
  @value_type = value_type
  raise ArgumentError, "value_type must be RAW, CONVERTED, FORMATTED, or WITH_UNITS. Is #{@value_type}" unless Packet::VALUE_TYPES.include?(@value_type)
  @results = {}
end

Instance Attribute Details

#nameString

Returns The processor name.

Returns:

  • (String)

    The processor name



19
20
21
# File 'lib/cosmos/processors/processor.rb', line 19

def name
  @name
end

#resultsHash

Returns The results of the most recent execution of the processor.

Returns:

  • (Hash)

    The results of the most recent execution of the processor



22
23
24
# File 'lib/cosmos/processors/processor.rb', line 22

def results
  @results
end

#value_typeSymbol (readonly)

Returns The value type for the processor.

Returns:

  • (Symbol)

    The value type for the processor



16
17
18
# File 'lib/cosmos/processors/processor.rb', line 16

def value_type
  @value_type
end

Instance Method Details

#call(packet, buffer) ⇒ Object

Perform processing on the packet.

Parameters:

  • packet (Packet)

    The packet which contains the value. This can be useful to reach into the packet and use other values in the conversion.

  • buffer (String)

    The packet buffer

Returns:

  • The processed result



45
46
47
# File 'lib/cosmos/processors/processor.rb', line 45

def call(packet, buffer)
  raise "call method must be defined by subclass"
end

#cloneProcessor Also known as: dup

Make a light weight clone of this processor. This only creates a new hash of results

Returns:

  • (Processor)

    A copy of the processor with a new hash of results



62
63
64
65
66
# File 'lib/cosmos/processors/processor.rb', line 62

def clone
  processor = super()
  processor.results = processor.results.clone
  processor
end

#resetObject

Reset any state



55
56
57
# File 'lib/cosmos/processors/processor.rb', line 55

def reset
  # By default do nothing
end

#to_sString

Returns The processor class.

Returns:

  • (String)

    The processor class



50
51
52
# File 'lib/cosmos/processors/processor.rb', line 50

def to_s
  self.class.to_s.split('::')[-1]
end