From b859baa04737644e40002f511c5941d002a956e3 Mon Sep 17 00:00:00 2001 From: Daniel Pittman Date: Sat, 26 Mar 2011 00:12:17 -0700 Subject: MAINT: the API is officially named "string" as of this moment. Now that we have settled on the final public name for the API, "Puppet::String", mass-rename and mass-edit all the files to follow. Reviewed-By: Randall Hansen --- lib/puppet/string/action_builder.rb | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 lib/puppet/string/action_builder.rb (limited to 'lib/puppet/string/action_builder.rb') diff --git a/lib/puppet/string/action_builder.rb b/lib/puppet/string/action_builder.rb new file mode 100644 index 000000000..b3db51104 --- /dev/null +++ b/lib/puppet/string/action_builder.rb @@ -0,0 +1,27 @@ +require 'puppet/string' +require 'puppet/string/action' + +class Puppet::String::ActionBuilder + attr_reader :action + + def self.build(string, name, &block) + name = name.to_s + raise "Action '#{name}' must specify a block" unless block + builder = new(string, name, &block) + builder.action + end + + def initialize(string, name, &block) + @string = string + @action = Puppet::String::Action.new(string, name) + instance_eval(&block) + end + + # Ideally the method we're defining here would be added to the action, and a + # method on the string would defer to it, but we can't get scope correct, + # so we stick with this. --daniel 2011-03-24 + def invoke(&block) + raise "Invoke called on an ActionBuilder with no corresponding Action" unless @action + @action.invoke = block + end +end -- cgit