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
|
# 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
|
||||||
|
|
Loading…
Reference in a new issue