mirror of
				https://github.com/python/cpython.git
				synced 2025-10-22 17:33:55 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable file
		
	
	
	
	
| #! /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()
 | 
