Module: Shell::Extensions::ObjectCoreExtensions
- Defined in:
- lib/chef/shell/ext.rb
Overview
Extensions to be included in every ‘main’ object in chef-shell. These objects are extended with this module.
Instance Method Summary collapse
- #all_help_descriptions ⇒ Object
- #desc(help_text) ⇒ Object
- #ensure_session_select_defined ⇒ Object
- #explain(explain_text) ⇒ Object
- #explain_command(method_name) ⇒ Object
- #find_or_create_session_for(context_obj) ⇒ Object
- #help_banner ⇒ Object
- #help_descriptions ⇒ Object
-
#off ⇒ Object
returns
:off
so you can just do ‘tracing off’. -
#on ⇒ Object
helpfully returns
:on
so we can have sugary syntax like ‘tracing on’. - #singleton_method_added(mname) ⇒ Object
- #subcommands(subcommand_help = {}) ⇒ Object
Instance Method Details
#all_help_descriptions ⇒ Object
116 117 118 |
# File 'lib/chef/shell/ext.rb', line 116 def all_help_descriptions help_descriptions end |
#desc(help_text) ⇒ Object
120 121 122 |
# File 'lib/chef/shell/ext.rb', line 120 def desc(help_text) @desc = help_text end |
#ensure_session_select_defined ⇒ Object
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'lib/chef/shell/ext.rb', line 38 def ensure_session_select_defined # irb breaks if you prematurely define IRB::JobMangager # so these methods need to be defined at the latest possible time. unless jobs.respond_to?(:select_session_by_context) def jobs.select_session_by_context(&block) @jobs.select { |job| block.call(job[1].context.main)} end end unless jobs.respond_to?(:session_select) def jobs.select_shell_session(target_context) session = if target_context.kind_of?(Class) select_session_by_context { |main| main.kind_of?(target_context) } else select_session_by_context { |main| main.equal?(target_context) } end Array(session.first)[1] end end end |
#explain(explain_text) ⇒ Object
124 125 126 |
# File 'lib/chef/shell/ext.rb', line 124 def explain(explain_text) @explain = explain_text end |
#explain_command(method_name) ⇒ Object
86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 |
# File 'lib/chef/shell/ext.rb', line 86 def explain_command(method_name) help = self.all_help_descriptions.find { |h| h.cmd.to_s == method_name.to_s } if help puts "" puts "Command: #{method_name}" puts "".ljust(80, "=") puts help.explanation || help.desc puts "".ljust(80, "=") puts "" else puts "" puts "command #{method_name} not found or no help available" puts "" end end |
#find_or_create_session_for(context_obj) ⇒ Object
59 60 61 62 63 64 65 66 |
# File 'lib/chef/shell/ext.rb', line 59 def find_or_create_session_for(context_obj) ensure_session_select_defined if subsession = jobs.select_shell_session(context_obj) jobs.switch(subsession) else irb(context_obj) end end |
#help_banner ⇒ Object
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 |
# File 'lib/chef/shell/ext.rb', line 68 def = [] << "" << "chef-shell Help" << "".ljust(80, "=") << "| " + "Command".ljust(25) + "| " + "Description" << "".ljust(80, "=") self.all_help_descriptions.each do |help_text| << "| " + help_text.cmd.ljust(25) + "| " + help_text.desc end << "".ljust(80, "=") << "\n" << "Use help(:command) to get detailed help with individual commands" << "\n" .join("\n") end |
#help_descriptions ⇒ Object
112 113 114 |
# File 'lib/chef/shell/ext.rb', line 112 def help_descriptions @help_descriptions ||= [] end |
#off ⇒ Object
returns :off
so you can just do ‘tracing off’
108 109 110 |
# File 'lib/chef/shell/ext.rb', line 108 def off :off end |
#on ⇒ Object
helpfully returns :on
so we can have sugary syntax like ‘tracing on’
103 104 105 |
# File 'lib/chef/shell/ext.rb', line 103 def on :on end |
#singleton_method_added(mname) ⇒ Object
132 133 134 135 136 137 138 139 140 141 142 143 |
# File 'lib/chef/shell/ext.rb', line 132 def singleton_method_added(mname) if @desc help_descriptions << Help.new(mname.to_s, @desc.to_s, @explain) @desc, @explain = nil, nil end if @subcommand_help @subcommand_help.each do |subcommand, text| help_descriptions << Help.new("#{mname}.#{subcommand}", text.to_s, nil) end end @subcommand_help = {} end |
#subcommands(subcommand_help = {}) ⇒ Object
128 129 130 |
# File 'lib/chef/shell/ext.rb', line 128 def subcommands(subcommand_help={}) @subcommand_help = subcommand_help end |