2011-04-30 03:50:38 +02:00
|
|
|
#
|
|
|
|
# flatten.rb
|
|
|
|
#
|
|
|
|
|
|
|
|
module Puppet::Parser::Functions
|
|
|
|
newfunction(:flatten, :type => :rvalue, :doc => <<-EOS
|
2011-07-30 00:09:30 +02:00
|
|
|
This function flattens any deeply nested arrays and returns a single flat array
|
|
|
|
as a result.
|
|
|
|
|
|
|
|
*Examples:*
|
|
|
|
|
|
|
|
flatten(['a', ['b', ['c']]])
|
|
|
|
|
|
|
|
Would return: ['a','b','c']
|
2011-04-30 03:50:38 +02:00
|
|
|
EOS
|
|
|
|
) do |arguments|
|
|
|
|
|
|
|
|
raise(Puppet::ParseError, "flatten(): Wrong number of arguments " +
|
|
|
|
"given (#{arguments.size} for 1)") if arguments.size < 1
|
|
|
|
|
|
|
|
array = arguments[0]
|
|
|
|
|
|
|
|
unless array.is_a?(Array)
|
|
|
|
raise(Puppet::ParseError, 'flatten(): Requires array to work with')
|
|
|
|
end
|
|
|
|
|
|
|
|
result = array.flatten
|
|
|
|
|
|
|
|
return result
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# vim: set ts=2 sw=2 et :
|