core: default commands to primary

This commit is contained in:
Mitchell Hashimoto 2014-01-11 09:15:14 -08:00
parent f05388349c
commit 08b1aee00d
4 changed files with 20 additions and 5 deletions

View File

@ -53,7 +53,7 @@ module Vagrant
o.on("-v", "--version", "Print the version and exit.") o.on("-v", "--version", "Print the version and exit.")
o.on("-h", "--help", "Print this help.") o.on("-h", "--help", "Print this help.")
o.separator "" o.separator ""
o.separator "Available subcommands:" o.separator "Common subcommands:"
# 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.
@ -77,6 +77,10 @@ module Vagrant
o.separator "" o.separator ""
o.separator "For help on any individual command run `vagrant COMMAND -h`" o.separator "For help on any individual command run `vagrant COMMAND -h`"
o.separator ""
o.separator "Additional subcommands are available, but are either more advanced"
o.separator "or not commonly used. To see all subcommands, run the command"
o.separator "`vagrant list-commands`."
end end
@env.ui.info(opts.help, :prefix => false) @env.ui.info(opts.help, :prefix => false)

View File

@ -87,6 +87,9 @@ module Vagrant
raise InvalidCommandName, "Commands can only contain letters, numbers, and hyphens" raise InvalidCommandName, "Commands can only contain letters, numbers, and hyphens"
end end
# By default, the command is primary
opts[:primary] = true if !opts.has_key?(:primary)
# Register the command # Register the command
components.commands.register(name.to_sym) do components.commands.register(name.to_sym) do
[block, opts] [block, opts]

View File

@ -64,9 +64,17 @@ describe Vagrant::Plugin::V2::Plugin do
expect(plugin.components.commands.keys).to be_include(:foo) expect(plugin.components.commands.keys).to be_include(:foo)
expect(plugin.components.commands[:foo][0].call).to eql("bar") expect(plugin.components.commands[:foo][0].call).to eql("bar")
expect(plugin.components.commands[:foo][1]).to eql({ expect(plugin.components.commands[:foo][1][:opt]).to eql(:bar)
opt: :bar, end
})
it "should register commands as primary by default" do
plugin = Class.new(described_class) do
command("foo") { "bar" }
command("bar", primary: false) { "bar" }
end
expect(plugin.components.commands[:foo][1][:primary]).to be_true
expect(plugin.components.commands[:bar][1][:primary]).to be_false
end end
["spaces bad", "sym^bols"].each do |bad| ["spaces bad", "sym^bols"].each do |bad|

View File

@ -36,7 +36,7 @@ implements the `Vagrant.plugin(2, "command")` interface.
You can also define _non-primary commands_. These commands do not show You can also define _non-primary commands_. These commands do not show
up in the `vagrant -h` output. They only show up if the user explicitly up in the `vagrant -h` output. They only show up if the user explicitly
does a `vagrant help commands` which shows the full listing of available does a `vagrant list-commands` which shows the full listing of available
commands. This is useful for highly specific commands or plugins that a commands. This is useful for highly specific commands or plugins that a
beginner to Vagrant would not be using anyways. Vagrant itself uses non-primary beginner to Vagrant would not be using anyways. Vagrant itself uses non-primary
commands to expose some internal functions, as well. commands to expose some internal functions, as well.