opcode.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. /*
  2. ** TeCGraf - PUC-Rio
  3. ** $Id: opcode.h,v 3.32 1997/04/04 22:24:51 roberto Exp roberto $
  4. */
  5. #ifndef opcode_h
  6. #define opcode_h
  7. #include "lua.h"
  8. #include "types.h"
  9. #include "tree.h"
  10. #include "func.h"
  11. #define FIELDS_PER_FLUSH 40
  12. /*
  13. * WARNING: if you change the order of this enumeration,
  14. * grep "ORDER LUA_T"
  15. */
  16. typedef enum
  17. {
  18. LUA_T_NIL = -9,
  19. LUA_T_NUMBER = -8,
  20. LUA_T_STRING = -7,
  21. LUA_T_ARRAY = -6, /* array==table */
  22. LUA_T_FUNCTION = -5,
  23. LUA_T_CFUNCTION= -4,
  24. LUA_T_MARK = -3,
  25. LUA_T_CMARK = -2,
  26. LUA_T_LINE = -1,
  27. LUA_T_USERDATA = 0
  28. } lua_Type;
  29. #define NUM_TYPES 10
  30. extern char *luaI_typenames[];
  31. typedef enum {
  32. /* name parm before after side effect
  33. -----------------------------------------------------------------------------*/
  34. PUSHNIL,/* - nil */
  35. PUSH0,/* - 0.0 */
  36. PUSH1,/* - 1.0 */
  37. PUSH2,/* - 2.0 */
  38. PUSHBYTE,/* b - (float)b */
  39. PUSHWORD,/* w - (float)w */
  40. PUSHFLOAT,/* f - f */
  41. PUSHSTRING,/* w - STR[w] */
  42. PUSHFUNCTION,/* p - FUN(p) */
  43. PUSHLOCAL0,/* - LOC[0] */
  44. PUSHLOCAL1,/* - LOC[1] */
  45. PUSHLOCAL2,/* - LOC[2] */
  46. PUSHLOCAL3,/* - LOC[3] */
  47. PUSHLOCAL4,/* - LOC[4] */
  48. PUSHLOCAL5,/* - LOC[5] */
  49. PUSHLOCAL6,/* - LOC[6] */
  50. PUSHLOCAL7,/* - LOC[7] */
  51. PUSHLOCAL8,/* - LOC[8] */
  52. PUSHLOCAL9,/* - LOC[9] */
  53. PUSHLOCAL,/* b - LOC[b] */
  54. PUSHGLOBAL,/* w - VAR[w] */
  55. PUSHINDEXED,/* i t t[i] */
  56. PUSHSELF,/* w t t t[STR[w]] */
  57. STORELOCAL0,/* x - LOC[0]=x */
  58. STORELOCAL1,/* x - LOC[1]=x */
  59. STORELOCAL2,/* x - LOC[2]=x */
  60. STORELOCAL3,/* x - LOC[3]=x */
  61. STORELOCAL4,/* x - LOC[4]=x */
  62. STORELOCAL5,/* x - LOC[5]=x */
  63. STORELOCAL6,/* x - LOC[6]=x */
  64. STORELOCAL7,/* x - LOC[7]=x */
  65. STORELOCAL8,/* x - LOC[8]=x */
  66. STORELOCAL9,/* x - LOC[9]=x */
  67. STORELOCAL,/* b x - LOC[b]=x */
  68. STOREGLOBAL,/* w x - VAR[w]=x */
  69. STOREINDEXED0,/* v i t - t[i]=v */
  70. STOREINDEXED,/* b v a_b...a_1 i t a_b...a_1 i t t[i]=v */
  71. STORELIST0,/* b v_b...v_1 t - t[i]=v_i */
  72. STORELIST,/* b c v_b...v_1 t - t[i+c*FPF]=v_i */
  73. STORERECORD,/* b
  74. w_b...w_1 v_b...v_1 t - t[STR[w_i]]=v_i */
  75. ADJUST0,/* - - TOP=BASE */
  76. ADJUST,/* b - - TOP=BASE+b */
  77. CREATEARRAY,/* w - newarray(size = w) */
  78. EQOP,/* y x (x==y)? 1 : nil */
  79. LTOP,/* y x (x<y)? 1 : nil */
  80. LEOP,/* y x (x<y)? 1 : nil */
  81. GTOP,/* y x (x>y)? 1 : nil */
  82. GEOP,/* y x (x>=y)? 1 : nil */
  83. ADDOP,/* y x x+y */
  84. SUBOP,/* y x x-y */
  85. MULTOP,/* y x x*y */
  86. DIVOP,/* y x x/y */
  87. POWOP,/* y x x^y */
  88. CONCOP,/* y x x..y */
  89. MINUSOP,/* x -x */
  90. NOTOP,/* x (x==nil)? 1 : nil */
  91. ONTJMP,/* w x - (x!=nil)? PC+=w */
  92. ONFJMP,/* w x - (x==nil)? PC+=w */
  93. JMP,/* w - - PC+=w */
  94. UPJMP,/* w - - PC-=w */
  95. IFFJMP,/* w x - (x==nil)? PC+=w */
  96. IFFUPJMP,/* w x - (x==nil)? PC-=w */
  97. POP,/* x - */
  98. CALLFUNC,/* b c v_b...v_1 f r_c...r_1 f(v1,...,v_b) */
  99. RETCODE0,
  100. RETCODE,/* b - - */
  101. SETLINE,/* w - - LINE=w */
  102. VARARGS,/* b v_b...v_1 {v_1...v_b;n=b} */
  103. STOREMAP/* b v_b k_b ...v_1 k_1 t - t[k_i]=v_i */
  104. } OpCode;
  105. #define MULT_RET 255
  106. typedef union
  107. {
  108. lua_CFunction f;
  109. real n;
  110. TaggedString *ts;
  111. TFunc *tf;
  112. struct Hash *a;
  113. int i;
  114. } Value;
  115. typedef struct TObject
  116. {
  117. lua_Type ttype;
  118. Value value;
  119. } TObject;
  120. /* Macros to access structure members */
  121. #define ttype(o) ((o)->ttype)
  122. #define nvalue(o) ((o)->value.n)
  123. #define svalue(o) ((o)->value.ts->str)
  124. #define tsvalue(o) ((o)->value.ts)
  125. #define avalue(o) ((o)->value.a)
  126. #define fvalue(o) ((o)->value.f)
  127. /* Macros to access symbol table */
  128. #define s_object(i) (lua_table[i].object)
  129. #define s_ttype(i) (ttype(&s_object(i)))
  130. #define s_nvalue(i) (nvalue(&s_object(i)))
  131. #define s_svalue(i) (svalue(&s_object(i)))
  132. #define s_tsvalue(i) (tsvalue(&s_object(i)))
  133. #define s_avalue(i) (avalue(&s_object(i)))
  134. #define s_fvalue(i) (fvalue(&s_object(i)))
  135. #define s_uvalue(i) (uvalue(&s_object(i)))
  136. #define get_word(code,pc) {memcpy(&code, pc, sizeof(Word)); pc+=sizeof(Word);}
  137. #define get_float(code,pc){memcpy(&code, pc, sizeof(real)); pc+=sizeof(real);}
  138. #define get_code(code,pc) {memcpy(&code, pc, sizeof(TFunc *)); \
  139. pc+=sizeof(TFunc *);}
  140. /* Exported functions */
  141. void lua_parse (TFunc *tf); /* from "lua.stx" module */
  142. void luaI_codedebugline (int line); /* from "lua.stx" module */
  143. void lua_travstack (int (*fn)(TObject *));
  144. TObject *luaI_Address (lua_Object o);
  145. void luaI_pushobject (TObject *o);
  146. void luaI_gcIM (TObject *o);
  147. int luaI_dorun (TFunc *tf);
  148. #endif