Class: OpenC3::UnixTimeConversion

Inherits:
Conversion show all
Defined in:
lib/openc3/conversions/unix_time_conversion.rb

Overview

Converts a unix format time: Epoch Jan 1 1970, seconds and microseconds

Instance Attribute Summary

Attributes inherited from Conversion

#converted_array_size, #converted_bit_size, #converted_type

Instance Method Summary collapse

Constructor Details

#initialize(seconds_item_name, microseconds_item_name = nil, seconds_type = 'RAW', microseconds_type = 'RAW') ⇒ UnixTimeConversion

Initializes the time item to grab from the packet

Parameters:

  • seconds_item_name (String)

    The telemetry item in the packet which represents the number of seconds since the UNIX time epoch

  • microseconds_item_name (String) (defaults to: nil)

    The telemetry item in the packet which represents microseconds



34
35
36
37
38
39
40
41
42
# File 'lib/openc3/conversions/unix_time_conversion.rb', line 34

def initialize(seconds_item_name, microseconds_item_name = nil, seconds_type = 'RAW', microseconds_type = 'RAW')
  super()
  @seconds_item_name = seconds_item_name
  @microseconds_item_name = microseconds_item_name
  @converted_type = :RUBY_TIME
  @converted_bit_size = 0
  @seconds_type = seconds_type.to_sym
  @microseconds_type = microseconds_type.to_sym
end

Instance Method Details

#as_json(*a) ⇒ Object



69
70
71
72
73
# File 'lib/openc3/conversions/unix_time_conversion.rb', line 69

def as_json(*a)
  result = super(*a)
  result['params'] = [@seconds_item_name, @microseconds_item_name, @seconds_type, @microseconds_type]
  result
end

#call(value, packet, buffer) ⇒ Float

Returns Packet time in seconds since UNIX epoch.

Parameters:

  • value (Object)

    The value to convert

  • 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:

  • (Float)

    Packet time in seconds since UNIX epoch



46
47
48
49
50
51
52
# File 'lib/openc3/conversions/unix_time_conversion.rb', line 46

def call(value, packet, buffer)
  if @microseconds_item_name
    return Time.at(packet.read(@seconds_item_name, @seconds_type, buffer), packet.read(@microseconds_item_name, @microseconds_type, buffer)).sys
  else
    return Time.at(packet.read(@seconds_item_name, @seconds_type, buffer), 0).sys
  end
end

#to_config(read_or_write) ⇒ String

Returns Config fragment for this conversion.

Parameters:

  • read_or_write (String)

    Either 'READ' or 'WRITE'

Returns:

  • (String)

    Config fragment for this conversion



65
66
67
# File 'lib/openc3/conversions/unix_time_conversion.rb', line 65

def to_config(read_or_write)
  "    #{read_or_write}_CONVERSION #{self.class.name.class_name_to_filename} #{@seconds_item_name} #{@microseconds_item_name}\n"
end

#to_sString

Returns The name of the class followed by the time conversion.

Returns:

  • (String)

    The name of the class followed by the time conversion



55
56
57
58
59
60
61
# File 'lib/openc3/conversions/unix_time_conversion.rb', line 55

def to_s
  if @microseconds_item_name
    return "Time.at(packet.read('#{@seconds_item_name}', :#{@seconds_type}, buffer), packet.read('#{@microseconds_item_name}', :#{@microseconds_type}, buffer)).sys"
  else
    return "Time.at(packet.read('#{@seconds_item_name}', :#{@seconds_type}, buffer), 0).sys"
  end
end