summaryrefslogtreecommitdiffstats
path: root/lib/puppet/string.rb
diff options
context:
space:
mode:
authorPieter van de Bruggen <pieter@puppetlabs.com>2011-03-29 13:29:24 -0700
committerPieter van de Bruggen <pieter@puppetlabs.com>2011-03-29 13:29:24 -0700
commitb53cf84b76d9cbe60c2aa29eed167b05cf7b6a35 (patch)
tree4653bbedb95460bdd22720f0d07d34952ad434ba /lib/puppet/string.rb
parent2ad8c96935ec53c2d98201ad77fd070dc40dadb6 (diff)
parentf7f1e5822f3921336872956fe07c4da4406ce8eb (diff)
downloadpuppet-b53cf84b76d9cbe60c2aa29eed167b05cf7b6a35.tar.gz
puppet-b53cf84b76d9cbe60c2aa29eed167b05cf7b6a35.tar.xz
puppet-b53cf84b76d9cbe60c2aa29eed167b05cf7b6a35.zip
Merge branch 'tickets/master/6770'
Diffstat (limited to 'lib/puppet/string.rb')
-rw-r--r--lib/puppet/string.rb30
1 files changed, 16 insertions, 14 deletions
diff --git a/lib/puppet/string.rb b/lib/puppet/string.rb
index b5f7b9048..783b6afe0 100644
--- a/lib/puppet/string.rb
+++ b/lib/puppet/string.rb
@@ -70,23 +70,25 @@ class Puppet::String
# Try to find actions defined in other files.
def load_actions
- path = "puppet/string/v#{version}/#{name}"
+ path = "puppet/string/#{name}"
loaded = []
- Puppet::String.autoloader.search_directories.each do |dir|
- fdir = ::File.join(dir, path)
- next unless FileTest.directory?(fdir)
-
- Dir.chdir(fdir) do
- Dir.glob("*.rb").each do |file|
- aname = file.sub(/\.rb/, '')
- if loaded.include?(aname)
- Puppet.debug "Not loading duplicate action '#{aname}' for '#{name}' from '#{fdir}/#{file}'"
- next
+ [path, "#{name}@#{version}/#{path}"].each do |path|
+ Puppet::String.autoloader.search_directories.each do |dir|
+ fdir = ::File.join(dir, path)
+ next unless FileTest.directory?(fdir)
+
+ Dir.chdir(fdir) do
+ Dir.glob("*.rb").each do |file|
+ aname = file.sub(/\.rb/, '')
+ if loaded.include?(aname)
+ Puppet.debug "Not loading duplicate action '#{aname}' for '#{name}' from '#{fdir}/#{file}'"
+ next
+ end
+ loaded << aname
+ Puppet.debug "Loading action '#{aname}' for '#{name}' from '#{fdir}/#{file}'"
+ require "#{Dir.pwd}/#{aname}"
end
- loaded << aname
- Puppet.debug "Loading action '#{aname}' for '#{name}' from '#{fdir}/#{file}'"
- require "#{path}/#{aname}"
end
end
end