blob: ecad163d4e4157af4547f03c66462f462d3f58a3 (
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
|
require 'puppet/parser/ast/branch'
class Puppet::Parser::AST
# The inline conditional operator. Unlike CaseStatement, which executes
# code, we just return a value.
class Selector < AST::Branch
attr_accessor :param, :values
def each
[@param,@values].each { |child| yield child }
end
# Find the value that corresponds with the test.
def evaluate(scope)
retvalue = nil
found = nil
# Get our parameter.
paramvalue = @param.safeevaluate(scope)
sensitive = Puppet[:casesensitive]
if ! sensitive and paramvalue.respond_to?(:downcase)
paramvalue = paramvalue.downcase
end
default = nil
unless @values.instance_of? AST::ASTArray or @values.instance_of? Array
@values = [@values]
end
# Then look for a match in the options.
@values.each { |obj|
param = obj.param.safeevaluate(scope)
if ! sensitive && param.respond_to?(:downcase)
param = param.downcase
end
if param == paramvalue
# we found a matching option
retvalue = obj.value.safeevaluate(scope)
found = true
break
elsif obj.param.is_a?(Default)
# Store the default, in case it's necessary.
default = obj
end
}
# Unless we found something, look for the default.
unless found
if default
retvalue = default.value.safeevaluate(scope)
else
self.fail Puppet::ParseError,
"No matching value for selector param '%s'" % paramvalue
end
end
return retvalue
end
end
end
|