Class: Bashly::Models::Base
- Inherits:
-
Object
- Object
- Bashly::Models::Base
show all
- Includes:
- Renderable
- Defined in:
- lib/bashly/models/base.rb
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.
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
#options ⇒ Object
Returns the value of attribute options.
6
7
8
|
# File 'lib/bashly/models/base.rb', line 6
def options
@options
end
|
Instance Method Details
#help ⇒ Object
40
41
42
|
# File 'lib/bashly/models/base.rb', line 40
def help
options['help'] ||= ''
end
|
#optional ⇒ Object
32
33
34
|
# File 'lib/bashly/models/base.rb', line 32
def optional
!required
end
|
#respond_to?(method_name, include_private = false) ⇒ 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
|
#summary ⇒ Object
36
37
38
|
# File 'lib/bashly/models/base.rb', line 36
def summary
help.empty? ? "" : help.split("\n").first
end
|