2015-12-15 09:51:16 -05:00
|
|
|
module Banzai
|
|
|
|
# Extract possible GFM references from an arbitrary String for further processing.
|
|
|
|
class ReferenceExtractor
|
|
|
|
def initialize
|
|
|
|
@texts = []
|
|
|
|
end
|
|
|
|
|
|
|
|
def analyze(text, context = {})
|
|
|
|
@texts << Renderer.render(text, context)
|
|
|
|
end
|
|
|
|
|
2016-05-26 07:16:43 -04:00
|
|
|
def references(type, project, current_user = nil)
|
|
|
|
processor = Banzai::ReferenceParser[type].
|
|
|
|
new(project, current_user)
|
|
|
|
|
|
|
|
processor.process(html_documents)
|
|
|
|
end
|
2015-12-15 09:51:16 -05:00
|
|
|
|
2016-05-26 07:16:43 -04:00
|
|
|
private
|
2015-12-15 09:51:16 -05:00
|
|
|
|
2016-05-26 07:16:43 -04:00
|
|
|
def html_documents
|
|
|
|
# This ensures that we don't memoize anything until we have a number of
|
|
|
|
# text blobs to parse.
|
|
|
|
return [] if @texts.empty?
|
2015-12-15 09:51:16 -05:00
|
|
|
|
2016-05-26 07:16:43 -04:00
|
|
|
@html_documents ||= @texts.map { |html| Nokogiri::HTML.fragment(html) }
|
2015-12-15 09:51:16 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|