aboutsummaryrefslogtreecommitdiff
path: root/lib/puppet/parser/functions/multi_source_template.rb
diff options
context:
space:
mode:
authorSilvio Rhatto <rhatto@riseup.net>2011-02-14 12:11:35 -0200
committerSilvio Rhatto <rhatto@riseup.net>2011-02-14 12:11:35 -0200
commit0b03f41b32e8423bbbfa3c8a6b02dbf17c04f4c1 (patch)
treec5d7863c96377394b8559fbd5c7777fb32b6fda1 /lib/puppet/parser/functions/multi_source_template.rb
parente0080adb1ca115ee98bf97c9cfb91fccbfeddaac (diff)
parenta81984c77ed1efb56e978d8b5050b6c3ec409d80 (diff)
downloadpuppet-common-0b03f41b32e8423bbbfa3c8a6b02dbf17c04f4c1.tar.gz
puppet-common-0b03f41b32e8423bbbfa3c8a6b02dbf17c04f4c1.tar.bz2
Merge branch 'master' of git://labs.riseup.net/shared-common
Conflicts: lib/puppet/parser/functions/gsub.rb lib/puppet/parser/functions/prefix_with.rb lib/puppet/parser/functions/slash_escape.rb lib/puppet/parser/functions/split.rb lib/puppet/parser/functions/substitute.rb manifests/classes/lsb_release.pp manifests/defines/concatenated_file.pp manifests/defines/config_file.pp manifests/defines/line.pp manifests/defines/module_dir.pp manifests/defines/module_file.pp manifests/defines/replace.pp manifests/init.pp
Diffstat (limited to 'lib/puppet/parser/functions/multi_source_template.rb')
-rw-r--r--lib/puppet/parser/functions/multi_source_template.rb29
1 files changed, 29 insertions, 0 deletions
diff --git a/lib/puppet/parser/functions/multi_source_template.rb b/lib/puppet/parser/functions/multi_source_template.rb
new file mode 100644
index 0000000..e075320
--- /dev/null
+++ b/lib/puppet/parser/functions/multi_source_template.rb
@@ -0,0 +1,29 @@
+module Puppet::Parser::Functions
+ require 'erb'
+
+ newfunction(:multi_source_template, :type => :rvalue) do |args|
+ contents = nil
+ environment = compiler.environment
+ sources = args
+
+ sources.each do |file|
+ Puppet.debug("Looking for #{file} in #{environment}")
+ if filename = Puppet::Parser::Files.find_template(file, environment.to_s)
+ wrapper = Puppet::Parser::TemplateWrapper.new(self)
+ wrapper.file = file
+
+ begin
+ contents = wrapper.result
+ rescue => detail
+ raise Puppet::ParseError, "Failed to parse template %s: %s" % [file, detail]
+ end
+
+ break
+ end
+ end
+
+ raise Puppet::ParseError, "multi_source_template: No match found for files: #{sources.join(', ')}" if contents == nil
+
+ contents
+ end
+end