Rizin
unix-like reverse engineering framework and cli tools
opcode_20.c File Reference
#include "opcode.h"

Go to the source code of this file.

Functions

pyc_opcodesopcode_20 (void)
 

Function Documentation

◆ opcode_20()

pyc_opcodes* opcode_20 ( void  )

Definition at line 6 of file opcode_20.c.

6  {
7  pyc_opcodes *ret = opcode_21();
8  if (!ret) {
9  return NULL;
10  }
11 
12  ret->version_sig = (void *(*)())opcode_20;
13 
14  // 2.1 Bytecodes not in 2.0
15  rm_op(.op_obj = ret->opcodes, .op_name = "CONTINUE_LOOP", .op_code = 119);
16  rm_op(.op_obj = ret->opcodes, .op_name = "MAKE_CLOSURE", .op_code = 134);
17  rm_op(.op_obj = ret->opcodes, .op_name = "LOAD_CLOSURE", .op_code = 135);
18  rm_op(.op_obj = ret->opcodes, .op_name = "LOAD_DEREF", .op_code = 136);
19  rm_op(.op_obj = ret->opcodes, .op_name = "STORE_DEREF", .op_code = 137);
20 
22  add_arg_fmt(ret, "EXTENDED_ARG", format_extended_arg);
23 
24  return ret;
25 }
#define NULL
Definition: cris-opc.c:27
RZ_API void rz_list_purge(RZ_NONNULL RzList *list)
Empties the list without freeing the list pointer.
Definition: list.c:120
void add_arg_fmt(pyc_opcodes *ret, char *op_name, const char *(*formatter)(ut32 oparg))
Definition: opcode.c:234
pyc_opcodes * opcode_20(void)
Definition: opcode_20.c:6
const char * format_extended_arg(ut32 oparg)
Definition: opcode_arg_fmt.c:6
pyc_opcodes * opcode_21(void)
Definition: opcode_21.c:6
#define rm_op(...)
Definition: opcode.h:175
char * op_name
Definition: opcode.h:38
void *(* version_sig)()
Definition: opcode.h:49
pyc_opcode_object * opcodes
Definition: opcode.h:51
RzList * opcode_arg_fmt
Definition: opcode.h:50

References add_arg_fmt(), format_extended_arg(), NULL, pyc_opcode_object::op_name, opcode_20(), opcode_21(), pyc_opcodes::opcode_arg_fmt, pyc_opcodes::opcodes, rm_op, rz_list_purge(), and pyc_opcodes::version_sig.

Referenced by opcode_20().