Command base code documentation
This commit is contained in:
parent
c8d7e6601d
commit
08d502e856
|
@ -58,7 +58,9 @@ module Vagrant
|
|||
# end
|
||||
#
|
||||
# Then, the above can be invoked with `vagrant hello Mitchell` which would
|
||||
# output "Hello, Mitchell"
|
||||
# output "Hello, Mitchell." If instead you're looking for switches, such as
|
||||
# "--name Mitchell", then take a look at `class_option`, an example of which
|
||||
# can be found in the {PackageCommand}.
|
||||
class Base < Thor::Group
|
||||
include Thor::Actions
|
||||
include Helpers
|
||||
|
@ -69,21 +71,36 @@ module Vagrant
|
|||
# given name. The name will be used for accessing it from the CLI,
|
||||
# so if you name it "lamp", then the command to invoke this
|
||||
# will be `vagrant lamp`.
|
||||
#
|
||||
# The description is used when the help is listed, and is meant to be
|
||||
# a brief (one sentence) description of what the command does.
|
||||
#
|
||||
# Some additional options may be passed in as the last parameter:
|
||||
#
|
||||
# * `:alias` - If given as an array or string, these will be aliases
|
||||
# for the same command. For example, `vagrant version` is also
|
||||
# `vagrant --version` and `vagrant -v`
|
||||
#
|
||||
# @param [String] usage
|
||||
# @param [String] description
|
||||
# @param [Hash] opts
|
||||
def self.register(usage, description, opts=nil)
|
||||
desc description
|
||||
CLI.register(self, extract_name_from_usage(usage), usage, desc, opts)
|
||||
end
|
||||
|
||||
# Extracts the name of the command from a usage string. Example:
|
||||
# `init [box_name] [box_url]` becomes just `init`.
|
||||
def self.extract_name_from_usage(usage)
|
||||
/^([-_a-zA-Z0-9]+)(\s+(.+?))?$/.match(usage).to_a[1]
|
||||
end
|
||||
|
||||
def initialize(*args)
|
||||
super
|
||||
initialize_environment(*args)
|
||||
end
|
||||
|
||||
protected
|
||||
|
||||
# Extracts the name of the command from a usage string. Example:
|
||||
# `init [box_name] [box_url]` becomes just `init`.
|
||||
def self.extract_name_from_usage(usage)
|
||||
/^([-_a-zA-Z0-9]+)(\s+(.+?))?$/.match(usage).to_a[1]
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -3,11 +3,65 @@ require 'thor/actions'
|
|||
|
||||
module Vagrant
|
||||
module Command
|
||||
# A {GroupBase} is the subclass which should be used if you're
|
||||
# A {GroupBase} is the superclass which should be used if you're
|
||||
# creating a CLI command which has subcommands such as `vagrant box`,
|
||||
# which has subcommands such as `add`, `remove`, `list`. If you're
|
||||
# creating a simple command which has no subcommands, such as `vagrant up`,
|
||||
# then use {Base} instead.
|
||||
#
|
||||
# Unlike {Base}, where all public methods are executed, in a {GroupBase},
|
||||
# each public method defines a separate task which can be invoked. The best
|
||||
# way to get examples of how to create a {GroupBase} command is to look
|
||||
# at the built-in commands, such as {BoxCommand}.
|
||||
#
|
||||
# # Defining a New Command
|
||||
#
|
||||
# To define a new command with subcommands, create a new class which inherits
|
||||
# from this class, then call {register} to register the command. That's it! When
|
||||
# the command is invoked, the method matching the subcommand is invoked. An
|
||||
# example is shown below:
|
||||
#
|
||||
# class SayCommand < Vagrant::Command::GroupBase
|
||||
# register "say", "Say hello or goodbye"
|
||||
#
|
||||
# desc "hello", "say hello"
|
||||
# def hello
|
||||
# env.ui.info "Hello"
|
||||
# end
|
||||
#
|
||||
# desc "goodbye", "say goodbye"
|
||||
# def goodbye
|
||||
# env.ui.info "Goodbye"
|
||||
# end
|
||||
# end
|
||||
#
|
||||
# In this case, the above class is invokable via `vagrant say hello` or
|
||||
# `vagrant say goodbye`. To give it a try yourself, just copy and paste
|
||||
# the above into a Vagrantfile somewhere, and run `vagrant` from within
|
||||
# that directory. You should see the new command!
|
||||
#
|
||||
# Also notice that in the above, each task follows a `desc` call. This
|
||||
# call is used to provide usage and description for each task, and is
|
||||
# required.
|
||||
#
|
||||
# ## Defining Command-line Options
|
||||
#
|
||||
# ### Arguments
|
||||
#
|
||||
# To define arguments to your commands, such as `vagrant say hello mitchell`,
|
||||
# then you simply define them as arguments to the method implementing the
|
||||
# task. An example is shown below (only the method, to keep things brief):
|
||||
#
|
||||
# def hello(name)
|
||||
# env.ui.info "Hello, #{name}"
|
||||
# end
|
||||
#
|
||||
# Then, if `vagrant say hello mitchell` was called, then the output would
|
||||
# be "Hello, mitchell"
|
||||
#
|
||||
# ### Switches or Other Options
|
||||
#
|
||||
# TODO
|
||||
class GroupBase < Thor
|
||||
include Thor::Actions
|
||||
include Helpers
|
||||
|
@ -18,6 +72,20 @@ module Vagrant
|
|||
# usage. The usage will be used for accessing it from the CLI,
|
||||
# so if you give it a usage of `lamp [subcommand]`, then the command
|
||||
# to invoke this will be `vagrant lamp` (with a subcommand).
|
||||
#
|
||||
# The description is used when a listing of the commands is given
|
||||
# and is meant to be a brief (one sentence) description of what this
|
||||
# command does.
|
||||
#
|
||||
# Some additional options may be passed in as the last parameter:
|
||||
#
|
||||
# * `:alias` - If given as an array or string, these will be aliases
|
||||
# for the same command. For example, `vagrant version` is also
|
||||
# `vagrant --version` and `vagrant -v`
|
||||
#
|
||||
# @param [String] usage
|
||||
# @param [String] description
|
||||
# @param [Hash] opts
|
||||
def self.register(usage, description, opts=nil)
|
||||
CLI.register(self, Base.extract_name_from_usage(usage), usage, description, opts)
|
||||
end
|
||||
|
|
|
@ -1,7 +1,12 @@
|
|||
module Vagrant
|
||||
module Command
|
||||
# Same as {Base} except adds the `name` argument so that you
|
||||
# can use methods such as `target_vms` in your command.
|
||||
# Same as {Base} except adds the `name` argument for you. This superclass
|
||||
# is useful if you're creating a command which should be able to target
|
||||
# a specific VM in a multi-VM environment. For example, in a multi-VM
|
||||
# environment, `vagrant up` "ups" all defined VMs, but you can specify a
|
||||
# name such as `vagrant up web` to target only a specific VM. That name
|
||||
# argument is from {NamedBase}. Of course, you can always add it manually
|
||||
# yourself, as well.
|
||||
class NamedBase < Base
|
||||
argument :name, :type => :string, :optional => true
|
||||
end
|
||||
|
|
Loading…
Reference in New Issue