git@vger.kernel.org list mirror (unofficial, one of many)
 help / color / mirror / code / Atom feed
2ed92c30552d149251e2569294dd7afee294207f blob 3161 bytes (raw)

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
 
require 'asciidoctor'
require 'asciidoctor/extensions'
require 'asciidoctor/converter/manpage'

module Asciidoctor
  class Converter::ManPageConverter
    alias orig_convert_inline_anchor convert_inline_anchor
    def convert_inline_anchor(node)
      case node.type
      when :xref
        return node.text if node.text
        refid = node.attributes['refid']
        'the section called “%s”' % refid.gsub('_', ' ')
      when :link
        return node.target if node.text == node.target
        doc = node.document

        footnote = doc.footnotes.find { |e| e.id == node.target }
        if !footnote
          target = node.target
          target = doc.attributes['baseurl'] + target unless target.include? ':'
          footnote_text = "%s\n\e.RS\n\e\\%%%s\n\e.RE" % [node.text, target]
          index = doc.counter('footnote-number')
          footnote = Document::Footnote.new(index, node.target, footnote_text)
          doc.register(:footnotes, footnote)
        end

        "\e\\fB%s\e\\fR[%d]" % [node.text, footnote.index]
      else
        orig_convert_inline_anchor(node)
      end
    end
  end
end

