summaryrefslogtreecommitdiff
path: root/misc/kwcheck.py
blob: 713167a830164ccca62c062da7d4668a476d9d1e (plain)
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
#! /usr/bin/env python

import sys
import re

import pkgloader
pkgloader.require('skytools', '3.0')
import skytools.quoting

kwmap = skytools.quoting._ident_kwmap

fn = "/opt/src/pgsql/postgresql/src/include/parser/kwlist.h"
if len(sys.argv) == 2:
    fn = sys.argv[1]

rc = re.compile(r'PG_KEYWORD[(]"(.*)" , \s* \w+ , \s* (\w+) [)]', re.X)

data = open(fn, 'r').read()
full_map = {}
cur_map = {}
print "== new =="
for kw, cat in rc.findall(data):
    full_map[kw] = 1
    if cat == 'UNRESERVED_KEYWORD':
        continue
    if cat == 'COL_NAME_KEYWORD':
        continue
    cur_map[kw] = 1
    if kw not in kwmap:
        print kw, cat
    kwmap[kw] = 1

print "== obsolete =="
kws = kwmap.keys()
kws.sort()
for k in kws:
    if k not in full_map:
        print k, '(not in full_map)'
    elif k not in cur_map:
        print k, '(not in cur_map)'

print "== full list =="
ln = ""
for k in kws:
    ln += '"%s":1, ' % k
    if len(ln) > 70:
        print ln.strip()
        ln = ""
print ln.strip()