Welcome to mirror list, hosted at ThFree Co, Russian Federation.

recalculate_geom_index.py « python « tools - github.com/mapsme/omim.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 0eb9f5c33ea0dba5130a52da00045e91e96afed0 (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
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
"""
recalculate_geom_index.py <data_path> <generator_tool> [<designer_tool> <designer_param>]

Calculates geometry index for all mwms found inside the resource and the writable directories.
Uses generator_tool for index calculation. After all it runs designer_tool if has one.
"""

import os
import subprocess
import sys
from Queue import Queue, Empty
from threading import Thread

WORKERS = 8

exclude_names = ("WorldCoasts.mwm", "WorldCoasts_migrate.mwm")

def FindAllMwms(data_path):
    result = []
    for file in os.listdir(data_path):
        new_path = os.path.join(data_path, file)
        if os.path.isdir(new_path):
            result.extend(FindAllMwms(new_path))
            continue
        if file.endswith(".mwm") and file not in exclude_names:
            result.append((file, data_path))
    return result

def ProcessMwm(generator_tool, task, error_queue):
    print "Processing ", task[0]
    try:
        subprocess.call((generator_tool, '--data_path={0}'.format(task[1]), '--output={0}'.format(task[0][:-4]), "--generate_index=true", "--intermediate_data_path=/tmp/"))
    except subprocess.CalledProcessError as e:
        error_queue.put(str(error_queue))

def parallel_worker(tasks, generator_tool, error_queue):
    while True:
        try:
            task = tasks.get_nowait()
        except Empty:
            print "Process done!"
            return
        ProcessMwm(generator_tool, task, error_queue)
        tasks.task_done()

if __name__ == "__main__":

    if len(sys.argv) < 3:
        print "{0} <resources_dir> <writable_dir> <generator_tool> [<designer_tool> <designer_params>]".format(sys.argv[0])
        exit(1)

    mwms = FindAllMwms(sys.argv[1])
    if sys.argv[2] != sys.argv[1]:
        mwms.extend(FindAllMwms(sys.argv[2]))
    tasks = Queue()
    error_queue = Queue()
    for task in mwms:
        tasks.put(task)

    for i in range(WORKERS):
        t=Thread(target=parallel_worker, args=(tasks, sys.argv[3], error_queue))
        t.daemon = True
        t.start()

    tasks.join()
    print "Processing done."

    if len(sys.argv) > 4:
        print "Starting app"
        subprocess.Popen(sys.argv[4:])

    if not error_queue.qsize() == 0:
        while error_queue.qsize():
            error = error_queue.get()
            print error
        exit(1)