core: output synopsis with command [GH-2249]

This commit is contained in:
Mitchell Hashimoto 2013-11-23 14:00:42 -08:00
parent 844c672911
commit 97389d4255
17 changed files with 80 additions and 11 deletions

View File

@ -55,13 +55,16 @@ module Vagrant
# Add the available subcommands as separators in order to print them # Add the available subcommands as separators in order to print them
# out as well. # out as well.
keys = [] commands = {}
Vagrant.plugin("2").manager.commands.each do |key, _| longest = 0
keys << key Vagrant.plugin("2").manager.commands.each do |key, klass|
key = key.to_s
commands[key] = klass.synopsis
longest = key.length if key.length > longest
end end
keys.sort.each do |key| commands.keys.sort.each do |key|
o.separator " #{key}" o.separator " #{key.ljust(longest+2)} #{commands[key]}"
end end
o.separator "" o.separator ""

View File

@ -9,6 +9,14 @@ module Vagrant
class Command class Command
include Util::SafePuts include Util::SafePuts
# This should return a brief (60 characters or less) synopsis of what
# this command does. It will be used in the output of the help.
#
# @return [String]
def self.synopsis
""
end
def initialize(argv, env) def initialize(argv, env)
@argv = argv @argv = argv
@env = env @env = env

View File

@ -4,6 +4,10 @@ module VagrantPlugins
module CommandBox module CommandBox
module Command module Command
class Root < Vagrant.plugin("2", :command) class Root < Vagrant.plugin("2", :command)
def self.synopsis
"manages boxes: installation, removal, etc."
end
def initialize(argv, env) def initialize(argv, env)
super super

View File

@ -1,6 +1,10 @@
module VagrantPlugins module VagrantPlugins
module CommandDestroy module CommandDestroy
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
def self.synopsis
"stops and deletes all traces of the vagrant machine"
end
def execute def execute
options = {} options = {}
options[:force] = false options[:force] = false

View File

@ -3,6 +3,10 @@ require 'optparse'
module VagrantPlugins module VagrantPlugins
module CommandHalt module CommandHalt
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
def self.synopsis
"stops the vagrant machine"
end
def execute def execute
options = {} options = {}
options[:force] = false options[:force] = false

View File

@ -3,6 +3,10 @@ require 'optparse'
module VagrantPlugins module VagrantPlugins
module CommandHelp module CommandHelp
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
def self.synopsis
"shows the help for a subcommand"
end
def execute def execute
return @env.cli([]) if @argv.empty? return @env.cli([]) if @argv.empty?
@env.cli([@argv[0], "-h"]) @env.cli([@argv[0], "-h"])

View File

@ -5,11 +5,13 @@ require 'vagrant/util/template_renderer'
module VagrantPlugins module VagrantPlugins
module CommandInit module CommandInit
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
def execute def self.synopsis
options = {} "initializes a new Vagrant environment by creating a Vagrantfile"
end
opts = OptionParser.new do |opts| def execute
opts.banner = "Usage: vagrant init [box-name] [box-url]" opts = OptionParser.new do |o|
o.banner = "Usage: vagrant init [box-name] [box-url]"
end end
# Parse the options # Parse the options
@ -34,7 +36,7 @@ module VagrantPlugins
# Success, exit status 0 # Success, exit status 0
0 0
end end
end end
end end
end end

View File

@ -3,6 +3,10 @@ require 'optparse'
module VagrantPlugins module VagrantPlugins
module CommandPackage module CommandPackage
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
def self.synopsis
"packages a running vagrant environment into a box"
end
def execute def execute
options = {} options = {}

View File

@ -4,6 +4,10 @@ module VagrantPlugins
module CommandPlugin module CommandPlugin
module Command module Command
class Root < Vagrant.plugin("2", :command) class Root < Vagrant.plugin("2", :command)
def self.synopsis
"manages plugins: install, uninstall, update, etc."
end
def initialize(argv, env) def initialize(argv, env)
super super

View File

@ -3,6 +3,10 @@ require 'optparse'
module VagrantPlugins module VagrantPlugins
module CommandProvision module CommandProvision
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
def self.synopsis
"provisions the vagrant machine"
end
def execute def execute
options = {} options = {}
options[:provision_types] = nil options[:provision_types] = nil
@ -14,7 +18,7 @@ module VagrantPlugins
"Enable only certain provisioners, by type.") do |list| "Enable only certain provisioners, by type.") do |list|
options[:provision_types] = list.map { |type| type.to_sym } options[:provision_types] = list.map { |type| type.to_sym }
end end
o.on("--[no-]parallel", o.on("--[no-]parallel",
"Enable or disable parallelism if provider supports it.") do |parallel| "Enable or disable parallelism if provider supports it.") do |parallel|
options[:parallel] = parallel options[:parallel] = parallel

View File

@ -11,6 +11,10 @@ module VagrantPlugins
# to this. # to this.
include VagrantPlugins::CommandUp::StartMixins include VagrantPlugins::CommandUp::StartMixins
def self.synopsis
"restarts vagrant machine, loads new Vagrantfile configuration"
end
def execute def execute
options = {} options = {}
options[:provision_ignore_sentinel] = false options[:provision_ignore_sentinel] = false

View File

@ -3,6 +3,10 @@ require 'optparse'
module VagrantPlugins module VagrantPlugins
module CommandResume module CommandResume
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
def self.synopsis
"resume a suspended vagrant machine"
end
def execute def execute
opts = OptionParser.new do |o| opts = OptionParser.new do |o|
o.banner = "Usage: vagrant resume [vm-name]" o.banner = "Usage: vagrant resume [vm-name]"

View File

@ -3,6 +3,10 @@ require 'optparse'
module VagrantPlugins module VagrantPlugins
module CommandSSH module CommandSSH
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
def self.synopsis
"connects to machine via SSH"
end
def execute def execute
options = {} options = {}

View File

@ -7,6 +7,10 @@ module VagrantPlugins
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
include Vagrant::Util::SafePuts include Vagrant::Util::SafePuts
def self.synopsis
"outputs OpenSSH valid configuration to connect to the machine"
end
def execute def execute
options = {} options = {}

View File

@ -3,6 +3,10 @@ require 'optparse'
module VagrantPlugins module VagrantPlugins
module CommandStatus module CommandStatus
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
def self.synopsis
"outputs status of the vagrant machine"
end
def execute def execute
opts = OptionParser.new do |o| opts = OptionParser.new do |o|
o.banner = "Usage: vagrant status [machine-name]" o.banner = "Usage: vagrant status [machine-name]"

View File

@ -3,6 +3,10 @@ require 'optparse'
module VagrantPlugins module VagrantPlugins
module CommandSuspend module CommandSuspend
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
def self.synopsis
"suspends the machine"
end
def execute def execute
opts = OptionParser.new do |o| opts = OptionParser.new do |o|
o.banner = "Usage: vagrant suspend [vm-name]" o.banner = "Usage: vagrant suspend [vm-name]"

View File

@ -9,6 +9,10 @@ module VagrantPlugins
class Command < Vagrant.plugin("2", :command) class Command < Vagrant.plugin("2", :command)
include StartMixins include StartMixins
def self.synopsis
"starts and provisions the vagrant environment"
end
def execute def execute
options = {} options = {}
options[:destroy_on_error] = true options[:destroy_on_error] = true