Subversion Repositories Kolibri OS

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
5205 clevermous 1
/*
2
** $Id: lparser.h,v 1.69 2011/07/27 18:09:01 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 Proto *luaY_parser (lua_State *L, ZIO *z, Mbuffer *buff,
116
                              Dyndata *dyd, const char *name, int firstchar);
117
 
118
 
119
#endif