lib/puppet/interface/action_builder.rb in puppet-3.0.2 vs lib/puppet/interface/action_builder.rb in puppet-3.1.0.rc1

- old
+ new

@@ -1,46 +1,119 @@ require 'puppet/interface' require 'puppet/interface/action' +# This class is used to build {Puppet::Interface::Action actions}. +# When an action is defined with +# {Puppet::Interface::ActionManager#action} the block is evaluated +# within the context of a new instance of this class. +# @api public class Puppet::Interface::ActionBuilder + # The action under construction + # @return [Puppet::Interface::Action] + # @api private attr_reader :action + # Builds a new action. + # @return [Puppet::Interface::Action] + # @api private def self.build(face, name, &block) raise "Action #{name.inspect} must specify a block" unless block new(face, name, &block).action end # Ideally the method we're defining here would be added to the action, and a # method on the face would defer to it, but we can't get scope correct, so # we stick with this. --daniel 2011-03-24 + + # Sets what the action does when it is invoked. This takes a block + # which will be called when the action is invoked. The action will + # accept arguments based on the arity of the block. It should always + # take at least one argument for options. Options will be the last + # argument. + # + # @overload when_invoked({|options| ... }) + # An action with no arguments + # @overload when_invoked({|arg1, arg2, options| ... }) + # An action with two arguments + # @return [void] + # @api public + # @dsl Faces def when_invoked(&block) @action.when_invoked = block end + # Sets a block to be run at the rendering stage, for a specific + # rendering type (eg JSON, YAML, console), after the block for + # when_invoked gets run. This manipulates the value returned by the + # action. It makes it possible to work around limitations in the + # underlying object returned, and should be avoided in favor of + # returning a more capable object. + # @api private + # @todo this needs more + # @dsl Faces def when_rendering(type = nil, &block) if type.nil? then # the default error message sucks --daniel 2011-04-18 raise ArgumentError, 'You must give a rendering format to when_rendering' end if block.nil? then raise ArgumentError, 'You must give a block to when_rendering' end @action.set_rendering_method_for(type, block) end + # Declare that this action can take a specific option, and provide the + # code to do so. One or more strings are given, in the style of + # OptionParser (see example). These strings are parsed to derive a + # name for the option. Any `-` characters within the option name (ie + # excluding the intial `-` or `--` for an option) will be translated + # to `_`.The first long option will be used as the name, and the rest + # are retained as aliases. The original form of the option is used + # when invoking the face, the translated form is used internally. + # + # When the action is invoked the value of the option is available in + # a hash passed to the {Puppet::Interface::ActionBuilder#when_invoked + # when_invoked} block, using the option name in symbol form as the + # hash key. + # + # The block to this method is used to set attributes for the option + # (see {Puppet::Interface::OptionBuilder}). + # + # @param declaration [String] Option declarations, as described above + # and in the example. + # + # @example Say hi + # action :say_hi do + # option "-u USER", "--user-name USER" do + # summary "Who to say hi to" + # end + # + # when_invoked do |options| + # "Hi, #{options[:user_name]}" + # end + # end + # @api public + # @dsl Faces def option(*declaration, &block) option = Puppet::Interface::OptionBuilder.build(@action, *declaration, &block) @action.add_option(option) end + # Set this as the default action for the face. + # @api public + # @dsl Faces + # @return [void] def default(value = true) @action.default = !!value end - + + # @api private def display_global_options(*args) @action.add_display_global_options args end alias :display_global_option :display_global_options + # Sets the default rendering format + # @api private def render_as(value = nil) value.nil? and raise ArgumentError, "You must give a rendering format to render_as" formats = Puppet::Network::FormatHandler.formats unless formats.include? value