require "htmlentities" require "uri" module Asciidoctor module Rfc::V3 module Blocks # Syntax: # [discrete] # == Section def floating_title(node) noko do |xml| xml.t { |xml_t| xml_t.strong node.title } end end # Syntax: # [[id]] # .name # [align=left|center|right,alt=alt_text] (optional) # .... # literal # .... def literal(node) artwork_attributes = { anchor: node.id, align: node.attr("align"), type: "ascii-art", name: node.title, alt: node.attr("alt"), } # NOTE: html escaping is performed by Nokogiri artwork_content = "\n" + node.lines.join("\n") + "\n" noko do |xml| if node.parent.context != :example xml.figure do |xml_figure| # xml_figure.artwork artwork_content, **attr_code(artwork_attributes) xml_figure.artwork **attr_code(artwork_attributes) do |a| a.cdata artwork_content end end else # xml.artwork artwork_content, **attr_code(artwork_attributes) xml.artwork **attr_code(artwork_attributes) do |a| a.cdata artwork_content end end end end # stem is treated as literal, but with center alignment def stem(node) artwork_attributes = { anchor: node.id, align: node.attr("align") || "center", type: "ascii-art", name: node.title, alt: node.attr("alt"), } # NOTE: html escaping is performed by Nokogiri artwork_content = "\n" + node.lines.join("\n") + "\n" noko do |xml| if node.parent.context != :example xml.figure do |xml_figure| # xml_figure.artwork artwork_content, **attr_code(artwork_attributes) xml_figure.artwork **attr_code(artwork_attributes) do |a| a.cdata artwork_content end end else # xml.artwork artwork_content, **attr_code(artwork_attributes) xml.artwork **attr_code(artwork_attributes) do |a| a.cdata artwork_content end end end end # Syntax: # [[id]] # [quote, attribution, citation info] # citation info limited to URL # Text def quote(node) cite_value = node.attr("citetitle") cite_value = nil unless cite_value.to_s =~ URI::DEFAULT_PARSER.make_regexp blockquote_attributes = { anchor: node.id, quotedFrom: node.attr("attribution"), cite: cite_value, } noko do |xml| xml.blockquote **attr_code(blockquote_attributes) do |xml_blockquote| xml_blockquote << node.content end end end # realise as quote() ;
in v3 does not have the applicability of , # it is restricted to tables def verse(node) quote(node) end # Syntax: # = Title # Author # :HEADER # # ABSTRACT # # NOTE: note # # [NOTE] # .Title (in preamble) # ==== # Content # ==== # # [NOTE,removeInRFC=true] (in preamble) # [NOTE,display=true|false,source=name] (in body) # .Title # ==== # Content # ==== # @note admonitions within preamble are notes. Elsewhere, they are comments. def admonition(node) result = [] if node.parent.context == :preamble note_attributes = { removeInRFC: node.attr("remove-in-rfc"), } result << noko do |xml| xml.note **attr_code(note_attributes) do |xml_note| xml_note.name node.title unless node.title.nil? xml_note << HTMLEntities.new.decode([paragraph1(node)].flatten.join("\n")) end end else cref_attributes = { anchor: node.id, display: node.attr("display"), source: node.attr("source"), } cref_contents = node.blocks? ? flatten(node) : node.content cref_contents = [cref_contents].flatten.join("\n") warn <<~WARNING_MESSAGE if node.blocks? asciidoctor: WARNING (#{current_location(node)}): comment can not contain blocks of text in XML RFC:\n #{node.content} WARNING_MESSAGE result << noko do |xml| xml.cref **attr_code(cref_attributes) do |xml_cref| xml_cref << cref_contents end end end result end # Syntax: # [[id]] # **** # Sidebar # **** def sidebar(node) aside_attributes = { anchor: node.id, } noko do |xml| xml.aside **attr_code(aside_attributes) do |xml_aside| xml_aside << node.content end end end # Syntax: # .Title # ==== # Example # ==== def example(node) node.blocks.each do |b| unless %i{listing image literal stem}.include? b.context warn "asciidoctor: WARNING (#{current_location(b)}): examples (figures) should only contain listings (sourcecode), images (artwork), or literal (artwork):\n#{b.lines}" end end figure_attributes = { anchor: node.id, } noko do |xml| xml.figure **attr_code(figure_attributes) do |xml_figure| xml_figure.name node.title if node.title? # TODO iref xml_figure << node.content end end end # Syntax: # .name # [source,type,src=uri] (src is mutually exclusive with listing content) (v3) # [source,type,src=uri,align,alt] (src is mutually exclusive with listing content) (v2) # ---- # code # ---- def listing(node) sourcecode_attributes = { anchor: node.id, align: nil, alt: nil, name: node.title, type: node.attr("language"), src: node.attr("src"), } # NOTE: html escaping is performed by Nokogiri sourcecode_content = sourcecode_attributes[:src].nil? ? "\n" + node.lines.join("\n") + "\n" : "" noko do |xml| if node.parent.context != :example xml.figure do |xml_figure| # xml_figure.sourcecode sourcecode_content, **attr_code(sourcecode_attributes) xml_figure.sourcecode **attr_code(sourcecode_attributes) do |a| a.cdata sourcecode_content end end else # xml.sourcecode sourcecode_content, **attr_code(sourcecode_attributes) xml.sourcecode **attr_code(sourcecode_attributes) do |a| a.cdata sourcecode_content end end end end end end end