2014-04-15 20:20:06 +02:00
|
|
|
# This script generates the opcode.h header file.
|
|
|
|
|
|
|
|
import sys
|
|
|
|
header = """/* Auto-generated by Tools/scripts/generate_opcode_h.py */
|
|
|
|
#ifndef Py_OPCODE_H
|
|
|
|
#define Py_OPCODE_H
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/* Instruction opcodes for compiled code */
|
|
|
|
"""
|
|
|
|
|
|
|
|
footer = """
|
|
|
|
/* EXCEPT_HANDLER is a special, implicit block type which is created when
|
|
|
|
entering an except handler. It is not an opcode but we define it here
|
|
|
|
as we want it to be available to both frameobject.c and ceval.c, while
|
|
|
|
remaining private.*/
|
|
|
|
#define EXCEPT_HANDLER 257
|
|
|
|
|
|
|
|
|
|
|
|
enum cmp_op {PyCmp_LT=Py_LT, PyCmp_LE=Py_LE, PyCmp_EQ=Py_EQ, PyCmp_NE=Py_NE,
|
|
|
|
PyCmp_GT=Py_GT, PyCmp_GE=Py_GE, PyCmp_IN, PyCmp_NOT_IN,
|
|
|
|
PyCmp_IS, PyCmp_IS_NOT, PyCmp_EXC_MATCH, PyCmp_BAD};
|
|
|
|
|
|
|
|
#define HAS_ARG(op) ((op) >= HAVE_ARGUMENT)
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* !Py_OPCODE_H */
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
2014-04-17 01:13:29 +02:00
|
|
|
def main(opcode_py, outfile='Include/opcode.h'):
|
|
|
|
opcode = {}
|
|
|
|
exec(open(opcode_py).read(), opcode)
|
|
|
|
opmap = opcode['opmap']
|
2014-04-15 20:20:06 +02:00
|
|
|
with open(outfile, 'w') as fobj:
|
|
|
|
fobj.write(header)
|
2014-04-17 01:13:29 +02:00
|
|
|
for name in opcode['opname']:
|
|
|
|
if name in opmap:
|
2015-05-27 20:31:33 +02:00
|
|
|
fobj.write("#define %-23s %3s\n" % (name, opmap[name]))
|
2014-04-15 20:20:06 +02:00
|
|
|
if name == 'POP_EXCEPT': # Special entry for HAVE_ARGUMENT
|
2015-05-27 20:31:33 +02:00
|
|
|
fobj.write("#define %-23s %3d\n" %
|
2014-04-17 01:13:29 +02:00
|
|
|
('HAVE_ARGUMENT', opcode['HAVE_ARGUMENT']))
|
2014-04-15 20:20:06 +02:00
|
|
|
fobj.write(footer)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2014-04-17 01:13:29 +02:00
|
|
|
main(sys.argv[1], sys.argv[2])
|