Project

General

Profile

1
#!/usr/bin/env python
2
# Transforms a map spreadsheet to use a different root
3

    
4
import csv
5
import os.path
6
import re
7
import sys
8

    
9
sys.path.append(os.path.dirname(__file__)+"/../lib")
10

    
11
import maps
12
import opts
13

    
14
def main():
15
    # Get config from env vars
16
    env_names = []
17
    print_usage_ref = [False]
18
    def on_unset(e): print_usage_ref[0] = True
19
    configs = [opts.get_env_vars(['in_root', 'out_root'], col, env_names,
20
        on_unset) for col in ['left', 'right']]
21
    if print_usage_ref[0]: raise SystemExit(
22
        'Usage: '+opts.env_usage(env_names)+' '+sys.argv[0]+' <in_map >out_map')
23
    
24
    # Transform map
25
    reader = csv.reader(sys.stdin)
26
    writer = csv.writer(sys.stdout)
27
    cols = reader.next()
28
    for i in xrange(len(configs)):
29
        config = configs[i]
30
        cols[i], config['root'] = maps.col_info(cols[i])[:2]
31
        
32
        if config['root'] != None: cols[i] += ':'+config['out_root']
33
        else:
34
            assert config['out_root'] == ''
35
            config['root'] = ''
36
        
37
        config['in_root_re'] = r'^'+re.escape(config['in_root'])+r'(?=\b|\W|$)'
38
    writer.writerow(cols)
39
    for row in reader:
40
        def sub(i):
41
            row[i], n = re.subn(configs[i]['in_root_re'], r'',
42
                configs[i]['root']+row[i])
43
            return n > 0
44
        if row[0] != '' and sub(0) and (row[1] == '' or sub(1)):
45
            writer.writerow(row)
46

    
47
main()
(2-2/53)