diff options
author | Jeff McCune <jeff@puppetlabs.com> | 2013-02-14 22:16:11 -0800 |
---|---|---|
committer | Jeff McCune <jeff@puppetlabs.com> | 2013-02-14 22:16:11 -0800 |
commit | f7a18189ec338b01b0fc89d75def832753af3868 (patch) | |
tree | de5f520a54af2f34d8cb6aa58838e7155596203e /lib | |
parent | 36a7b29630a4d4de17af79b5dd4e9491ec20b123 (diff) | |
parent | 95cf3fed689a72c6a7c6641fdf462770f94112ca (diff) |
Merge pull request #130 from jhoblitt/has_element
(#19272) Add has_element() function
Diffstat (limited to 'lib')
-rw-r--r-- | lib/puppet/parser/functions/has_element.rb | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/lib/puppet/parser/functions/has_element.rb b/lib/puppet/parser/functions/has_element.rb new file mode 100644 index 0000000..e29bbb9 --- /dev/null +++ b/lib/puppet/parser/functions/has_element.rb @@ -0,0 +1,28 @@ +module Puppet::Parser::Functions + + newfunction(:has_element, :type => :rvalue, :doc => <<-'ENDHEREDOC') do |args| + Determine if an array has an element with a matching value. + + Example: + + $my_array = ['key_one'] + if has_element($my_array, 'key_two') { + notice('we will not reach here') + } + if has_element($my_array, 'key_one') { + notice('this will be printed') + } + + ENDHEREDOC + + unless args.length == 2 + raise Puppet::ParseError, ("has_element(): wrong number of arguments (#{args.length}; must be 2)") + end + unless args[0].is_a?(Array) + raise Puppet::ParseError, "has_element(): expects the first argument to be an array, got #{args[0].inspect} which is of type #{args[0].class}" + end + args[0].include?(args[1]) + + end + +end |