]> git.ipfire.org Git - thirdparty/systemd.git/blame - tools/update-man-rules.py
Merge pull request #16497 from DaanDeMeyer/mkosi
[thirdparty/systemd.git] / tools / update-man-rules.py
CommitLineData
3e67e5c9 1#!/usr/bin/env python3
d8a0bcfd 2# SPDX-License-Identifier: LGPL-2.1+
56ba3c78
ZJS
3
4from __future__ import print_function
56ba3c78
ZJS
5import collections
6import sys
e2bb4105 7import pprint
a2095c06 8from os.path import basename
1c6c3ef0 9from xml_helper import xml_parse
56ba3c78 10
56ba3c78 11def man(page, number):
0689f766 12 return '{}.{}'.format(page, number)
56ba3c78
ZJS
13
14def add_rules(rules, name):
1a13e31d 15 xml = xml_parse(name)
56ba3c78 16 # print('parsing {}'.format(name), file=sys.stderr)
c0652d45
ZJS
17 if xml.getroot().tag != 'refentry':
18 return
56ba3c78
ZJS
19 conditional = xml.getroot().get('conditional') or ''
20 rulegroup = rules[conditional]
21 refmeta = xml.find('./refmeta')
22 title = refmeta.find('./refentrytitle').text
23 number = refmeta.find('./manvolnum').text
24 refnames = xml.findall('./refnamediv/refname')
25 target = man(refnames[0].text, number)
26 if title != refnames[0].text:
27 raise ValueError('refmeta and refnamediv disagree: ' + name)
28 for refname in refnames:
29 assert all(refname not in group
30 for group in rules.values()), "duplicate page name"
31 alias = man(refname.text, number)
32 rulegroup[alias] = target
33 # print('{} => {} [{}]'.format(alias, target, conditional), file=sys.stderr)
34
40be878a 35def create_rules(xml_files):
56ba3c78
ZJS
36 " {conditional => {alias-name => source-name}} "
37 rules = collections.defaultdict(dict)
38 for name in xml_files:
c0652d45
ZJS
39 try:
40 add_rules(rules, name)
41 except Exception:
42 print("Failed to process", name, file=sys.stderr)
43 raise
56ba3c78
ZJS
44 return rules
45
46def mjoin(files):
47 return ' \\\n\t'.join(sorted(files) or '#')
48
e2bb4105 49MESON_HEADER = '''\
06689b8d 50# Do not edit. Generated by update-man-rules.py.
34d2f920
ZJS
51# Update with:
52# ninja -C build man/update-man-rules
e2bb4105
ZJS
53manpages = ['''
54
55MESON_FOOTER = '''\
56]
57# Really, do not edit.'''
58
59def make_mesonfile(rules, dist_files):
60 # reformat rules as
61 # grouped = [ [name, section, [alias...], condition], ...]
62 #
63 # but first create a dictionary like
64 # lists = { (name, condition) => [alias...]
65 grouped = collections.defaultdict(list)
66 for condition, items in rules.items():
67 for alias, name in items.items():
68 group = grouped[(name, condition)]
69 if name != alias:
70 group.append(alias)
71
72 lines = [ [p[0][:-2], p[0][-1], sorted(a[:-2] for a in aliases), p[1]]
73 for p, aliases in sorted(grouped.items()) ]
74 return '\n'.join((MESON_HEADER, pprint.pformat(lines)[1:-1], MESON_FOOTER))
75
56ba3c78 76if __name__ == '__main__':
0689f766 77 pages = sys.argv[1:]
a2095c06
ZJS
78 pages = (p for p in pages
79 if basename(p) not in {
80 'systemd.directives.xml',
81 'systemd.index.xml',
82 'directives-template.xml'})
e2bb4105
ZJS
83
84 rules = create_rules(pages)
a2095c06 85 dist_files = (basename(p) for p in pages)
0689f766 86 print(make_mesonfile(rules, dist_files))