Class: Bashly::Models::Base

Inherits:
Object
  • Object
show all
Includes:
Renderable
Defined in:
lib/bashly/models/base.rb

Direct Known Subclasses

Argument, Command, EnvironmentVariable, Flag

Constant Summary collapse

OPTION_KEYS =
%i[
  arg
  dependencies
  description
  default
  environment_variables
  examples
  flags
  group
  help
  long
  name
  parent_name
  required
  short
  version
]

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Renderable

#render, #strings

Constructor Details

#initialize(options) ⇒ Base

Returns a new instance of Base.

Raises:



26
27
28
29
30
# File 'lib/bashly/models/base.rb', line 26

def initialize(options)
  raise Error, "Invalid options provided" unless options.respond_to? :keys
  @options = options
  verify if respond_to? :verify
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(method_name, *arguments, &block) ⇒ Object



44
45
46
47
# File 'lib/bashly/models/base.rb', line 44

def method_missing(method_name, *arguments, &block)
  key = method_name.to_s
  respond_to?(method_name) ? options[key] : super
end

Instance Attribute Details

#optionsObject (readonly)

Returns the value of attribute options.



6
7
8
# File 'lib/bashly/models/base.rb', line 6

def options
  @options
end

Instance Method Details

#helpObject



40
41
42
# File 'lib/bashly/models/base.rb', line 40

def help
  options['help'] ||= ''
end

#optionalObject



32
33
34
# File 'lib/bashly/models/base.rb', line 32

def optional
  !required
end

#respond_to?(method_name, include_private = false) ⇒ Boolean

Returns:

  • (Boolean)


49
50
51
# File 'lib/bashly/models/base.rb', line 49

def respond_to?(method_name, include_private = false)
  OPTION_KEYS.include?(method_name) || super
end

#summaryObject



36
37
38
# File 'lib/bashly/models/base.rb', line 36

def summary
  help.empty? ? "" : help.split("\n").first
end