2014-05-23 04:02:35 +00:00
|
|
|
require 'puppetx/yardoc'
|
|
|
|
|
2014-05-22 05:14:53 +00:00
|
|
|
require 'puppet/pops'
|
|
|
|
|
2014-05-23 04:02:35 +00:00
|
|
|
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.
|
|
|
|
class YARDTransformer
|
2014-05-22 05:14:53 +00:00
|
|
|
def initialize
|
2014-05-23 04:02:35 +00:00
|
|
|
@transform_visitor = Puppet::Pops::Visitor.new(self, 'transform')
|
2014-05-22 05:14:53 +00:00
|
|
|
end
|
|
|
|
|
2014-05-23 04:02:35 +00:00
|
|
|
def transform(o)
|
|
|
|
@transform_visitor.visit(o)
|
2014-05-22 05:14:53 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2014-05-23 04:02:35 +00:00
|
|
|
def transform_Factory(o)
|
|
|
|
transform(o.current)
|
2014-05-22 05:14:53 +00:00
|
|
|
end
|
|
|
|
|
2014-05-23 04:02:35 +00:00
|
|
|
def transform_Program(o)
|
|
|
|
# FIXME: Uuuuuughhhhhhhhh.... This should be extracted some other way.
|
|
|
|
# Perhaps using a SourcePosAdapter?
|
2014-05-22 05:14:53 +00:00
|
|
|
@source_text = o.source_text.lines.to_a
|
|
|
|
@locator = o.locator
|
|
|
|
|
2014-05-23 04:02:35 +00:00
|
|
|
o.definitions.map{|d| transform(d)}
|
2014-05-22 05:14:53 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# Extract comments from "Definition" objects. That is: nodes definitions,
|
|
|
|
# type definitions and class definitions.
|
2014-05-23 04:02:35 +00:00
|
|
|
def transform_Definition(o)
|
2014-05-22 05:14:53 +00:00
|
|
|
line = @locator.line_for_offset(o.offset)
|
|
|
|
comments_before(line)
|
|
|
|
end
|
|
|
|
|
2014-05-23 04:02:35 +00:00
|
|
|
# TODO: This stuff should probably be part of a separate class/adapter.
|
|
|
|
COMMENT_PATTERN = /^\s*#.*\n/
|
|
|
|
|
2014-05-22 05:14:53 +00:00
|
|
|
def comments_before(line)
|
|
|
|
comments = []
|
|
|
|
|
|
|
|
# FIXME: Horribly inefficient. Multiple copies. Generator pattern would
|
|
|
|
# be much better.
|
|
|
|
@source_text.slice(0, line-1).reverse.each do |line|
|
|
|
|
if COMMENT_PATTERN.match(line)
|
|
|
|
comments.unshift line
|
|
|
|
else
|
|
|
|
# No comment found on this line. We must be done piecing together a
|
|
|
|
# comment block.
|
|
|
|
break
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Stick everything back together.
|
|
|
|
comments.join
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|