unofficial mirror of notmuch@notmuchmail.org
 help / color / mirror / code / Atom feed
blob 968722a1c750c620e24e1d5869269930bd3e5b96 1439 bytes (raw)
name: doc/prerst2man.py 	 # note: path name is non-authoritative(*)

 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
 
from sys import argv
from datetime import date
from os.path import dirname, isdir
from os import makedirs, system
import re

sourcedir = argv[1]
outdir = argv[2]

if not isdir(outdir):
    makedirs(outdir, 0o755)

with open(sourcedir + "/conf.py") as cf:
    exec(cf.read())


def header(file, startdocname, command, description, authors, section):
    file.write("""
{0:s}
{1:s}
{2:s}

:Date:   {3:s}
:Version: {4:s}
:Manual section: {5:d}
:Manual group: {6:s}

""".format(
'-' * len(description),
description,
'-' * len(description),
date.today().isoformat(), release, section, project))

blankre = re.compile("^\s*$")
for page in man_pages:
    outdirname = outdir + '/' + dirname(page[0])
    if not isdir(outdirname):
        makedirs(outdirname, 0o755)
    filename = outdir + '/' + page[0] + '.rst'
    outfile = open(filename, 'w')
    infile = open(sourcedir + '/' + page[0] + '.rst', 'r')

    # this is a crude hack. We look for the first blank line, and
    # insert the rst2man header there.
    #
    # XXX consider really parsing input

    count = 0
    lines = infile.readlines()
    for line in lines:
        outfile.write(line)
        if (blankre.match(line)):
            break
        count = count + 1

    del lines[0:count + 1]

    header(outfile, *page)

    outfile.write("".join(lines))
    outfile.close()

    system('set -x; rst2man {0} {1}/{2}.{3}'
           .format(filename, outdir, page[0], page[4]))

debug log:

solving 968722a ...
found 968722a in https://yhetil.org/notmuch.git/

(*) Git path names are given by the tree(s) the blob belongs to.
    Blobs themselves have no identifier aside from the hash of its contents.^

Code repositories for project(s) associated with this public inbox

	https://yhetil.org/notmuch.git/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).