Adding support for string alongside arrays.

Signed-off-by: Krzysztof Wilczynski <krzysztof.wilczynski@linux.com>
This commit is contained in:
Krzysztof Wilczynski 2011-04-29 05:00:51 +01:00
parent 1296b3fc28
commit e9d0b65807

View file

@ -2,8 +2,6 @@
# shuffle.rb # shuffle.rb
# #
# TODO(Krzysztof Wilczynski): Support for strings would be nice too ...
module Puppet::Parser::Functions module Puppet::Parser::Functions
newfunction(:shuffle, :type => :rvalue, :doc => <<-EOS newfunction(:shuffle, :type => :rvalue, :doc => <<-EOS
EOS EOS
@ -12,13 +10,23 @@ module Puppet::Parser::Functions
raise(Puppet::ParseError, "shuffle(): Wrong number of arguments " + raise(Puppet::ParseError, "shuffle(): Wrong number of arguments " +
"given (#{arguments.size} for 1)") if arguments.size < 1 "given (#{arguments.size} for 1)") if arguments.size < 1
array = arguments[0] value = arguments[0]
klass = value.class
if not array.is_a?(Array) if not [Array, String].include?(klass)
raise(Puppet::ParseError, 'shuffle(): Requires an array to work with') raise(Puppet::ParseError, 'shuffle(): Requires either an ' +
'array or string to work with')
end
string_given = false
result = value.clone
if value.is_a?(String)
result = result.split('')
string_given = true
end end
result = array.clone
elements = result.size elements = result.size
return [] if result.size == 0 return [] if result.size == 0
@ -30,6 +38,8 @@ module Puppet::Parser::Functions
result[j], result[i] = result[i], result[j] result[j], result[i] = result[i], result[j]
end end
result = string_given ? result.join : result
return result return result
end end
end end