| #! /usr/bin/env python |
| """Generate C code for the jump table of the threaded code interpreter |
| (for compilers supporting computed gotos or "labels-as-values", such as gcc). |
| """ |
| |
| # This code should stay compatible with Python 2.3, at least while |
| # some of the buildbots have Python 2.3 as their system Python. |
| |
| import imp |
| import os |
| |
| |
| def find_module(modname): |
| """Finds and returns a module in the local dist/checkout. |
| """ |
| modpath = os.path.join( |
| os.path.dirname(os.path.dirname(__file__)), "Lib") |
| return imp.load_module(modname, *imp.find_module(modname, [modpath])) |
| |
| def write_contents(f): |
| """Write C code contents to the target file object. |
| """ |
| opcode = find_module("opcode") |
| targets = ['_unknown_opcode'] * 256 |
| for opname, op in opcode.opmap.items(): |
| if opname == "STOP_CODE": |
| # XXX opcode not implemented |
| continue |
| targets[op] = "TARGET_%s" % opname |
| f.write("static void *opcode_targets[256] = {\n") |
| f.write(",\n".join(["\t&&%s" % s for s in targets])) |
| f.write("\n};\n") |
| |
| |
| if __name__ == "__main__": |
| import sys |
| assert len(sys.argv) < 3, "Too many arguments" |
| if len(sys.argv) == 2: |
| target = sys.argv[1] |
| else: |
| target = "Python/opcode_targets.h" |
| f = open(target, "w") |
| try: |
| write_contents(f) |
| finally: |
| f.close() |