summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorDavid Schmitt <david.schmitt@puppetlabs.com>2015-08-24 14:36:20 +0100
committerDavid Schmitt <david.schmitt@puppetlabs.com>2015-08-24 14:36:20 +0100
commit24e57b5d2849982d5a927f43d698ff7f312ab93a (patch)
tree315a8a912f1bd8d17530b84bdb923b45596cae3d /lib
parent1d89df906e1ae1d09a862974181663caaf8012c6 (diff)
parent1d9189d860f28067b72093cbe4027cf49b7d612c (diff)
downloadpuppet-stdlib-24e57b5d2849982d5a927f43d698ff7f312ab93a.tar.gz
puppet-stdlib-24e57b5d2849982d5a927f43d698ff7f312ab93a.tar.bz2
Merge pull request #507 from Jetroid/mod2456
(MODULES-2456) Modify union to accept more than two arrays
Diffstat (limited to 'lib')
-rw-r--r--lib/puppet/parser/functions/union.rb17
1 files changed, 6 insertions, 11 deletions
diff --git a/lib/puppet/parser/functions/union.rb b/lib/puppet/parser/functions/union.rb
index c91bb80..6c5bb83 100644
--- a/lib/puppet/parser/functions/union.rb
+++ b/lib/puppet/parser/functions/union.rb
@@ -4,7 +4,7 @@
module Puppet::Parser::Functions
newfunction(:union, :type => :rvalue, :doc => <<-EOS
-This function returns a union of two arrays.
+This function returns a union of two or more arrays.
*Examples:*
@@ -14,20 +14,15 @@ Would return: ["a","b","c","d"]
EOS
) do |arguments|
- # Two arguments are required
+ # Check that 2 or more arguments have been given ...
raise(Puppet::ParseError, "union(): Wrong number of arguments " +
- "given (#{arguments.size} for 2)") if arguments.size != 2
+ "given (#{arguments.size} for < 2)") if arguments.size < 2
- first = arguments[0]
- second = arguments[1]
-
- unless first.is_a?(Array) && second.is_a?(Array)
- raise(Puppet::ParseError, 'union(): Requires 2 arrays')
+ arguments.each do |argument|
+ raise(Puppet::ParseError, 'union(): Every parameter must be an array') unless argument.is_a?(Array)
end
- result = first | second
-
- return result
+ arguments.reduce(:|)
end
end