#! /usr/bin/python3 import sys import re from geo import Geo show_triangles = False show_scales = False do_dump = False def listGeo(fn, fh): geo = Geo() geo.loadFromFile(fh) for m in geo.models: if do_dump and m.name.decode("utf-8") != dump_name: continue if do_dump: m.dump() return s = "%s : %s" % (geo.header_modelheader_name.decode("utf-8"), m.name.decode("utf-8")) if show_triangles: s += " : %d" % (m.tris and len(m.tris) or 0, ) if show_scales: s += " : %f, %f, %f" % tuple(m.scale) print(s) def parseOption(opt): global show_triangles global show_scales global do_dump for c in opt[1:]: if c == "t": show_triangles = True elif c == "s": show_scales = True elif c == "d": do_dump = True if len(sys.argv) <= 1: print("Usage:") print(" %s [] " % (sys.argv[0], )) print("Options:") print(" -t Display triangle count.") print(" -s Display model scale.") print(" -d Dump model.") exit() dump_name = "" for i in range(1, len(sys.argv)): if do_dump and not dump_name: dump_name = sys.argv[i] continue if sys.argv[i].startswith("-"): parseOption(sys.argv[i]) continue try: fn = sys.argv[i] fh = open(fn, "rb") except: print("Couldn't open '%s'." % (sys.argv[i], )) continue listGeo(fn, fh)