Class: VagrantBundler::Command::Bundle
- Defined in:
- lib/vagrant_bundler/command/bundle.rb
Instance Method Summary collapse
- #execute ⇒ Object
-
#help ⇒ Object
Prints the help out for this command.
-
#initialize(argv, env) ⇒ Bundle
constructor
A new instance of Bundle.
Constructor Details
#initialize(argv, env) ⇒ Bundle
Returns a new instance of Bundle.
6 7 8 9 10 11 12 13 14 15 |
# File 'lib/vagrant_bundler/command/bundle.rb', line 6 def initialize(argv, env) super @main_args, @sub_command, @sub_args = split_main_and_subcommand(argv) @subcommands = Vagrant::Registry.new @subcommands.register(:list) { VagrantBundler::Command::BundleList } @subcommands.register(:open) { VagrantBundler::Command::BundleOpen } @subcommands.register(:show) { VagrantBundler::Command::BundleShow } end |
Instance Method Details
#execute ⇒ Object
17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
# File 'lib/vagrant_bundler/command/bundle.rb', line 17 def execute if @main_args.include?("-h") || @main_args.include?("--help") # Print the help for all the box commands. return help end # If we reached this far then we must have a subcommand. If not, # then we also just print the help and exit. command_class = @subcommands.get(@sub_command.to_sym) if @sub_command return help if !command_class || !@sub_command # Initialize and execute the command class command_class.new(@sub_args, @env).execute end |
#help ⇒ Object
Prints the help out for this command
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 |
# File 'lib/vagrant_bundler/command/bundle.rb', line 33 def help opts = OptionParser.new do |opts| opts. = "Usage: vagrant bundle <command> [<args>]" opts.separator "" opts.separator "Available subcommands:" # Add the available subcommands as separators in order to print them # out as well. keys = [] @subcommands.each { |key, value| keys << key } keys.each do |key| opts.separator " #{key}" end end @env.ui.info(opts.help, :prefix => false) end |