forked from p12tic/cppreference-doc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
index2autolinker.py
executable file
·77 lines (61 loc) · 2.3 KB
/
index2autolinker.py
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
#!/usr/bin/env python3
'''
Copyright (C) 2013 Povilas Kanapickas <[email protected]>
This file is part of cppreference-doc
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see http://www.gnu.org/licenses/.
'''
''' This script produces a definition file for AutoLinker extension
The definitions are written in JSON in the following format:
{
"groups" : [
{
name : "string",
OPTIONAL base_url : "string", END
urls : [ "url", "url", ... ],
},
...
],
"links" : [
{
string : "string",
EITHER on_group : "name" OR on_page : "url" END
target : "url",
},
...
],
}
'''
import argparse
import json
from index_transform.autolinker import *
def main():
parser = argparse.ArgumentParser(prog='index2autolinker')
parser.add_argument('index', type=str,
help='Path to index file to process')
parser.add_argument('destination', type=str,
help='Path to destination file to store results to')
args = parser.parse_args()
out_f = open(args.destination, 'w', encoding='utf-8')
tr = Index2AutolinkerGroups()
tr.transform_file(args.index)
groups = tr.groups
tr = Index2AutolinkerLinks()
tr.transform_file(args.index)
links = tr.links
json_groups = [ v for v in groups.values() ]
json_groups = sorted(json_groups, key=lambda x: x['name'])
links = sorted(links, key=lambda x: x['target'])
out_f.write(json.dumps({ 'groups' : json_groups, 'links' : links}, indent=None,
separators=(',\n', ': '), sort_keys=True))
out_f.close()
if __name__ == '__main__':
main()