0c16722ee2184fd0e1c887af1baec8be893494c2
[mirror/dsa-puppet.git] / 3rdparty / modules / stdlib / lib / puppet / parser / functions / intersection.rb
1 #
2 # intersection.rb
3 #
4 module Puppet::Parser::Functions
5   newfunction(:intersection, :type => :rvalue, :doc => <<-DOC
6     This function returns an array of the intersection of two.
7
8     *Examples:*
9
10         intersection(["a","b","c"],["b","c","d"])  # returns ["b","c"]
11         intersection(["a","b","c"],[1,2,3,4])      # returns [] (true, when evaluated as a Boolean)
12     DOC
13              ) do |arguments|
14
15     # Two arguments are required
16     raise(Puppet::ParseError, "intersection(): Wrong number of arguments given (#{arguments.size} for 2)") if arguments.size != 2
17
18     first = arguments[0]
19     second = arguments[1]
20
21     unless first.is_a?(Array) && second.is_a?(Array)
22       raise(Puppet::ParseError, 'intersection(): Requires 2 arrays')
23     end
24
25     result = first & second
26
27     return result
28   end
29 end
30
31 # vim: set ts=2 sw=2 et :