blob: 1c712e896dc3d4adf189154eada65ce08fc764b2 (
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
75
76
77
78
|
require 'puppet/parser/ast/branch'
class Puppet::Parser::AST
# Each individual option in a case statement.
class CaseOpt < AST::Branch
attr_accessor :value, :statements
# CaseOpt is a bit special -- we just want the value first,
# so that CaseStatement can compare, and then it will selectively
# decide whether to fully evaluate this option
def each
[@value,@statements].each { |child| yield child }
end
# Are we the default option?
def default?
# Cache the @default value.
if defined? @default
return @default
end
if @value.is_a?(AST::ASTArray)
@value.each { |subval|
if subval.is_a?(AST::Default)
@default = true
break
end
}
else
if @value.is_a?(AST::Default)
@default = true
end
end
unless defined? @default
@default = false
end
return @default
end
# You can specify a list of values; return each in turn.
def eachvalue(scope)
if @value.is_a?(AST::ASTArray)
@value.each { |subval|
if scope
yield subval.evaluate(:scope => scope)
elsif subval.is_a? AST::Leaf
yield subval.value
end
}
else
if scope
yield @value.evaluate(:scope => scope)
elsif @value.is_a? AST::Leaf
yield @value.value
end
end
end
# Evaluate the actual statements; this only gets called if
# our option matched.
def evaluate(hash)
scope = hash[:scope]
return @statements.safeevaluate(:scope => scope)
end
def tree(indent = 0)
rettree = [
@value.tree(indent + 1),
((@@indline * indent) + self.typewrap(self.pin)),
@statements.tree(indent + 1)
]
return rettree.flatten.join("\n")
end
end
end
|