annotate contrib/check-params-in-docs.py @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
131
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
1 #!/usr/bin/env python3
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
2 #
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
3 # Find missing and extra parameters in documentation compared to
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
4 # output of: gcc --help=params.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
5 #
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
6 # This file is part of GCC.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
7 #
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
8 # GCC is free software; you can redistribute it and/or modify it under
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
9 # the terms of the GNU General Public License as published by the Free
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
10 # Software Foundation; either version 3, or (at your option) any later
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
11 # version.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
12 #
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
13 # GCC is distributed in the hope that it will be useful, but WITHOUT ANY
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
14 # WARRANTY; without even the implied warranty of MERCHANTABILITY or
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
15 # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
16 # for more details.
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
17 #
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
18 # You should have received a copy of the GNU General Public License
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
19 # along with GCC; see the file COPYING3. If not see
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
20 # <http://www.gnu.org/licenses/>. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
21 #
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
22 #
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
23 #
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
24
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
25 import sys
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
26 import json
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
27 import argparse
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
28
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
29 from itertools import *
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
30
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
31 def get_param_tuple(line):
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
32 line = line.strip()
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
33 i = line.find(' ')
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
34 return (line[:i], line[i:].strip())
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
35
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
36 parser = argparse.ArgumentParser()
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
37 parser.add_argument('texi_file')
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
38 parser.add_argument('params_output')
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
39
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
40 args = parser.parse_args()
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
41
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
42 ignored = set(['logical-op-non-short-circuit'])
131
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
43 params = {}
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
44
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
45 for line in open(args.params_output).readlines():
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
46 if line.startswith(' '):
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
47 r = get_param_tuple(line)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
48 params[r[0]] = r[1]
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
49
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
50 # Find section in .texi manual with parameters
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
51 texi = ([x.strip() for x in open(args.texi_file).readlines()])
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
52 texi = dropwhile(lambda x: not 'item --param' in x, texi)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
53 texi = takewhile(lambda x: not '@node Instrumentation Options' in x, texi)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
54 texi = list(texi)[1:]
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
55
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
56 token = '@item '
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
57 texi = [x[len(token):] for x in texi if x.startswith(token)]
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
58 sorted_texi = sorted(texi)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
59
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
60 texi_set = set(texi) - ignored
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
61 params_set = set(params.keys()) - ignored
131
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
62
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
63 extra = texi_set - params_set
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
64 if len(extra):
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
65 print('Extra:')
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
66 print(extra)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
67
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
68 missing = params_set - texi_set
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
69 if len(missing):
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
70 print('Missing:')
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
71 for m in missing:
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
72 print('@item ' + m)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
73 print(params[m])
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
74 print()
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
75
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
76 if texi != sorted_texi:
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
77 print('WARNING: not sorted alphabetically!')