41 lines
1.0 KiB
Ruby
41 lines
1.0 KiB
Ruby
require 'puppet/pops'
|
|
|
|
require_relative '../../yardoc'
|
|
require_relative 'yard_statement'
|
|
|
|
module Puppetx::Yardoc::Pops
|
|
# Loosely based on the TreeDumper classes in Pops::Model. The responsibility of
|
|
# this class is to walk a Pops::Model and output objects that can be consumed
|
|
# by YARD handlers.
|
|
#
|
|
# @note Currently, this class only extracts node, host class and type
|
|
# definitions.
|
|
class YARDTransformer
|
|
def initialize
|
|
@transform_visitor = Puppet::Pops::Visitor.new(self, 'transform')
|
|
end
|
|
|
|
def transform(o)
|
|
@transform_visitor.visit(o)
|
|
end
|
|
|
|
private
|
|
|
|
def transform_Factory(o)
|
|
transform(o.current)
|
|
end
|
|
|
|
def transform_Program(o)
|
|
o.definitions.map{|d| transform(d)}
|
|
end
|
|
|
|
# Extract comments from "Definition" objects. That is: nodes definitions,
|
|
# type definitions and class definitions. Wrap them into YARDStatement
|
|
# objects that provide an interface for YARD handlers.
|
|
def transform_Definition(o)
|
|
YARDStatement.new(o)
|
|
end
|
|
|
|
end
|
|
end
|