kramdown-rfc2629 1.3.23 → 1.3.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +15 -4
- data/bin/kdrfc +11 -1
- data/bin/kramdown-rfc2629 +3 -3
- data/kramdown-rfc2629.gemspec +2 -2
- data/lib/kramdown-rfc/erb.rb +16 -0
- data/lib/kramdown-rfc/refxml.rb +4 -2
- data/lib/kramdown-rfc2629.rb +33 -3
- metadata +5 -4
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: c6818d86a47ba8a06c199cdbca16a30644b06c4bb517fc7a5a5a35d93161a0e6
         | 
| 4 | 
            +
              data.tar.gz: cb90602fd0b11b2e010200ffc4fac1727cd0aa446d2e59e5861d4fcd6b1cf579
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: b2c6ca51eaf892fb8b52c4bf115a82830deb1df21afcc0fb28c58eabbe273b727872be851d5e858c1018ce97e3ee5b8e7464086d4652a17af2f1144dda5f86a4
         | 
| 7 | 
            +
              data.tar.gz: fb3125ce8ee03845999ad6f7e09cc9047ee4f4f3406da987c6a1458c0a4de65d0c2d590f62d02c516aa1d3de4d71e21660d33313fbf370452d57ee98d0a472ee
         | 
    
        data/README.md
    CHANGED
    
    | @@ -294,13 +294,24 @@ output generated by the tool (e.g., `plantuml-utxt`). | |
| 294 294 |  | 
| 295 295 | 
             
            Currently supported labels as of 1.3.9:
         | 
| 296 296 |  | 
| 297 | 
            -
            * goat, ditaa: ASCII (plaintext) art to figure conversion
         | 
| 298 | 
            -
            * mscgen: Message Sequence Charts
         | 
| 299 | 
            -
            * plantuml: widely used multi-purpose diagram generator
         | 
| 297 | 
            +
            * [goat][], [ditaa][]: ASCII (plaintext) art to figure conversion
         | 
| 298 | 
            +
            * [mscgen][]: Message Sequence Charts
         | 
| 299 | 
            +
            * [plantuml][]: widely used multi-purpose diagram generator
         | 
| 300 300 | 
             
            * plantuml-utxt: Like plantuml, except that a plantuml-generated
         | 
| 301 301 | 
             
              plaintext form is used
         | 
| 302 | 
            -
            * mermaid: Very experimental; the conversion to SVG is prone to
         | 
| 302 | 
            +
            * [mermaid][]: Very experimental; the conversion to SVG is prone to
         | 
| 303 303 | 
             
              generate black-on-black text in this version
         | 
| 304 | 
            +
            * math: display math using [tex2svg][] for HTML/PDF and [asciitex][]
         | 
| 305 | 
            +
              (fork: [asciiTeX][asciiTeX-eggert]) for plaintext
         | 
| 306 | 
            +
             | 
| 307 | 
            +
            [goat]: https://github.com/blampe/goat
         | 
| 308 | 
            +
            [ditaa]:  https://github.com/stathissideris/ditaa
         | 
| 309 | 
            +
            [mscgen]: http://www.mcternan.me.uk/mscgen/
         | 
| 310 | 
            +
            [plantuml]: https://plantuml.com
         | 
| 311 | 
            +
            [mermaid]: https://github.com/mermaid-js/mermaid-cli
         | 
| 312 | 
            +
            [tex2svg]: https://github.com/mathjax/MathJax-demos-node/blob/master/direct/tex2svg
         | 
| 313 | 
            +
            [asciitex]: http://asciitex.sourceforge.net/
         | 
| 314 | 
            +
            [asciiTeX-eggert]: https://github.com/larseggert/asciiTeX
         | 
| 304 315 |  | 
| 305 316 | 
             
            Note that this feature does not play well with the CI (continuous
         | 
| 306 317 | 
             
            integration) support in Martin Thomson's [I-D Template][], as that may
         | 
    
        data/bin/kdrfc
    CHANGED
    
    | @@ -24,6 +24,12 @@ def process_mkd(input, output) | |
| 24 24 | 
             
              end
         | 
| 25 25 | 
             
            end
         | 
| 26 26 |  | 
| 27 | 
            +
            def run_idnits(txt_fn)
         | 
