summaryrefslogtreecommitdiff
path: root/join.rb
blob: 469763a14c94848b5e2463997edf7748c9a39736 (plain)
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#
# join.rb
#

module Puppet::Parser::Functions
  newfunction(:join, :type => :rvalue, :doc => <<-EOS
This function will allow to concatenate elements of an array together
with a given suffix and optionally with prefix if such is given ...

For example:

Given the following sample manifest:

   define iterator {
     notice $name
   }

   $array = ['a', 'b', 'c']

   $result = split(join($array, ',', 'letter_'), ',')

   notice $result

   iterator { $result: }

This will produce the following:

   notice: Scope(Class[main]): letter_a letter_b letter_c
   notice: Scope(Iterator[letter_a]): letter_a
   notice: Scope(Iterator[letter_b]): letter_b
   notice: Scope(Iterator[letter_c]): letter_c

Which allows you to avoid resorting to the following:

   $result = split(inline_template("<%= array.collect { |i| \"letter_#{i}\" }.join(',') %>"), ',')

Phasing out the need for use and abuse of the infamous inline_template
in the example above and which in this very case is extremely ugly as
we have to escape double-quotes to make Puppet parser not evaluate them.
    EOS
  ) do |arguments|

    # Technically we support three arguments but only first two are mandatory ...
    raise(Puppet::ParseError, "join(): Wrong number of arguments " +
      "given (#{arguments.size} for 2)") if arguments.size < 2

    array = arguments[0]

    if not array.is_a?(Array)
      raise(Puppet::ParseError, 'join(): Requires an array to work with')
    end

    suffix = arguments[1]
    prefix = arguments[2] if arguments[2]

    raise(Puppet::ParseError, 'join(): You must provide suffix ' +
      'to join array elements with') if suffix.empty?

    if prefix and prefix.empty?
      raise(Puppet::ParseError, 'join(): You must provide prefix ' +
        'to add to join')
    end

    if prefix and not prefix.empty?
      result = prefix + array.join(suffix + prefix)
    else
      result = array.join(suffix)
    end

    return result
  end
end

# vim: set ts=2 sw=2 et :