mirror of
https://github.com/lua/lua.git
synced 2025-01-14 05:43:00 +08:00
150 lines
4.0 KiB
C
150 lines
4.0 KiB
C
/*
|
|
** TeCGraf - PUC-Rio
|
|
** $Id: opcode.h,v 3.22 1996/09/24 21:46:44 roberto Exp roberto $
|
|
*/
|
|
|
|
#ifndef opcode_h
|
|
#define opcode_h
|
|
|
|
#include "lua.h"
|
|
#include "types.h"
|
|
#include "tree.h"
|
|
#include "func.h"
|
|
|
|
|
|
#define FIELDS_PER_FLUSH 40
|
|
|
|
|
|
typedef enum {
|
|
/* name parm before after side effect
|
|
-----------------------------------------------------------------------------*/
|
|
|
|
PUSHNIL,/* - nil */
|
|
PUSH0,/* - 0.0 */
|
|
PUSH1,/* - 1.0 */
|
|
PUSH2,/* - 2.0 */
|
|
PUSHBYTE,/* b - (float)b */
|
|
PUSHWORD,/* w - (float)w */
|
|
PUSHFLOAT,/* f - f */
|
|
PUSHSTRING,/* w - STR[w] */
|
|
PUSHFUNCTION,/* p - FUN(p) */
|
|
PUSHLOCAL0,/* - LOC[0] */
|
|
PUSHLOCAL1,/* - LOC[1] */
|
|
PUSHLOCAL2,/* - LOC[2] */
|
|
PUSHLOCAL3,/* - LOC[3] */
|
|
PUSHLOCAL4,/* - LOC[4] */
|
|
PUSHLOCAL5,/* - LOC[5] */
|
|
PUSHLOCAL6,/* - LOC[6] */
|
|
PUSHLOCAL7,/* - LOC[7] */
|
|
PUSHLOCAL8,/* - LOC[8] */
|
|
PUSHLOCAL9,/* - LOC[9] */
|
|
PUSHLOCAL,/* w - LOC[w] */
|
|
PUSHGLOBAL,/* w - VAR[w] */
|
|
PUSHINDEXED,/* i t t[i] */
|
|
PUSHSELF,/* w t t t[STR[w]] */
|
|
STORELOCAL0,/* x - LOC[0]=x */
|
|
STORELOCAL1,/* x - LOC[1]=x */
|
|
STORELOCAL2,/* x - LOC[2]=x */
|
|
STORELOCAL3,/* x - LOC[3]=x */
|
|
STORELOCAL4,/* x - LOC[4]=x */
|
|
STORELOCAL5,/* x - LOC[5]=x */
|
|
STORELOCAL6,/* x - LOC[6]=x */
|
|
STORELOCAL7,/* x - LOC[7]=x */
|
|
STORELOCAL8,/* x - LOC[8]=x */
|
|
STORELOCAL9,/* x - LOC[9]=x */
|
|
STORELOCAL,/* w x - LOC[w]=x */
|
|
STOREGLOBAL,/* w x - VAR[w]=x */
|
|
STOREINDEXED0,/* v i t - t[i]=v */
|
|
STOREINDEXED,/* b v a_b...a_1 i t a_b...a_1 i t t[i]=v */
|
|
STORELIST0,/* w v_w...v_1 t - t[i]=v_i */
|
|
STORELIST,/* w n v_w...v_1 t - t[i+n*FPF]=v_i */
|
|
STORERECORD,/* n
|
|
w_n...w_1 v_n...v_1 t - t[STR[w_i]]=v_i */
|
|
ADJUST0,/* - - TOP=BASE */
|
|
ADJUST,/* b - - TOP=BASE+b */
|
|
CREATEARRAY,/* w - newarray(size = w) */
|
|
EQOP,/* y x (x==y)? 1 : nil */
|
|
LTOP,/* y x (x<y)? 1 : nil */
|
|
LEOP,/* y x (x<y)? 1 : nil */
|
|
GTOP,/* y x (x>y)? 1 : nil */
|
|
GEOP,/* y x (x>=y)? 1 : nil */
|
|
ADDOP,/* y x x+y */
|
|
SUBOP,/* y x x-y */
|
|
MULTOP,/* y x x*y */
|
|
DIVOP,/* y x x/y */
|
|
POWOP,/* y x x^y */
|
|
CONCOP,/* y x x..y */
|
|
MINUSOP,/* x -x */
|
|
NOTOP,/* x (x==nil)? 1 : nil */
|
|
ONTJMP,/* w x - (x!=nil)? PC+=w */
|
|
ONFJMP,/* w x - (x==nil)? PC+=w */
|
|
JMP,/* w - - PC+=w */
|
|
UPJMP,/* w - - PC-=w */
|
|
IFFJMP,/* w x - (x==nil)? PC+=w */
|
|
IFFUPJMP,/* w x - (x==nil)? PC-=w */
|
|
POP,/* x - */
|
|
CALLFUNC,/* n m v_n...v_1 f r_m...r_1 f(v1,...,v_n) */
|
|
RETCODE0,
|
|
RETCODE,/* b - - */
|
|
SETLINE,/* w - - LINE=w */
|
|
VARARGS/* b v_n...v_1 {v_1...v_n;n=n} */
|
|
|
|
} OpCode;
|
|
|
|
|
|
#define MULT_RET 255
|
|
|
|
|
|
typedef union
|
|
{
|
|
lua_CFunction f;
|
|
real n;
|
|
TaggedString *ts;
|
|
TFunc *tf;
|
|
struct Hash *a;
|
|
void *u;
|
|
int i;
|
|
} Value;
|
|
|
|
typedef struct Object
|
|
{
|
|
lua_Type tag;
|
|
Value value;
|
|
} Object;
|
|
|
|
|
|
/* Macros to access structure members */
|
|
#define tag(o) ((o)->tag)
|
|
#define nvalue(o) ((o)->value.n)
|
|
#define svalue(o) ((o)->value.ts->str)
|
|
#define tsvalue(o) ((o)->value.ts)
|
|
#define avalue(o) ((o)->value.a)
|
|
#define fvalue(o) ((o)->value.f)
|
|
#define uvalue(o) ((o)->value.u)
|
|
|
|
/* Macros to access symbol table */
|
|
#define s_object(i) (lua_table[i].object)
|
|
#define s_tag(i) (tag(&s_object(i)))
|
|
#define s_nvalue(i) (nvalue(&s_object(i)))
|
|
#define s_svalue(i) (svalue(&s_object(i)))
|
|
#define s_avalue(i) (avalue(&s_object(i)))
|
|
#define s_fvalue(i) (fvalue(&s_object(i)))
|
|
#define s_uvalue(i) (uvalue(&s_object(i)))
|
|
|
|
#define get_word(code,pc) {memcpy(&code, pc, sizeof(Word)); pc+=sizeof(Word);}
|
|
#define get_float(code,pc){memcpy(&code, pc, sizeof(real)); pc+=sizeof(real);}
|
|
#define get_code(code,pc) {memcpy(&code, pc, sizeof(TFunc *)); \
|
|
pc+=sizeof(TFunc *);}
|
|
|
|
|
|
/* Exported functions */
|
|
void lua_parse (TFunc *tf); /* from "lua.stx" module */
|
|
void luaI_codedebugline (int line); /* from "lua.stx" module */
|
|
void lua_travstack (int (*fn)(Object *));
|
|
Object *luaI_Address (lua_Object o);
|
|
void luaI_pushobject (Object *o);
|
|
void luaI_gcFB (Object *o);
|
|
int luaI_dorun (TFunc *tf);
|
|
|
|
#endif
|