Module: OpenC3::CmdLog

Included in:
Api, Commands
Defined in:
lib/openc3/utilities/cmd_log.rb

Instance Method Summary collapse

Instance Method Details

#_build_cmd_output_string(method_name, target_name, cmd_name, cmd_params, packet) ⇒ Object



23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
# File 'lib/openc3/utilities/cmd_log.rb', line 23

def _build_cmd_output_string(method_name, target_name, cmd_name, cmd_params, packet)
  output_string = "#{method_name}(\""
  output_string << (target_name + ' ' + cmd_name)
  if cmd_params.nil? or cmd_params.empty?
    output_string << '")'
  else
    params = []
    cmd_params.each do |key, value|
      next if Packet::RESERVED_ITEM_NAMES.include?(key)

      item = packet['items'].find { |find_item| find_item['name'] == key.to_s }
      begin
        item_type = item['data_type'].intern
      rescue
        item_type = nil
      end

      if (item and item['obfuscate'])
        params << "#{key} *****"
      else
        if value.is_a?(String)
          value = value.dup
          if item_type == :BLOCK or item_type == :STRING
            if !value.is_printable?
              value = "0x" + value.simple_formatted
            else
              value = value.inspect
            end
          else
            value = value.convert_to_value.to_s
          end
          if value.length > 256
            value = value[0..255] + "...'"
          end
          value.tr!('"', "'")
        elsif value.is_a?(Array)
          value = "[#{value.join(", ")}]"
        end
        params << "#{key} #{value}"
      end
    end
    params = params.join(", ")
    output_string << (' with ' + params + '")')
  end
  return output_string
end