annotate it/web/genindex.py @ 776:c0794abb494e
Unicode fiddling.
author |
Giulio@puck |
date |
Tue Aug 04 18:57:58 2009 +0200 (2009-08-04) |
parents |
23ebfe2bd091 |
children |
52ed51334e01 |
rev |
line source |
Giulio@747
|
1 # This script works with Python 3.0 or above
|
Giulio@722
|
2
|
Giulio@722
|
3 import glob, os, re
|
Giulio@722
|
4
|
Giulio@722
|
5 chapter_re = re.compile(r'<(chapter|appendix|preface)\s+id="([^"]+)">')
|
Giulio@722
|
6 filename_re = re.compile(r'<\?dbhtml filename="([^"]+)"\?>')
|
Giulio@722
|
7 title_re = re.compile(r'<title>(.*)</title>')
|
Giulio@722
|
8
|
Giulio@722
|
9 chapters = (sorted(glob.glob('../ch*.xml')) +
|
Giulio@722
|
10 sorted(glob.glob('../app*.xml')))
|
Giulio@722
|
11
|
Giulio@776
|
12 fp = open('index-read.html.in', 'w', encoding='utf-8')
|
Giulio@722
|
13
|
Giulio@722
|
14 print('''
|
Giulio@722
|
15 <div class="navheader"><h1 class="booktitle">Mercurial: la guida definitiva<div class="authors">di Bryan O'Sullivan</div></h1></div>
|
Giulio@722
|
16 <div class="book"><ul class="booktoc">''', file=fp)
|
Giulio@722
|
17
|
Giulio@722
|
18 ch = 0
|
Giulio@722
|
19 app = 0
|
Giulio@722
|
20 ab = 0
|
Giulio@722
|
21 for c in chapters:
|
Giulio@722
|
22 filename = None
|
Giulio@722
|
23 title = None
|
Giulio@722
|
24 chapid = None
|
Giulio@722
|
25 chaptype = None
|
Giulio@776
|
26 for line in open(c, encoding='utf-8'):
|
Giulio@722
|
27 m = chapter_re.search(line)
|
Giulio@722
|
28 if m:
|
Giulio@722
|
29 chaptype, chapid = m.groups()
|
Giulio@722
|
30 m = filename_re.search(line)
|
Giulio@722
|
31 if m:
|
Giulio@722
|
32 filename = m.group(1)
|
Giulio@722
|
33 m = title_re.search(line)
|
Giulio@722
|
34 if m:
|
Giulio@722
|
35 title = m.group(1)
|
Giulio@722
|
36 if filename and title and chapid:
|
Giulio@722
|
37 if chaptype == 'appendix':
|
Giulio@722
|
38 num = chr(ord('A') + app)
|
Giulio@722
|
39 app += 1
|
Giulio@722
|
40 else:
|
Giulio@722
|
41 num = ch
|
Giulio@722
|
42 ch += 1
|
Giulio@722
|
43 ab += 1
|
Giulio@722
|
44 date = os.popen('hg log -l1 --template "{date|isodate}" ' + c).read().split(None, 1)[0]
|
Giulio@722
|
45 args = {
|
Giulio@722
|
46 'ab': "ab"[ab % 2],
|
Giulio@722
|
47 'date': date,
|
Giulio@722
|
48 'chapid': chapid,
|
Giulio@722
|
49 'num': num,
|
Giulio@722
|
50 'filename': filename,
|
Giulio@722
|
51 'title': title,
|
Giulio@722
|
52 }
|
Giulio@722
|
53 print('<li class="zebra_%(ab)s"><span class="chapinfo">%(date)s<a href="/feeds/comments/%(chapid)s/"><img src="figs/rss.png"/></a></span>%(num)s. <a href="%(filename)s">%(title)s</a></li>' % args, file=fp)
|
Giulio@722
|
54 break
|
Giulio@722
|
55
|
Giulio@722
|
56 print('</ul></div>', file=fp)
|
Giulio@722
|
57
|
Giulio@722
|
58 fp.close()
|