| 28 | 
            +
              unless system("idnits", txt_fn)
         | 
| 29 | 
            +
                warn "*** problem #$? running idnits"
         | 
| 30 | 
            +
              end
         | 
| 31 | 
            +
            end
         | 
| 32 | 
            +
             | 
| 27 33 | 
             
            def process_xml(*args)
         | 
| 28 34 | 
             
              if $options.remote
         | 
| 29 35 | 
             
                process_xml_remotely(*args)
         | 
| @@ -124,6 +130,9 @@ BANNER | |
| 124 130 | 
             
              opts.on("-c", "--[no-]convert", "Convert xml to v3 xml") do |v|
         | 
| 125 131 | 
             
                $options.v2v3 = v
         | 
| 126 132 | 
             
              end
         | 
| 133 | 
            +
              opts.on("-i", "--[no-]idnits", "Run idnits on the resulting text") do |v|
         | 
| 134 | 
            +
                $options.idnits = v
         | 
| 135 | 
            +
              end
         | 
| 127 136 | 
             
              opts.on("-h", "--[no-]html", "Convert to html as well") do |v|
         | 
| 128 137 | 
             
                $options.html = v
         | 
| 129 138 | 
             
              end
         | 
| @@ -139,8 +148,9 @@ op.parse! | |
| 139 148 | 
             
            def process_the_xml(fn, base)
         | 
| 140 149 | 
             
              process_xml(fn, "#{base}.prepped.xml", "--preptool") if $options.prep
         | 
| 141 150 | 
             
              process_xml(fn, "#{base}.v2v3.xml", "--v2v3") if $options.v2v3
         | 
| 142 | 
            -
              process_xml(fn, "#{base}.txt") if $options.txt
         | 
| 151 | 
            +
              process_xml(fn, "#{base}.txt") if $options.txt || $options.idnits
         | 
| 143 152 | 
             
              process_xml(fn, "#{base}.html", "--html") if $options.html
         | 
| 153 | 
            +
              run_idnits("#{base}.txt") if $options.idnits
         | 
| 144 154 | 
             
            end
         | 
| 145 155 |  | 
| 146 156 | 
             
            case ARGV.size
         | 
    
        data/bin/kramdown-rfc2629
    CHANGED
    
    | @@ -4,7 +4,7 @@ require 'kramdown-rfc2629' | |
| 4 4 | 
             
            require 'kramdown-rfc/parameterset'
         | 
| 5 5 | 
             
            require 'kramdown-rfc/refxml'
         | 
| 6 6 | 
             
            require 'yaml'
         | 
| 7 | 
            -
            require 'erb'
         | 
| 7 | 
            +
            require 'kramdown-rfc/erb'
         | 
| 8 8 | 
             
            require 'date'
         | 
| 9 9 |  | 
| 10 10 | 
             
            # try to get this from gemspec.
         | 
| @@ -154,7 +154,7 @@ def xml_from_sections(input) | |
| 154 154 | 
             
                  if bibref
         | 
| 155 155 | 
             
                    if old = anchor_to_bibref[word]
         | 
| 156 156 | 
             
                      if bibref != old
         | 
| 157 | 
            -
                        warn "*** conflicting definitions for xref #{ | 
| 157 | 
            +
                        warn "*** conflicting definitions for xref #{word}: #{old} != #{bibref}"
         | 
| 158 158 | 
             
                      end
         | 
| 159 159 | 
             
                    else
         | 
| 160 160 | 
             
                      anchor_to_bibref[word] = bibref
         | 
| @@ -229,7 +229,7 @@ def xml_from_sections(input) | |
| 229 229 |  | 
| 230 230 | 
             
              erbfilename = File.expand_path '../../data/kramdown-rfc2629.erb', __FILE__
         | 
| 231 231 | 
             
              erbfile = File.read(erbfilename, coding: "UTF-8")
         | 
| 232 | 
            -
              erb = ERB. | 
| 232 | 
            +
              erb = ERB.trim_new(erbfile, '-')
         | 
| 233 233 | 
             
              # remove redundant nomarkdown pop outs/pop ins as they confuse kramdown
         | 
| 234 234 | 
             
              input = erb.result(binding).gsub(%r"{::nomarkdown}\s*{:/nomarkdown}"m, "")
         | 
