class Byebug::Setting


Parent class for all byebug settings.

def [](name)

def [](name)
  settings[name].value
end

def []=(name, value)

def []=(name, value)
  settings[name].value = value
end

def boolean?

def boolean?
  [true, false].include?(value)
end

def find(shortcut)

def find(shortcut)
  abbr = shortcut =~ /^no/ ? shortcut[2..-1] : shortcut
  matches = settings.select do |key, value|
    key =~ (value.boolean? ? /#{abbr}/ : /#{shortcut}/)
  end
  matches.size == 1 ? matches.values.first : nil
end

def help

def help
  prettify(banner)
end

def help_all

Other tags:
    Todo: - DRY this up. Very similar code exists in the CommandList class
def help_all
  output = "  List of supported settings:\n\n"
  width = settings.keys.max_by(&:size).size
  settings.values.each do |sett|
    output << format("  %-#{width}s -- %s\n", sett.to_sym, sett.banner)
  end
  output + "\n"
end

def initialize

def initialize
  @value = self.class::DEFAULT
end

def integer?

def integer?
  Integer(value) ? true : false
rescue ArgumentError
  false
end

def settings

def settings
  @settings ||= {}
end

def to_s

def to_s
  "#{to_sym} is #{value ? 'on' : 'off'}\n"
end

def to_sym

def to_sym
  name = self.class.name.gsub(/^Byebug::/, '').gsub(/Setting$/, '')
  name.gsub(/(.)([A-Z])/, '\1_\2').downcase.to_sym
end