blob: e09d62a5e875dd64eb6ec0d9fe5d32895b98846e [file] [log] [blame]
Lennart Poettering9c4fa6e2012-07-16 17:19:39 +02001#!/usr/bin/env python
2
3from xml.etree.ElementTree import parse, Element, SubElement, tostring
Lennart Poettering88641112012-07-16 17:39:26 +02004from sys import argv, stdout
Lennart Poettering9c4fa6e2012-07-16 17:19:39 +02005
6index = {}
7
Lennart Poettering88641112012-07-16 17:39:26 +02008for p in argv[1:]:
Lennart Poettering9c4fa6e2012-07-16 17:19:39 +02009 t = parse(p)
Lennart Poettering88641112012-07-16 17:39:26 +020010 section = t.find('./refmeta/manvolnum').text
11 purpose = t.find('./refnamediv/refpurpose').text
Lennart Poettering9c4fa6e2012-07-16 17:19:39 +020012 for f in t.findall('./refnamediv/refname'):
Lennart Poettering88641112012-07-16 17:39:26 +020013 index[f.text] = (p, section, purpose)
Lennart Poettering9c4fa6e2012-07-16 17:19:39 +020014
15html = Element('html')
16
17head = SubElement(html, 'head')
18title = SubElement(head, 'title')
19title.text = 'Manual Page Index'
20
21body = SubElement(html, 'body')
22h1 = SubElement(body, 'h1')
23h1.text = 'Manual Page Index'
24
25letter = None
Lennart Poettering88641112012-07-16 17:39:26 +020026for n in sorted(index.keys(), key = str.lower):
27 path, section, purpose = index[n]
Lennart Poettering9c4fa6e2012-07-16 17:19:39 +020028
29 if path.endswith('.xml'):
30 path = path[:-4] + ".html"
31
32 c = path.rfind('/')
33 if c >= 0:
34 path = path[c+1:]
35
36 if letter is None or n[0].upper() != letter:
37 letter = n[0].upper()
38
39 h2 = SubElement(body, 'h1')
40 h2.text = letter
41
42 ul = SubElement(body, 'ul')
43 ul.set('style', 'list-style-type:none')
44
45 li = SubElement(ul, 'li');
46
47 a = SubElement(li, 'a');
48 a.set('href', path)
49 a.text = n + '(' + section + ')'
Lennart Poettering88641112012-07-16 17:39:26 +020050 a.tail = ' -- ' + purpose
Lennart Poettering9c4fa6e2012-07-16 17:19:39 +020051
Lennart Poettering88641112012-07-16 17:39:26 +020052stdout.write(tostring(html))