44596e73da
85d5ead
Updated the concat function so that it wouldn't modify the
original array. A side-effect of this change is that it now always calls
`Array()` on the second argument. If thit is a Hash, this results in
`to_a` being called on the hash, which converts it to an array or
tuples. This is undesired.
Update the behaviour so that it doesn't (indirectly) call `to_a` on
anything, instead test for the type of the argument, wrapping it in an
array if it's not already an array.
41 lines
866 B
Ruby
41 lines
866 B
Ruby
#
|
|
# concat.rb
|
|
#
|
|
|
|
module Puppet::Parser::Functions
|
|
newfunction(:concat, :type => :rvalue, :doc => <<-EOS
|
|
Appends the contents of multiple arrays into array 1.
|
|
|
|
*Example:*
|
|
|
|
concat(['1','2','3'],['4','5','6'],['7','8','9'])
|
|
|
|
Would result in:
|
|
|
|
['1','2','3','4','5','6','7','8','9']
|
|
EOS
|
|
) do |arguments|
|
|
|
|
# Check that more than 2 arguments have been given ...
|
|
raise(Puppet::ParseError, "concat(): Wrong number of arguments " +
|
|
"given (#{arguments.size} for < 2)") if arguments.size < 2
|
|
|
|
a = arguments[0]
|
|
|
|
# Check that the first parameter is an array
|
|
unless a.is_a?(Array)
|
|
raise(Puppet::ParseError, 'concat(): Requires array to work with')
|
|
end
|
|
|
|
result = a
|
|
arguments.shift
|
|
|
|
arguments.each do |x|
|
|
result = result + (x.is_a?(Array) ? x : [x])
|
|
end
|
|
|
|
return result
|
|
end
|
|
end
|
|
|
|
# vim: set ts=2 sw=2 et :
|