diff options
author | Irit Katriel <1055913+iritkatriel@users.noreply.github.com> | 2023-08-01 20:05:48 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-08-01 20:05:48 (GMT) |
commit | 2bd04d423404e5ea862c858f62af76feade4d831 (patch) | |
tree | f60ed68a6779a6bb8119d7351ee2cc1ba5c0eca3 /Python | |
parent | 6ef8f8ca88b925685c6af83a9f0a899e565e1e33 (diff) | |
download | cpython-2bd04d423404e5ea862c858f62af76feade4d831.zip cpython-2bd04d423404e5ea862c858f62af76feade4d831.tar.gz cpython-2bd04d423404e5ea862c858f62af76feade4d831.tar.bz2 |
gh-105481: combine regen-opcode-targets with regen-opcode to avoid calculating the specialized opcodes in two places (#107540)
Diffstat (limited to 'Python')
-rwxr-xr-x | Python/makeopcodetargets.py | 56 |
1 files changed, 0 insertions, 56 deletions
diff --git a/Python/makeopcodetargets.py b/Python/makeopcodetargets.py deleted file mode 100755 index 5843079..0000000 --- a/Python/makeopcodetargets.py +++ /dev/null @@ -1,56 +0,0 @@ -#! /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). -""" - -import os -import sys - - -# 2023-04-27(warsaw): Pre-Python 3.12, this would catch ImportErrors and try to -# import imp, and then use imp.load_module(). The imp module was removed in -# Python 3.12 (and long deprecated before that), and it's unclear under what -# conditions this import will now fail, so the fallback was simply removed. -from importlib.machinery import SourceFileLoader - -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", modname + ".py") - return SourceFileLoader(modname, modpath).load_module() - - -def write_contents(f): - """Write C code contents to the target file object. - """ - opcode = find_module('opcode') - _opcode_metadata = find_module('_opcode_metadata') - targets = ['_unknown_opcode'] * 256 - for opname, op in opcode.opmap.items(): - if not opcode.is_pseudo(op): - targets[op] = "TARGET_%s" % opname - next_op = 1 - for opname in _opcode_metadata._specialized_instructions: - while targets[next_op] != '_unknown_opcode': - next_op += 1 - targets[next_op] = "TARGET_%s" % opname - f.write("static void *opcode_targets[256] = {\n") - f.write(",\n".join([" &&%s" % s for s in targets])) - f.write("\n};\n") - - -def main(): - if len(sys.argv) >= 3: - sys.exit("Too many arguments") - if len(sys.argv) == 2: - target = sys.argv[1] - else: - target = "Python/opcode_targets.h" - with open(target, "w") as f: - write_contents(f) - print("Jump table written into %s" % target) - - -if __name__ == "__main__": - main() |