]> git.zerfleddert.de Git - proxmark3-svn/blob - liblua/lparser.h
Merge pull request #319 from Proxmark/iceman1001-patch-2
[proxmark3-svn] / liblua / lparser.h
1 /*
2 ** $Id: lparser.h,v 1.70 2012/05/08 13:53:33 roberto Exp $
3 ** Lua Parser
4 ** See Copyright Notice in lua.h
5 */
6
7 #ifndef lparser_h
8 #define lparser_h
9
10 #include "llimits.h"
11 #include "lobject.h"
12 #include "lzio.h"
13
14
15 /*
16 ** Expression descriptor
17 */
18
19 typedef enum {
20 VVOID, /* no value */
21 VNIL,
22 VTRUE,
23 VFALSE,
24 VK, /* info = index of constant in `k' */
25 VKNUM, /* nval = numerical value */
26 VNONRELOC, /* info = result register */
27 VLOCAL, /* info = local register */
28 VUPVAL, /* info = index of upvalue in 'upvalues' */
29 VINDEXED, /* t = table register/upvalue; idx = index R/K */
30 VJMP, /* info = instruction pc */
31 VRELOCABLE, /* info = instruction pc */
32 VCALL, /* info = instruction pc */
33 VVARARG /* info = instruction pc */
34 } expkind;
35
36
37 #define vkisvar(k) (VLOCAL <= (k) && (k) <= VINDEXED)
38 #define vkisinreg(k) ((k) == VNONRELOC || (k) == VLOCAL)
39
40 typedef struct expdesc {
41 expkind k;
42 union {
43 struct { /* for indexed variables (VINDEXED) */
44 short idx; /* index (R/K) */
45 lu_byte t; /* table (register or upvalue) */
46 lu_byte vt; /* whether 't' is register (VLOCAL) or upvalue (VUPVAL) */
47 } ind;
48 int info; /* for generic use */
49 lua_Number nval; /* for VKNUM */
50 } u;
51 int t; /* patch list of `exit when true' */
52 int f; /* patch list of `exit when false' */
53 } expdesc;
54
55
56 /* description of active local variable */
57 typedef struct Vardesc {
58 short idx; /* variable index in stack */
59 } Vardesc;
60
61
62 /* description of pending goto statements and label statements */
63 typedef struct Labeldesc {
64 TString *name; /* label identifier */
65 int pc; /* position in code */
66 int line; /* line where it appeared */
67 lu_byte nactvar; /* local level where it appears in current block */
68 } Labeldesc;
69
70
71 /* list of labels or gotos */
72 typedef struct Labellist {
73 Labeldesc *arr; /* array */
74 int n; /* number of entries in use */
75 int size; /* array size */
76 } Labellist;
77
78
79 /* dynamic structures used by the parser */
80 typedef struct Dyndata {
81 struct { /* list of active local variables */
82 Vardesc *arr;
83 int n;
84 int size;
85 } actvar;
86 Labellist gt; /* list of pending gotos */
87 Labellist label; /* list of active labels */
88 } Dyndata;
89
90
91 /* control of blocks */
92 struct BlockCnt; /* defined in lparser.c */
93
94
95 /* state needed to generate code for a given function */
96 typedef struct FuncState {
97 Proto *f; /* current function header */
98 Table *h; /* table to find (and reuse) elements in `k' */
99 struct FuncState *prev; /* enclosing function */
100 struct LexState *ls; /* lexical state */
101 struct BlockCnt *bl; /* chain of current blocks */
102 int pc; /* next position to code (equivalent to `ncode') */
103 int lasttarget; /* 'label' of last 'jump label' */
104 int jpc; /* list of pending jumps to `pc' */
105 int nk; /* number of elements in `k' */
106 int np; /* number of elements in `p' */
107 int firstlocal; /* index of first local var (in Dyndata array) */
108 short nlocvars; /* number of elements in 'f->locvars' */
109 lu_byte nactvar; /* number of active local variables */
110 lu_byte nups; /* number of upvalues */
111 lu_byte freereg; /* first free register */
112 } FuncState;
113
114
115 LUAI_FUNC Closure *luaY_parser (lua_State *L, ZIO *z, Mbuffer *buff,
116 Dyndata *dyd, const char *name, int firstchar);
117
118
119 #endif
Impressum, Datenschutz