Class: Puppet::Pops::Parser::CodeMerger
- Defined in:
- lib/puppet/pops/parser/code_merger.rb
Instance Method Summary collapse
-
#concatenate(parse_results) ⇒ Object
Concatenates the logic in the array of parse results into one parse result.
Instance Method Details
#concatenate(parse_results) ⇒ Object
Concatenates the logic in the array of parse results into one parse result.
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
# File 'lib/puppet/pops/parser/code_merger.rb', line 7 def concatenate(parse_results) # this is a bit brute force as the result is already 3x ast with wrapped 4x content # this could be combined in a more elegant way, but it is only used to process a handful of files # at the beginning of a puppet run. TODO: Revisit for Puppet 4x when there is no 3x ast at the top. # PUP-5299, some sites have thousands of entries, and run out of stack when evaluating - the logic # below maps the logic as flatly as possible. # children = parse_results.select { |x| !x.nil? && x.code }.flat_map do |parsed_class| case parsed_class.code when Puppet::Parser::AST::BlockExpression # the BlockExpression wraps a single 4x instruction that is most likely wrapped in a Factory parsed_class.code.children.map { |c| c.is_a?(Puppet::Pops::Model::Factory) ? c.model : c } when Puppet::Pops::Model::Factory # If it is a 4x instruction wrapped in a Factory parsed_class.code.model else # It is the instruction directly parsed_class.code end end Puppet::Parser::AST::BlockExpression.new(:children => children) end |