Way more painful than is legal
authorPeter Palfrader <peter@palfrader.org>
Tue, 1 Mar 2011 10:07:57 +0000 (11:07 +0100)
committerPeter Palfrader <peter@palfrader.org>
Tue, 1 Mar 2011 10:07:57 +0000 (11:07 +0100)
modules/puppetmaster/lib/puppet/parser/functions/whohosts.rb

index d032184..84b618c 100644 (file)
@@ -17,7 +17,7 @@ module Puppet::Parser::Functions
         yaml.keys.each do |hoster|
           if yaml[hoster].kind_of?(Array)
             netrange = yaml[hoster]
-          elsif yaml[hoster].kind_of?(Array) and yaml[hoster].has_key?['netrange']
+          elsif yaml[hoster].kind_of?(Hash) and yaml[hoster].has_key?('netrange')
             netrange = yaml[hoster]['netrange']
           else
             next
@@ -25,10 +25,10 @@ module Puppet::Parser::Functions
           netrange.each do |net|
             begin
               if IPAddr.new(net).include?(addr)
-                return hoster
+                ans = hoster
               end
-            rescue
-              raise "Could not match addr #{addr} for net #{net}"
+            rescue Exception => e
+              raise "Error while trying to match addr #{addr} for net #{net}: #{e.message}\n#{e.backtrace}"
             end
           end
         end