diff options
author | Victor Stinner <victor.stinner@gmail.com> | 2016-11-28 17:13:52 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@gmail.com> | 2016-11-28 17:13:52 (GMT) |
commit | 213cc388c79c71d2f4a2f5cf9dbb29cd03e2eff9 (patch) | |
tree | a7c471dcac9cb8e1b2218d43d2c1e9683c84864a /Tools/scripts/generate_opcode_h.py | |
parent | 50c13f216e72a2bcc0eeff28ac4258ad2fa5e069 (diff) | |
download | cpython-213cc388c79c71d2f4a2f5cf9dbb29cd03e2eff9.zip cpython-213cc388c79c71d2f4a2f5cf9dbb29cd03e2eff9.tar.gz cpython-213cc388c79c71d2f4a2f5cf9dbb29cd03e2eff9.tar.bz2 |
Reintroduce Python2 support in generate_opcode_h.py
Issue #28821.
Add also a message to show that the command did something :-)
Diffstat (limited to 'Tools/scripts/generate_opcode_h.py')
-rw-r--r-- | Tools/scripts/generate_opcode_h.py | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/Tools/scripts/generate_opcode_h.py b/Tools/scripts/generate_opcode_h.py index bbc3aab..6622a3c 100644 --- a/Tools/scripts/generate_opcode_h.py +++ b/Tools/scripts/generate_opcode_h.py @@ -1,6 +1,8 @@ # This script generates the opcode.h header file. import sys +import tokenize + header = """/* Auto-generated by Tools/scripts/generate_opcode_h.py */ #ifndef Py_OPCODE_H #define Py_OPCODE_H @@ -32,12 +34,14 @@ enum cmp_op {PyCmp_LT=Py_LT, PyCmp_LE=Py_LE, PyCmp_EQ=Py_EQ, PyCmp_NE=Py_NE, #endif /* !Py_OPCODE_H */ """ -import tokenize - def main(opcode_py, outfile='Include/opcode.h'): opcode = {} - with tokenize.open(opcode_py) as fp: + if hasattr(tokenize, 'open'): + fp = tokenize.open(opcode_py) # Python 3.2+ + else: + fp = open(opcode_py) # Python 2.7 + with fp: code = fp.read() exec(code, opcode) opmap = opcode['opmap'] @@ -51,6 +55,8 @@ def main(opcode_py, outfile='Include/opcode.h'): ('HAVE_ARGUMENT', opcode['HAVE_ARGUMENT'])) fobj.write(footer) + print("%s regenerated from %s" % (outfile, opcode_py)) + if __name__ == '__main__': main(sys.argv[1], sys.argv[2]) |