Adding support for string alongside arrays.
Signed-off-by: Krzysztof Wilczynski <krzysztof.wilczynski@linux.com>
This commit is contained in:
parent
1296b3fc28
commit
e9d0b65807
1 changed files with 16 additions and 6 deletions
22
shuffle.rb
22
shuffle.rb
|
@ -2,8 +2,6 @@
|
|||
# shuffle.rb
|
||||
#
|
||||
|
||||
# TODO(Krzysztof Wilczynski): Support for strings would be nice too ...
|
||||
|
||||
module Puppet::Parser::Functions
|
||||
newfunction(:shuffle, :type => :rvalue, :doc => <<-EOS
|
||||
EOS
|
||||
|
@ -12,13 +10,23 @@ module Puppet::Parser::Functions
|
|||
raise(Puppet::ParseError, "shuffle(): Wrong number of arguments " +
|
||||
"given (#{arguments.size} for 1)") if arguments.size < 1
|
||||
|
||||
array = arguments[0]
|
||||
value = arguments[0]
|
||||
klass = value.class
|
||||
|
||||
if not array.is_a?(Array)
|
||||
raise(Puppet::ParseError, 'shuffle(): Requires an array to work with')
|
||||
if not [Array, String].include?(klass)
|
||||
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
|
||||
|
||||
result = array.clone
|
||||
elements = result.size
|
||||
|
||||
return [] if result.size == 0
|
||||
|
@ -30,6 +38,8 @@ module Puppet::Parser::Functions
|
|||
result[j], result[i] = result[i], result[j]
|
||||
end
|
||||
|
||||
result = string_given ? result.join : result
|
||||
|
||||
return result
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue