Class: Puppet::Pops::Model::ModelTreeDumper
Overview
Dumps a Pops::Model in reverse polish notation; i.e. LISP style The intention is to use this for debugging output TODO: BAD NAME - A DUMP is a Ruby Serialization
Instance Attribute Summary
Attributes inherited from TreeDumper
#indent_count
Instance Method Summary
collapse
Methods inherited from TreeDumper
#do_dump, #dump, #format, #format_r, #indent, #initialize
Instance Method Details
#dump_AccessExpression(o) ⇒ Object
40
41
42
43
44
45
46
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 40
def dump_AccessExpression o
if o.keys.size <= 1
["slice", do_dump(o.left_expr), do_dump(o.keys[0])]
else
["slice", do_dump(o.left_expr), do_dump(o.keys)]
end
end
|
#dump_AndExpression(o) ⇒ Object
92
93
94
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 92
def dump_AndExpression o
["&&", do_dump(o.left_expr), do_dump(o.right_expr)]
end
|
#dump_ArithmeticExpression(o) ⇒ Object
35
36
37
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 35
def dump_ArithmeticExpression o
[o.operator.to_s, do_dump(o.left_expr), do_dump(o.right_expr)]
end
|
#dump_Array(o) ⇒ Object
6
7
8
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 6
def dump_Array o
o.collect {|e| do_dump(e) }
end
|
#dump_AssignmentExpression(o) ⇒ Object
104
105
106
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 104
def dump_AssignmentExpression o
[o.operator.to_s, do_dump(o.left_expr), do_dump(o.right_expr)]
end
|
#dump_AttributeOperation(o) ⇒ Object
Produces (name => expr) or (name +> expr)
109
110
111
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 109
def dump_AttributeOperation o
[o.attribute_name, o.operator, do_dump(o.value_expr)]
end
|
#dump_BlockExpression(o) ⇒ Object
185
186
187
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 185
def dump_BlockExpression o
["block"] + o.statements.collect {|x| do_dump(x) }
end
|
#dump_CallMethodExpression(o) ⇒ Object
def dump_CallNamedFunctionExpression o
result = [o.rval_required ? "call" : "invoke", do_dump(o.functor_expr)]
o.arguments.collect {|a| result << do_dump(a) }
result
end
304
305
306
307
308
309
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 304
def dump_CallMethodExpression o
result = [o.rval_required ? "call-method" : "invoke-method", do_dump(o.functor_expr)]
o.arguments.collect {|a| result << do_dump(a) }
result << do_dump(o.lambda) if o.lambda
result
end
|
#dump_CallNamedFunctionExpression(o) ⇒ Object
Produces (invoke name args…) when not required to produce an rvalue, and (call name args … ) otherwise.
292
293
294
295
296
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 292
def dump_CallNamedFunctionExpression o
result = [o.rval_required ? "call" : "invoke", do_dump(o.functor_expr)]
o.arguments.collect {|a| result << do_dump(a) }
result
end
|
#dump_CaseExpression(o) ⇒ Object
311
312
313
314
315
316
317
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 311
def dump_CaseExpression o
result = ["case", do_dump(o.test), :indent]
o.options.each do |s|
result << :break << do_dump(s)
end
result << :dedent
end
|
#dump_CaseOption(o) ⇒ Object
319
320
321
322
323
324
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 319
def dump_CaseOption o
result = ["when"]
result << o.values.collect {|x| do_dump(x) }
result << ["then", do_dump(o.then_expr) ]
result
end
|
#dump_CollectExpression(o) ⇒ Object
52
53
54
55
56
57
58
59
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 52
def dump_CollectExpression o
result = ["collect", do_dump(o.type_expr), :indent, :break, do_dump(o.query), :indent]
o.operations do |ao|
result << :break << do_dump(ao)
end
result += [:dedent, :dedent ]
result
end
|
#dump_ComparisonExpression(o) ⇒ Object
88
89
90
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 88
def dump_ComparisonExpression o
[o.operator.to_s, do_dump(o.left_expr), do_dump(o.right_expr)]
end
|
#dump_ConcatenatedString(o) ⇒ Object
Interpolated strings are shown as (cat seg0 seg1 … segN)
190
191
192
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 190
def dump_ConcatenatedString o
["cat"] + o.segments.collect {|x| do_dump(x)}
end
|
#dump_EppExpression(o) ⇒ Object
61
62
63
64
65
66
67
68
69
70
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 61
def dump_EppExpression o
result = ["epp"]
if o.body
result << do_dump(o.body)
else
result << []
end
result
end
|
#dump_ExportedQuery(o) ⇒ Object
72
73
74
75
76
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 72
def dump_ExportedQuery o
result = ["<<| |>>"]
result += dump_QueryExpression(o) unless is_nop?(o.expr)
result
end
|
#dump_Factory(o) ⇒ Object
31
32
33
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 31
def dump_Factory o
do_dump(o.current)
end
|
#dump_HeredocExpression(o) ⇒ Object
194
195
196
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 194
def dump_HeredocExpression(o)
result = ["@(#{o.syntax})", :indent, :break, do_dump(o.text_expr), :dedent, :break]
end
|
#dump_HostClassDefinition(o) ⇒ Object
198
199
200
201
202
203
204
205
206
207
208
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 198
def dump_HostClassDefinition o
result = ["class", o.name]
result << ["inherits", o.parent_class] if o.parent_class
result << ["parameters"] + o.parameters.collect {|p| do_dump(p) } if o.parameters.size() > 0
if o.body
result << do_dump(o.body)
else
result << []
end
result
end
|
#dump_IfExpression(o) ⇒ Object
269
270
271
272
273
274
275
276
277
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 269
def dump_IfExpression o
result = ["if", do_dump(o.test), :indent, :break,
["then", :indent, do_dump(o.then_expr), :dedent]]
result +=
[:break,
["else", :indent, do_dump(o.else_expr), :dedent],
:dedent] unless is_nop? o.else_expr
result
end
|
#dump_InExpression(o) ⇒ Object
100
101
102
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 100
def dump_InExpression o
["in", do_dump(o.left_expr), do_dump(o.right_expr)]
end
|
#dump_KeyedEntry(o) ⇒ Object
121
122
123
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 121
def dump_KeyedEntry o
[do_dump(o.key), do_dump(o.value)]
end
|
#dump_LambdaExpression(o) ⇒ Object
133
134
135
136
137
138
139
140
141
142
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 133
def dump_LambdaExpression o
result = ["lambda"]
result << ["parameters"] + o.parameters.collect {|p| do_dump(p) } if o.parameters.size() > 0
if o.body
result << do_dump(o.body)
else
result << []
end
result
end
|
#dump_LiteralDefault(o) ⇒ Object
144
145
146
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 144
def dump_LiteralDefault o
":default"
end
|
#dump_LiteralFloat(o) ⇒ Object
10
11
12
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 10
def dump_LiteralFloat o
o.value.to_s
end
|
#dump_LiteralHash(o) ⇒ Object
117
118
119
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 117
def dump_LiteralHash o
["{}"] + o.entries.collect {|x| do_dump(x)}
end
|
#dump_LiteralInteger(o) ⇒ Object
14
15
16
17
18
19
20
21
22
23
24
25
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 14
def dump_LiteralInteger o
case o.radix
when 10
o.value.to_s
when 8
"0%o" % o.value
when 16
"0x%X" % o.value
else
"bad radix:" + o.value.to_s
end
end
|
#dump_LiteralList(o) ⇒ Object
113
114
115
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 113
def dump_LiteralList o
["[]"] + o.values.collect {|x| do_dump(x)}
end
|
#dump_LiteralRegularExpression(o) ⇒ Object
152
153
154
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 152
def dump_LiteralRegularExpression o
"/#{o.value.source}/"
end
|
#dump_LiteralString(o) ⇒ Object
129
130
131
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 129
def dump_LiteralString o
"'#{o.value}'"
end
|
#dump_LiteralUndef(o) ⇒ Object
148
149
150
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 148
def dump_LiteralUndef o
":undef"
end
|
#dump_LiteralValue(o) ⇒ Object
27
28
29
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 27
def dump_LiteralValue o
o.value.to_s
end
|
#dump_MatchesExpression(o) ⇒ Object
48
49
50
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 48
def dump_MatchesExpression o
[o.operator.to_s, do_dump(o.left_expr), do_dump(o.right_expr)]
end
|
#dump_MatchExpression(o) ⇒ Object
125
126
127
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 125
def dump_MatchExpression o
[o.operator.to_s, do_dump(o.left_expr), do_dump(o.right_expr)]
end
|
#dump_NamedAccessExpression(o) ⇒ Object
160
161
162
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 160
def dump_NamedAccessExpression o
[".", do_dump(o.left_expr), do_dump(o.right_expr)]
end
|
#dump_NamedDefinition(o) ⇒ Object
222
223
224
225
226
227
228
229
230
231
232
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 222
def dump_NamedDefinition o
result = [nil, o.name]
result << ["parameters"] + o.parameters.collect {|p| do_dump(p) } if o.parameters.size() > 0
if o.body
result << do_dump(o.body)
else
result << []
end
result
end
|
#dump_NilClass(o) ⇒ Object
164
165
166
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 164
def dump_NilClass o
"()"
end
|
#dump_NodeDefinition(o) ⇒ Object
210
211
212
213
214
215
216
217
218
219
220
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 210
def dump_NodeDefinition o
result = ["node"]
result << ["matches"] + o.host_matches.collect {|m| do_dump(m) }
result << ["parent", do_dump(o.parent)] if o.parent
if o.body
result << do_dump(o.body)
else
result << []
end
result
end
|
#dump_Nop(o) ⇒ Object
156
157
158
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 156
def dump_Nop o
":nop"
end
|
#dump_NotExpression(o) ⇒ Object
168
169
170
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 168
def dump_NotExpression o
['!', dump(o.expr)]
end
|
#dump_Object(o) ⇒ Object
378
379
380
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 378
def dump_Object o
[o.class.to_s, o.to_s]
end
|
#dump_OrExpression(o) ⇒ Object
96
97
98
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 96
def dump_OrExpression o
["||", do_dump(o.left_expr), do_dump(o.right_expr)]
end
|
#dump_Parameter(o) ⇒ Object
Produces parameters as name, or (= name value)
250
251
252
253
254
255
256
257
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 250
def dump_Parameter o
name_part = "#{o.name}"
if o.value
["=", name_part, do_dump(o.value)]
else
name_part
end
end
|
#dump_ParenthesizedExpression(o) ⇒ Object
259
260
261
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 259
def dump_ParenthesizedExpression o
do_dump(o.expr)
end
|
#dump_Program(o) ⇒ Object
Hides that Program exists in the output (only its body is shown), the definitions are just references to contained classes, resource types, and nodes
265
266
267
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 265
def dump_Program(o)
dump(o.body)
end
|
#dump_QueryExpression(o) ⇒ Object
84
85
86
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 84
def dump_QueryExpression o
[do_dump(o.expr)]
end
|
#dump_RelationshipExpression(o) ⇒ Object
326
327
328
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 326
def dump_RelationshipExpression o
[o.operator.to_s, do_dump(o.left_expr), do_dump(o.right_expr)]
end
|
#dump_RenderExpression(o) ⇒ Object
334
335
336
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 334
def dump_RenderExpression o
["render", do_dump(o.expr)]
end
|
#dump_RenderStringExpression(o) ⇒ Object
330
331
332
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 330
def dump_RenderStringExpression o
["render-s", " '#{o.value}'"]
end
|
#dump_ResourceBody(o) ⇒ Object
338
339
340
341
342
343
344
345
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 338
def dump_ResourceBody o
result = [do_dump(o.title), :indent]
o.operations.each do |p|
result << :break << do_dump(p)
end
result << :dedent
result
end
|
#dump_ResourceDefaultsExpression(o) ⇒ Object
347
348
349
350
351
352
353
354
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 347
def dump_ResourceDefaultsExpression o
result = ["resource-defaults", do_dump(o.type_ref), :indent]
o.operations.each do |p|
result << :break << do_dump(p)
end
result << :dedent
result
end
|
#dump_ResourceExpression(o) ⇒ Object
356
357
358
359
360
361
362
363
364
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 356
def dump_ResourceExpression o
form = o.form == :regular ? '' : o.form.to_s + "-"
result = [form+"resource", do_dump(o.type_name), :indent]
o.bodies.each do |b|
result << :break << do_dump(b)
end
result << :dedent
result
end
|
#dump_ResourceOverrideExpression(o) ⇒ Object
240
241
242
243
244
245
246
247
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 240
def dump_ResourceOverrideExpression o
result = ["override", do_dump(o.resources), :indent]
o.operations.each do |p|
result << :break << do_dump(p)
end
result << :dedent
result
end
|
#dump_ResourceTypeDefinition(o) ⇒ Object
234
235
236
237
238
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 234
def dump_ResourceTypeDefinition o
result = dump_NamedDefinition(o)
result[0] = 'define'
result
end
|
#dump_SelectorEntry(o) ⇒ Object
370
371
372
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 370
def dump_SelectorEntry o
[do_dump(o.matching_expr), "=>", do_dump(o.value_expr)]
end
|
#dump_SelectorExpression(o) ⇒ Object
366
367
368
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 366
def dump_SelectorExpression o
["?", do_dump(o.left_expr)] + o.selectors.collect {|x| do_dump(x) }
end
|
#dump_SubLocatedExpression(o) ⇒ Object
374
375
376
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 374
def dump_SubLocatedExpression o
["sublocated", do_dump(o.expr)]
end
|
#dump_TextExpression(o) ⇒ Object
Interpolation (to string) shown as (str expr)
177
178
179
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 177
def dump_TextExpression o
["str", do_dump(o.expr)]
end
|
#dump_UnaryMinusExpression(o) ⇒ Object
181
182
183
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 181
def dump_UnaryMinusExpression o
['-', do_dump(o.expr)]
end
|
#dump_UnlessExpression(o) ⇒ Object
279
280
281
282
283
284
285
286
287
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 279
def dump_UnlessExpression o
result = ["unless", do_dump(o.test), :indent, :break,
["then", :indent, do_dump(o.then_expr), :dedent]]
result +=
[:break,
["else", :indent, do_dump(o.else_expr), :dedent],
:dedent] unless is_nop? o.else_expr
result
end
|
#dump_VariableExpression(o) ⇒ Object
172
173
174
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 172
def dump_VariableExpression o
"$#{dump(o.expr)}"
end
|
#dump_VirtualQuery(o) ⇒ Object
78
79
80
81
82
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 78
def dump_VirtualQuery o
result = ["<| |>"]
result += dump_QueryExpression(o) unless is_nop?(o.expr)
result
end
|
#is_nop?(o) ⇒ Boolean
382
383
384
|
# File 'lib/puppet/pops/model/model_tree_dumper.rb', line 382
def is_nop? o
o.nil? || o.is_a?(Puppet::Pops::Model::Nop)
end
|