module Git
  module Documentation
    class LinkGitProcessor < Asciidoctor::Extensions::InlineMacroProcessor
      use_dsl

      named :chrome

      def process(parent, target, attrs)
        prefix = parent.document.attr('git-relative-html-prefix')
        if parent.document.doctype == 'book'
          "<ulink url=\"#{prefix}#{target}.html\">" \
          "#{target}(#{attrs[1]})</ulink>"
        elsif parent.document.basebackend? 'html'
          %(<a href="#{prefix}#{target}.html">#{target}(#{attrs[1]})</a>)
        elsif parent.document.basebackend? 'manpage'
          "\e\\fB%s\e\\fR(%s)" % [target, attrs[1]]
        elsif parent.document.basebackend? 'docbook'
          "<citerefentry>\n" \
            "<refentrytitle>#{target}</refentrytitle>" \
            "<manvolnum>#{attrs[1]}</manvolnum>\n" \
          "</citerefentry>"
        end
      end
    end

    class DocumentPostProcessor < Asciidoctor::Extensions::Postprocessor
      def process document, output
        if document.basebackend? 'docbook'
          mansource = document.attributes['mansource']
          manversion = document.attributes['manversion']
          manmanual = document.attributes['manmanual']
          new_tags = "" \
            "<refmiscinfo class=\"source\">#{mansource}</refmiscinfo>\n" \
            "<refmiscinfo class=\"version\">#{manversion}</refmiscinfo>\n" \
            "<refmiscinfo class=\"manual\">#{manmanual}</refmiscinfo>\n"
          output = output.sub(/<\/refmeta>/, new_tags + "</refmeta>")
        end
        output
      end
    end
  end
end

Asciidoctor::Extensions.register do
  # Override attributes for man pages.
  # https://github.com/asciidoctor/asciidoctor/issues/4059
  tree_processor do
    process do |document|
      if document.backend == 'manpage'
        document.attributes.merge!({ 'litdd' => '\--', 'plus' => '+' })
      end
      document
    end
  end

  inline_macro Git::Documentation::LinkGitProcessor, :linkgit
  postprocessor Git::Documentation::DocumentPostProcessor
end
debug log:

solving 2ed92c3055 ...
found 2ed92c3055 in https://public-inbox.org/git/20210514121435.504423-11-felipe.contreras@gmail.com/
found 42133ee6c3 in https://public-inbox.org/git/20210514121435.504423-10-felipe.contreras@gmail.com/
found b2bbb318ad in https://public-inbox.org/git/20210514121435.504423-9-felipe.contreras@gmail.com/
found 11937c2c1d in https://public-inbox.org/git/20210514121435.504423-8-felipe.contreras@gmail.com/
found ad68f7b0bb in https://public-inbox.org/git/20210514121435.504423-6-felipe.contreras@gmail.com/
found d906a00803 in git.git.git
preparing index
index prepared:
100644 d906a008039cf56c757ddb6bff9f0e1d9d7bfdc9	Documentation/asciidoctor-extensions.rb

applying [1/5] https://public-inbox.org/git/20210514121435.504423-6-felipe.contreras@gmail.com/
diff --git a/Documentation/asciidoctor-extensions.rb b/Documentation/asciidoctor-extensions.rb
index d906a00803..ad68f7b0bb 100644


applying [2/5] https://public-inbox.org/git/20210514121435.504423-8-felipe.contreras@gmail.com/
diff --git a/Documentation/asciidoctor-extensions.rb b/Documentation/asciidoctor-extensions.rb
index ad68f7b0bb..11937c2c1d 100644


applying [3/5] https://public-inbox.org/git/20210514121435.504423-9-felipe.contreras@gmail.com/
diff --git a/Documentation/asciidoctor-extensions.rb b/Documentation/asciidoctor-extensions.rb
index 11937c2c1d..b2bbb318ad 100644


applying [4/5] https://public-inbox.org/git/20210514121435.504423-10-felipe.contreras@gmail.com/
diff --git a/Documentation/asciidoctor-extensions.rb b/Documentation/asciidoctor-extensions.rb
index b2bbb318ad..42133ee6c3 100644


applying [5/5] https://public-inbox.org/git/20210514121435.504423-11-felipe.contreras@gmail.com/
diff --git a/Documentation/asciidoctor-extensions.rb b/Documentation/asciidoctor-extensions.rb
index 42133ee6c3..2ed92c3055 100644

Checking patch Documentation/asciidoctor-extensions.rb...
Applied patch Documentation/asciidoctor-extensions.rb cleanly.
Checking patch Documentation/asciidoctor-extensions.rb...
Applied patch Documentation/asciidoctor-extensions.rb cleanly.
Checking patch Documentation/asciidoctor-extensions.rb...
Applied patch Documentation/asciidoctor-extensions.rb cleanly.
Checking patch Documentation/asciidoctor-extensions.rb...
Applied patch Documentation/asciidoctor-extensions.rb cleanly.
Checking patch Documentation/asciidoctor-extensions.rb...
Applied patch Documentation/asciidoctor-extensions.rb cleanly.

index at:
100644 2ed92c30552d149251e2569294dd7afee294207f	Documentation/asciidoctor-extensions.rb

git@vger.kernel.org list mirror (unofficial, one of many)

This inbox may be cloned and mirrored by anyone:

	git clone --mirror https://public-inbox.org/git
	git clone --mirror http://ou63pmih66umazou.onion/git
	git clone --mirror http://czquwvybam4bgbro.onion/git
	git clone --mirror http://hjrcffqmbrq6wope.onion/git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V1 git git/ https://public-inbox.org/git \
		git@vger.kernel.org
	public-inbox-index git

Example config snippet for mirrors.
Newsgroups are available over NNTP:
	nntp://news.public-inbox.org/inbox.comp.version-control.git
	nntp://7fh6tueqddpjyxjmgtdiueylzoqt6pt7hec3pukyptlmohoowvhde4yd.onion/inbox.comp.version-control.git
	nntp://ie5yzdi7fg72h7s4sdcztq5evakq23rdt33mfyfcddc5u3ndnw24ogqd.onion/inbox.comp.version-control.git
	nntp://4uok3hntl7oi7b4uf4rtfwefqeexfzil2w6kgk2jn5z2f764irre7byd.onion/inbox.comp.version-control.git
	nntp://news.gmane.io/gmane.comp.version-control.git
 note: .onion URLs require Tor: https://www.torproject.org/

code repositories for project(s) associated with this inbox:

	https://80x24.org/mirrors/git.git

AGPL code for this site: git clone https://public-inbox.org/public-inbox.git