summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorJeff McCune <jeff@puppetlabs.com>2011-06-21 17:01:33 -0700
committerJeff McCune <jeff@puppetlabs.com>2011-06-21 17:01:33 -0700
commit4c00cfc610cc132080dc5baa1ac8f231c4b76368 (patch)
tree99f743f7094f3acb59948d49fecbf2d837e538ae /lib
parentde2434255e41e043017b6a4448ab1e936f427f2e (diff)
(#8010) Add validate_hash function
This function validates all passed variables are hashes. This is similar to the validate_bool function and is copied from it.
Diffstat (limited to 'lib')
-rw-r--r--lib/puppet/parser/functions/validate_hash.rb37
1 files changed, 37 insertions, 0 deletions
diff --git a/lib/puppet/parser/functions/validate_hash.rb b/lib/puppet/parser/functions/validate_hash.rb
new file mode 100644
index 0000000..1443318
--- /dev/null
+++ b/lib/puppet/parser/functions/validate_hash.rb
@@ -0,0 +1,37 @@
+module Puppet::Parser::Functions
+
+ newfunction(:validate_hash, :doc => <<-'ENDHEREDOC') do |args|
+ Validate all passed values are a Hash data structure
+ value does not pass the check.
+
+ Example:
+
+ These values validate
+
+ $my_hash = { 'one' => 'two' }
+ validate_hash($my_hash)
+
+ These values do NOT validate
+
+ validate_hash(true)
+ validate_hash('some_string')
+ $undefined = undef
+ validate_hash($undefined)
+
+ * Jeff McCune <jeff@puppetlabs.com>
+
+ ENDHEREDOC
+
+ unless args.length > 0 then
+ raise Puppet::ParseError, ("validate_hash(): wrong number of arguments (#{args.length}; must be > 0)")
+ end
+
+ args.each do |arg|
+ unless arg.is_a?(Hash)
+ raise Puppet::ParseError, ("#{arg.inspect} is not a Hash. It looks to be a #{arg.class}")
+ end
+ end
+
+ end
+
+end