1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
|
# frozen_string_literal: true
require 'shellwords'
#
# shell_split.rb
#
module Puppet::Parser::Functions
newfunction(:shell_split, type: :rvalue, doc: <<-DOC
@summary
Splits a string into an array of tokens in the same way the Bourne shell does.
@return
array of tokens
This function behaves the same as ruby's Shellwords.shellsplit() function
DOC
) do |arguments|
raise(Puppet::ParseError, "shell_split(): Wrong number of arguments given (#{arguments.size} for 1)") if arguments.size != 1
string = arguments[0].to_s
result = Shellwords.shellsplit(string)
return result
end
end
# vim: set ts=2 sw=2 et :
|