Wed, 12 Apr 2023 16:23:02 +0200
Reduced I2C master speed from 400 to 100 Khz. Hope to get power-on init for BMP280 more reliable. Added warnings for I2C devices that are missing. Some logmessages reduced to debug log messages. Added extra 10 mSec delays before read shunt voltage in the INA219 task. Removed and reduced log levels in the MQTT task. Show received data events. Remove WiFi total time debug logging, it's ok now.
# frozen_string_literal: true require "yaml" # A class that represents build target class Target VALID_KEYS = %w[name].freeze TARGETS_FILE = File.expand_path(File.join(File.dirname("__FILE__"), "..", "targets.yml")).freeze def initialize(arg) validate_arg(arg) validate_keys(arg) if arg.is_a?(Hash) @metadata = if arg.is_a?(String) { "name" => arg } else arg end end attr_reader :metadata def valid_arg_class?(arg) arg.is_a?(String) || arg.is_a?(Hash) end def validate_arg(arg) raise ArgumentError, "String or dict is ecpected, but got `#{arg.class}`" unless valid_arg_class?(arg) end def validate_keys(hash) hash.each_key do |k| raise ArgumentError, "unknown key: `#{k}`. valid keys are: #{VALID_KEYS.join(' ')}" unless VALID_KEYS.include?(k) end end def name? metadata.key?("name") end def name metadata["name"] end def load_file File.read(TARGETS_FILE) end def parse(string) YAML.safe_load(string) rescue StandardError => e warn "failed to parse #{TARGETS_FILE} as YAML" raise e end def targets return @targets if @targets @targets = parse(load_file) end def lookup(name) targets.select { |t| t.name == name } end end