| 235 235 | 
             
              ps.warn_if_leftovers
         | 
    
        data/kramdown-rfc2629.gemspec
    CHANGED
    
    | @@ -1,12 +1,12 @@ | |
| 1 1 | 
             
            spec = Gem::Specification.new do |s|
         | 
| 2 2 | 
             
              s.name = 'kramdown-rfc2629'
         | 
| 3 | 
            -
              s.version = '1.3. | 
| 3 | 
            +
              s.version = '1.3.28'
         | 
| 4 4 | 
             
              s.summary = "Kramdown extension for generating RFC 7749 XML."
         | 
| 5 5 | 
             
              s.description = %{An RFC7749 (XML2RFC) generating backend for Thomas Leitner's
         | 
| 6 6 | 
             
            "kramdown" markdown parser.  Mostly useful for RFC writers.}
         | 
| 7 7 | 
             
              s.add_dependency('kramdown', '~> 1.17.0')
         | 
| 8 8 | 
             
              s.add_dependency('certified', '~> 1.0')
         | 
| 9 | 
            -
              s.add_dependency(' | 
| 9 | 
            +
              s.add_dependency('json_pure', '~> 2.0')
         | 
| 10 10 | 
             
              s.files = Dir['lib/**/*.rb'] + %w(README.md LICENSE kramdown-rfc2629.gemspec bin/kdrfc bin/kramdown-rfc2629 bin/doilit bin/kramdown-rfc-extract-markdown data/kramdown-rfc2629.erb data/encoding-fallbacks.txt data/math.json)
         | 
| 11 11 | 
             
              s.require_path = 'lib'
         | 
| 12 12 | 
             
              s.executables = ['kramdown-rfc2629', 'doilit', 'kramdown-rfc-extract-markdown', 'kdrfc']
         | 
| @@ -0,0 +1,16 @@ | |
| 1 | 
            +
            require 'erb'
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            class ERB
         | 
| 4 | 
            +
             | 
| 5 | 
            +
              case version.sub("erb.rb [", "")
         | 
| 6 | 
            +
              when /\A2.1/                    # works back to 1.9.1
         | 
| 7 | 
            +
                def self.trim_new(s, trim)
         | 
| 8 | 
            +
                  ERB.new(s, nil, trim)
         | 
| 9 | 
            +
                end
         | 
| 10 | 
            +
              else
         | 
| 11 | 
            +
                def self.trim_new(s, trim)
         | 
| 12 | 
            +
                  ERB.new(s, trim_mode: trim)
         | 
| 13 | 
            +
                end
         | 
| 14 | 
            +
              end
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            end
         | 
    
        data/lib/kramdown-rfc/refxml.rb
    CHANGED
    
    | @@ -1,3 +1,5 @@ | |
| 1 | 
            +
            require 'kramdown-rfc/erb'
         | 
| 2 | 
            +
             | 
| 1 3 | 
             
            module KramdownRFC
         | 
| 2 4 |  | 
| 3 5 | 
             
              extend Kramdown::Utils::Html
         | 
| @@ -8,7 +10,7 @@ module KramdownRFC | |
| 8 10 |  | 
| 9 11 | 
             
              def self.ref_to_xml(k, v)
         | 
| 10 12 | 
             
                vps = KramdownRFC::ParameterSet.new(v)
         | 
| 11 | 
            -
                erb = ERB. | 
| 13 | 
            +
                erb = ERB.trim_new <<-REFERB, '-'
         | 
| 12 14 | 
             
            <reference anchor="<%= escattr(k) %>" <%= vps.attr("target") %>>
         | 
| 13 15 | 
             
              <front>
         | 
| 14 16 | 
             
                <%= vps.ele("title") -%>
         | 
| @@ -75,7 +77,7 @@ module KramdownRFC | |
| 75 77 | 
             
              ERB
         | 
| 76 78 |  | 
| 77 79 | 
             
              def self.person_element_from_aups(element_name, aups)
         | 
| 78 | 
            -
                erb = ERB. | 
| 80 | 
            +
                erb = ERB.trim_new(PERSON_ERB, '-')
         | 
| 79 81 | 
             
                erb.result(binding)
         | 
| 80 82 | 
             
              end
         | 
| 81 83 |  | 
    
        data/lib/kramdown-rfc2629.rb
    CHANGED
    
    | @@ -128,6 +128,22 @@ module Kramdown | |
| 128 128 | 
             
              end
         | 
| 129 129 |  | 
| 130 130 | 
             
              class Element
         | 
| 131 | 
            +
             | 
| 132 | 
            +
                # Not fixing studly element names postalLine and seriesInfo yet
         | 
| 133 | 
            +
             | 
| 134 | 
            +
                # occasionally regenerate the studly attribute name list via
         | 
| 135 | 
            +
                # script in data/studly.rb
         | 
| 136 | 
            +
                STUDLY_ATTR = %w(
         | 
| 137 | 
            +
                asciiAbbrev asciiFullname asciiInitials asciiName asciiSurname
         | 
| 138 | 
            +
                asciiValue blankLines derivedAnchor derivedContent derivedCounter
         | 
| 139 | 
            +
                derivedLink displayFormat docName expiresDate hangIndent hangText
         | 
| 140 | 
            +
                indexInclude iprExtract keepWithNext keepWithPrevious originalSrc
         | 
| 141 | 
            +
                prepTime quoteTitle quotedFrom removeInRFC sectionFormat seriesNo
         | 
| 142 | 
            +
                showOnFrontPage slugifiedName sortRefs submissionType symRefs tocDepth
         | 
| 143 | 
            +
                tocInclude
         | 
| 144 | 
            +
                )
         | 
| 145 | 
            +
                STUDLY_ATTR_MAP = Hash[STUDLY_ATTR.map {|s| [s.downcase, s]}]
         | 
| 146 | 
            +
             | 
| 131 147 | 
             
                def rfc2629_fix
         | 
| 132 148 | 
             
                  if a = attr
         | 
| 133 149 | 
             
                    if anchor = a.delete('id')
         | 
| @@ -136,6 +152,11 @@ module Kramdown | |
| 136 152 | 
             
                    if anchor = a.delete('href')
         | 
| 137 153 | 
             
                      a['target'] = anchor
         | 
| 138 154 | 
             
                    end
         | 
| 155 | 
            +
                    attr.keys.each do |k|
         | 
| 156 | 
            +
                      if (d = k.gsub(/_(.|$)/) { $1.upcase }) != k or d = STUDLY_ATTR_MAP[k]
         | 
| 157 | 
            +
                        a[d] = a.delete(k)
         | 
| 158 | 
            +
                      end
         | 
| 159 | 
            +
                    end
         | 
| 139 160 | 
             
                  end
         | 
| 140 161 | 
             
                end
         | 
| 141 162 | 
             
              end
         | 
| @@ -268,7 +289,12 @@ COLORS | |
| 268 289 | 
             
                    REXML::XPath.each(d.root, "//*[@fill]") { |x| x.attributes["fill"] = svg_munch_color(x.attributes["fill"], true) }
         | 
| 269 290 | 
             
                    REXML::XPath.each(d.root, "//*[@id]") { |x| x.attributes["id"] = svg_munch_id(x.attributes["id"]) }
         | 
| 270 291 | 
             
            ##      REXML::XPath.each(d.root, "//rect") { |x| x.attributes["style"] = "fill:none;stroke:black;stroke-width:1" unless x.attributes["style"] }
         | 
| 292 | 
            +
                    # Fix for mermaid:
         | 
| 293 | 
            +
                    REXML::XPath.each(d.root, "//polygon") { |x| x.attributes["rx"] = nil; x.attributes["ry"] = nil }
         | 
| 271 294 | 
             
                    d.to_s
         | 
| 295 | 
            +
                  rescue => detail
         | 
| 296 | 
            +
                    warn "*** Can't clean SVG: #{detail}"
         | 
| 297 | 
            +
                    d
         | 
| 272 298 | 
             
                  end
         | 
| 273 299 |  | 
| 274 300 | 
             
                  def memoize(meth, *args)
         | 
| @@ -309,13 +335,13 @@ COLORS | |
| 309 335 | 
             
                    when "mermaid"
         | 
| 310 336 | 
             
                      result1, err, _s = Open3.capture3("mmdc -i #{file.path}", stdin_data: result); #  -b transparent
         | 
| 311 337 | 
             
                      outpath = file.path + ".svg"
         | 
| 312 | 
            -
                      result1 = File.read(outpath)
         | 
| 313 | 
            -
                      File.unlink(outpath)
         | 
| 338 | 
            +
                      result1 = File.read(outpath) rescue '' # don't die before providing error message
         | 
| 339 | 
            +
                      File.unlink(outpath) rescue nil        # ditto
         | 
| 314 340 | 
             
                    when "plantuml", "plantuml-utxt"
         | 
| 315 341 | 
             
                      plantuml = "@startuml\n#{result}\n@enduml"
         | 
| 316 342 | 
             
                      result1, err, _s = Open3.capture3("plantuml -pipe -tsvg", stdin_data: plantuml);
         | 
| 317 343 | 
             
                      result, err1, _s = Open3.capture3("plantuml -pipe -tutxt", stdin_data: plantuml) if t == "plantuml-utxt"
         | 
| 318 | 
            -
                      err << err1
         | 
| 344 | 
            +
                      err << err1.to_s
         | 
| 319 345 | 
             
                    when "math"
         | 
| 320 346 | 
             
                      result1, err, _s = Open3.capture3("tex2svg --font STIX --speech=false #{Shellwords.escape(' ' << result)}");
         | 
| 321 347 | 
             
                      result, err1, _s = Open3.capture3("asciitex -f #{file.path}")
         | 
| @@ -328,6 +354,10 @@ COLORS | |
| 328 354 | 
             
                    result1, err, _s = Open3.capture3("svgcheck -qa", stdin_data: result1);
         | 
| 329 355 | 
             
                    capture_croak("svgcheck", err)
         | 
| 330 356 | 
             
                    # warn ["svgcheck:", result1.inspect]
         | 
| 357 | 
            +
                    if result1 == ''
         | 
| 358 | 
            +
                      warn "*** could not create svg for #{result.inspect[0...20]}..."
         | 
| 359 | 
            +
                      exit 65 # EX_DATAERR
         | 
| 360 | 
            +
                    end
         | 
| 331 361 | 
             
                    [result, result1]       # text, svg
         | 
| 332 362 | 
             
                  end
         | 
| 333 363 |  | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: kramdown-rfc2629
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 1.3. | 
| 4 | 
            +
              version: 1.3.28
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Carsten Bormann
         | 
| 8 8 | 
             
            autorequire:
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date:  | 
| 11 | 
            +
            date: 2021-02-05 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: kramdown
         | 
| @@ -39,7 +39,7 @@ dependencies: | |
| 39 39 | 
             
                  - !ruby/object:Gem::Version
         | 
| 40 40 | 
             
                    version: '1.0'
         | 
| 41 41 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 42 | 
            -
              name:  | 
| 42 | 
            +
              name: json_pure
         | 
| 43 43 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| 44 44 | 
             
                requirements:
         | 
| 45 45 | 
             
                - - "~>"
         | 
| @@ -74,6 +74,7 @@ files: | |
| 74 74 | 
             
            - data/kramdown-rfc2629.erb
         | 
| 75 75 | 
             
            - data/math.json
         | 
| 76 76 | 
             
            - kramdown-rfc2629.gemspec
         | 
| 77 | 
            +
            - lib/kramdown-rfc/erb.rb
         | 
| 77 78 | 
             
            - lib/kramdown-rfc/gzip-clone.rb
         | 
| 78 79 | 
             
            - lib/kramdown-rfc/parameterset.rb
         | 
| 79 80 | 
             
            - lib/kramdown-rfc/refxml.rb
         | 
| @@ -97,7 +98,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement | |
| 97 98 | 
             
                - !ruby/object:Gem::Version
         | 
| 98 99 | 
             
                  version: '0'
         | 
| 99 100 | 
             
            requirements: []
         | 
| 100 | 
            -
            rubygems_version: 3. | 
| 101 | 
            +
            rubygems_version: 3.2.3
         | 
| 101 102 | 
             
            signing_key:
         | 
| 102 103 | 
             
            specification_version: 4
         | 
| 103 104 | 
             
            summary: Kramdown extension for generating RFC 7749 XML.
         |