from __future__ import print_function
from __future__ import absolute_import
import os
import sys
sys.path.append(os.path.join(os.path.dirname(__file__), '..'))
from sumolib.output import parse, parse_fast
from sumolib.options import ArgumentParser
def parse_args():
ap = ArgumentParser()
ap.add_option("routefiles", nargs="+", category="input", type=ap.file_list, help="route files")
ap.add_option("-o", "--outfile", category="output", type=ap.file, help="name of output file")
options = ap.parse_args()
if options.outfile is None:
options.outfile = options.routefiles[0] + ".sel.txt"
return options
def main():
options = parse_args()
edges = set()
for routefile in options.routefiles:
for route in parse_fast(routefile, 'route', ['edges']):
edges.update(route.edges.split())
for walk in parse_fast(routefile, 'walk', ['edges']):
edges.update(walk.edges.split())
for trip in parse(routefile, ['trip', 'flow'], heterogeneous=True):
for attr in ['attr_from', 'to', 'via']:
if trip.attr_from:
edges.update(trip.attr_from)
if trip.to:
edges.update(trip.to)
if trip.via:
edges.update(trip.via.split())
for walk in parse_fast(routefile, 'walk', ['from', 'to']):
edges.update([walk.attr_from, walk.to])
with open(options.outfile, 'w') as outf:
for e in sorted(list(edges)):
outf.write('edge:%s\n' % e)
if __name__ == "__main__":
main()