summaryrefslogtreecommitdiffstats
path: root/Tools
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2016-11-28 17:13:52 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2016-11-28 17:13:52 (GMT)
commit213cc388c79c71d2f4a2f5cf9dbb29cd03e2eff9 (patch)
treea7c471dcac9cb8e1b2218d43d2c1e9683c84864a /Tools
parent50c13f216e72a2bcc0eeff28ac4258ad2fa5e069 (diff)
downloadcpython-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')
-rw-r--r--Tools/scripts/generate_opcode_h.py12
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])