Sha256: a8819cbd7c833b88b3a7e06add67b9a510388ad060a95ab095fcbe2536b68fd2
Contents?: true
Size: 1.99 KB
Versions: 1
Compression:
Stored size: 1.99 KB
Contents
# frozen_string_literal: true module VagrantPlugins module ProviderZone module Command # This is used to manage the power controls for the zone class GuestPowerControls < Vagrant.plugin('2', :command) def initialize(argv, env) @main_args, @sub_command, @sub_args = split_main_and_subcommand(argv) @subcommands = Vagrant::Registry.new @subcommands.register(:restart) do require File.expand_path('restart_guest', __dir__) RestartGuest end @subcommands.register(:shutdown) do require File.expand_path('shutdown_guest', __dir__) ShutdownGuest end super(argv, env) end def execute if @main_args.include?('-h') || @main_args.include?('--help') # Print the help for all the vagrant-zones commands. return help end command_class = @subcommands.get(@sub_command.to_sym) if @sub_command return help if !command_class || !@sub_command @logger.debug("Invoking command class: #{command_class} #{@sub_args.inspect}") # Initialize and execute the command class command_class.new(@sub_args, @env).execute end def help opts = OptionParser.new do |subopts| subopts.banner = 'Usage: vagrant zone control <subcommand> [<args>]' subopts.separator '' subopts.separator 'Available subcommands:' # Add the available subcommands as separators in order to print them # out as well. keys = [] @subcommands.each_key { |key| keys << key.to_s } keys.sort.each do |key| subopts.separator " #{key}" end subopts.separator '' subopts.separator 'For help on any individual subcommand run `vagrant zone control <subcommand> -h`' end @env.ui.info(opts.help, :prefix => false) end end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
vagrant-zones-0.1.80 | lib/vagrant-zones/command/guest_power_controls.rb |