Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/ceguilua/src/lua/lparser.c @ 1936

Last change on this file since 1936 was 1806, checked in by rgrieder, 17 years ago

added single 5.1.3 directory for lua since CEGUILua 0.5 can also build against lua 5.1

  • Property svn:eol-style set to native
File size: 35.8 KB
RevLine 
[1806]1/*
2** $Id: lparser.c,v 2.42.1.3 2007/12/28 15:32:23 roberto Exp $
3** Lua Parser
4** See Copyright Notice in lua.h
5*/
6
7
8#include <string.h>
9
10#define lparser_c
11#define LUA_CORE
12
13#include "lua.h"
14
15#include "lcode.h"
16#include "ldebug.h"
17#include "ldo.h"
18#include "lfunc.h"
19#include "llex.h"
20#include "lmem.h"
21#include "lobject.h"
22#include "lopcodes.h"
23#include "lparser.h"
24#include "lstate.h"
25#include "lstring.h"
26#include "ltable.h"
27
28
29
30#define hasmultret(k)           ((k) == VCALL || (k) == VVARARG)
31
32#define getlocvar(fs, i)        ((fs)->f->locvars[(fs)->actvar[i]])
33
34#define luaY_checklimit(fs,v,l,m)       if ((v)>(l)) errorlimit(fs,l,m)
35
36
37/*
38** nodes for block list (list of active blocks)
39*/
40typedef struct BlockCnt {
41  struct BlockCnt *previous;  /* chain */
42  int breaklist;  /* list of jumps out of this loop */
43  lu_byte nactvar;  /* # active locals outside the breakable structure */
44  lu_byte upval;  /* true if some variable in the block is an upvalue */
45  lu_byte isbreakable;  /* true if `block' is a loop */
46} BlockCnt;
47
48
49
50/*
51** prototypes for recursive non-terminal functions
52*/
53static void chunk (LexState *ls);
54static void expr (LexState *ls, expdesc *v);
55
56
57static void anchor_token (LexState *ls) {
58  if (ls->t.token == TK_NAME || ls->t.token == TK_STRING) {
59    TString *ts = ls->t.seminfo.ts;
60    luaX_newstring(ls, getstr(ts), ts->tsv.len);
61  }
62}
63
64
65static void error_expected (LexState *ls, int token) {
66  luaX_syntaxerror(ls,
67      luaO_pushfstring(ls->L, LUA_QS " expected", luaX_token2str(ls, token)));
68}
69
70
71static void errorlimit (FuncState *fs, int limit, const char *what) {
72  const char *msg = (fs->f->linedefined == 0) ?
73    luaO_pushfstring(fs->L, "main function has more than %d %s", limit, what) :
74    luaO_pushfstring(fs->L, "function at line %d has more than %d %s",
75                            fs->f->linedefined, limit, what);
76  luaX_lexerror(fs->ls, msg, 0);
77}
78
79
80static int testnext (LexState *ls, int c) {
81  if (ls->t.token == c) {
82    luaX_next(ls);
83    return 1;
84  }
85  else return 0;
86}
87
88
89static void check (LexState *ls, int c) {
90  if (ls->t.token != c)
91    error_expected(ls, c);
92}
93
94static void checknext (LexState *ls, int c) {
95  check(ls, c);
96  luaX_next(ls);
97}
98
99
100#define check_condition(ls,c,msg)       { if (!(c)) luaX_syntaxerror(ls, msg); }
101
102
103
104static void check_match (LexState *ls, int what, int who, int where) {
105  if (!testnext(ls, what)) {
106    if (where == ls->linenumber)
107      error_expected(ls, what);
108    else {
109      luaX_syntaxerror(ls, luaO_pushfstring(ls->L,
110             LUA_QS " expected (to close " LUA_QS " at line %d)",
111              luaX_token2str(ls, what), luaX_token2str(ls, who), where));
112    }
113  }
114}
115
116
117static TString *str_checkname (LexState *ls) {
118  TString *ts;
119  check(ls, TK_NAME);
120  ts = ls->t.seminfo.ts;
121  luaX_next(ls);
122  return ts;
123}
124
125
126static void init_exp (expdesc *e, expkind k, int i) {
127  e->f = e->t = NO_JUMP;
128  e->k = k;
129  e->u.s.info = i;
130}
131
132
133static void codestring (LexState *ls, expdesc *e, TString *s) {
134  init_exp(e, VK, luaK_stringK(ls->fs, s));
135}
136
137
138static void checkname(LexState *ls, expdesc *e) {
139  codestring(ls, e, str_checkname(ls));
140}
141
142
143static int registerlocalvar (LexState *ls, TString *varname) {
144  FuncState *fs = ls->fs;
145  Proto *f = fs->f;
146  int oldsize = f->sizelocvars;
147  luaM_growvector(ls->L, f->locvars, fs->nlocvars, f->sizelocvars,
148                  LocVar, SHRT_MAX, "too many local variables");
149  while (oldsize < f->sizelocvars) f->locvars[oldsize++].varname = NULL;
150  f->locvars[fs->nlocvars].varname = varname;
151  luaC_objbarrier(ls->L, f, varname);
152  return fs->nlocvars++;
153}
154
155
156#define new_localvarliteral(ls,v,n) \
157  new_localvar(ls, luaX_newstring(ls, "" v, (sizeof(v)/sizeof(char))-1), n)
158
159
160static void new_localvar (LexState *ls, TString *name, int n) {
161  FuncState *fs = ls->fs;
162  luaY_checklimit(fs, fs->nactvar+n+1, LUAI_MAXVARS, "local variables");
163  fs->actvar[fs->nactvar+n] = cast(unsigned short, registerlocalvar(ls, name));
164}
165
166
167static void adjustlocalvars (LexState *ls, int nvars) {
168  FuncState *fs = ls->fs;
169  fs->nactvar = cast_byte(fs->nactvar + nvars);
170  for (; nvars; nvars--) {
171    getlocvar(fs, fs->nactvar - nvars).startpc = fs->pc;
172  }
173}
174
175
176static void removevars (LexState *ls, int tolevel) {
177  FuncState *fs = ls->fs;
178  while (fs->nactvar > tolevel)
179    getlocvar(fs, --fs->nactvar).endpc = fs->pc;
180}
181
182
183static int indexupvalue (FuncState *fs, TString *name, expdesc *v) {
184  int i;
185  Proto *f = fs->f;
186  int oldsize = f->sizeupvalues;
187  for (i=0; i<f->nups; i++) {
188    if (fs->upvalues[i].k == v->k && fs->upvalues[i].info == v->u.s.info) {
189      lua_assert(f->upvalues[i] == name);
190      return i;
191    }
192  }
193  /* new one */
194  luaY_checklimit(fs, f->nups + 1, LUAI_MAXUPVALUES, "upvalues");
195  luaM_growvector(fs->L, f->upvalues, f->nups, f->sizeupvalues,
196                  TString *, MAX_INT, "");
197  while (oldsize < f->sizeupvalues) f->upvalues[oldsize++] = NULL;
198  f->upvalues[f->nups] = name;
199  luaC_objbarrier(fs->L, f, name);
200  lua_assert(v->k == VLOCAL || v->k == VUPVAL);
201  fs->upvalues[f->nups].k = cast_byte(v->k);
202  fs->upvalues[f->nups].info = cast_byte(v->u.s.info);
203  return f->nups++;
204}
205
206
207static int searchvar (FuncState *fs, TString *n) {
208  int i;
209  for (i=fs->nactvar-1; i >= 0; i--) {
210    if (n == getlocvar(fs, i).varname)
211      return i;
212  }
213  return -1;  /* not found */
214}
215
216
217static void markupval (FuncState *fs, int level) {
218  BlockCnt *bl = fs->bl;
219  while (bl && bl->nactvar > level) bl = bl->previous;
220  if (bl) bl->upval = 1;
221}
222
223
224static int singlevaraux (FuncState *fs, TString *n, expdesc *var, int base) {
225  if (fs == NULL) {  /* no more levels? */
226    init_exp(var, VGLOBAL, NO_REG);  /* default is global variable */
227    return VGLOBAL;
228  }
229  else {
230    int v = searchvar(fs, n);  /* look up at current level */
231    if (v >= 0) {
232      init_exp(var, VLOCAL, v);
233      if (!base)
234        markupval(fs, v);  /* local will be used as an upval */
235      return VLOCAL;
236    }
237    else {  /* not found at current level; try upper one */
238      if (singlevaraux(fs->prev, n, var, 0) == VGLOBAL)
239        return VGLOBAL;
240      var->u.s.info = indexupvalue(fs, n, var);  /* else was LOCAL or UPVAL */
241      var->k = VUPVAL;  /* upvalue in this level */
242      return VUPVAL;
243    }
244  }
245}
246
247
248static void singlevar (LexState *ls, expdesc *var) {
249  TString *varname = str_checkname(ls);
250  FuncState *fs = ls->fs;
251  if (singlevaraux(fs, varname, var, 1) == VGLOBAL)
252    var->u.s.info = luaK_stringK(fs, varname);  /* info points to global name */
253}
254
255
256static void adjust_assign (LexState *ls, int nvars, int nexps, expdesc *e) {
257  FuncState *fs = ls->fs;
258  int extra = nvars - nexps;
259  if (hasmultret(e->k)) {
260    extra++;  /* includes call itself */
261    if (extra < 0) extra = 0;
262    luaK_setreturns(fs, e, extra);  /* last exp. provides the difference */
263    if (extra > 1) luaK_reserveregs(fs, extra-1);
264  }
265  else {
266    if (e->k != VVOID) luaK_exp2nextreg(fs, e);  /* close last expression */
267    if (extra > 0) {
268      int reg = fs->freereg;
269      luaK_reserveregs(fs, extra);
270      luaK_nil(fs, reg, extra);
271    }
272  }
273}
274
275
276static void enterlevel (LexState *ls) {
277  if (++ls->L->nCcalls > LUAI_MAXCCALLS)
278        luaX_lexerror(ls, "chunk has too many syntax levels", 0);
279}
280
281
282#define leavelevel(ls)  ((ls)->L->nCcalls--)
283
284
285static void enterblock (FuncState *fs, BlockCnt *bl, lu_byte isbreakable) {
286  bl->breaklist = NO_JUMP;
287  bl->isbreakable = isbreakable;
288  bl->nactvar = fs->nactvar;
289  bl->upval = 0;
290  bl->previous = fs->bl;
291  fs->bl = bl;
292  lua_assert(fs->freereg == fs->nactvar);
293}
294
295
296static void leaveblock (FuncState *fs) {
297  BlockCnt *bl = fs->bl;
298  fs->bl = bl->previous;
299  removevars(fs->ls, bl->nactvar);
300  if (bl->upval)
301    luaK_codeABC(fs, OP_CLOSE, bl->nactvar, 0, 0);
302  /* a block either controls scope or breaks (never both) */
303  lua_assert(!bl->isbreakable || !bl->upval);
304  lua_assert(bl->nactvar == fs->nactvar);
305  fs->freereg = fs->nactvar;  /* free registers */
306  luaK_patchtohere(fs, bl->breaklist);
307}
308
309
310static void pushclosure (LexState *ls, FuncState *func, expdesc *v) {
311  FuncState *fs = ls->fs;
312  Proto *f = fs->f;
313  int oldsize = f->sizep;
314  int i;
315  luaM_growvector(ls->L, f->p, fs->np, f->sizep, Proto *,
316                  MAXARG_Bx, "constant table overflow");
317  while (oldsize < f->sizep) f->p[oldsize++] = NULL;
318  f->p[fs->np++] = func->f;
319  luaC_objbarrier(ls->L, f, func->f);
320  init_exp(v, VRELOCABLE, luaK_codeABx(fs, OP_CLOSURE, 0, fs->np-1));
321  for (i=0; i<func->f->nups; i++) {
322    OpCode o = (func->upvalues[i].k == VLOCAL) ? OP_MOVE : OP_GETUPVAL;
323    luaK_codeABC(fs, o, 0, func->upvalues[i].info, 0);
324  }
325}
326
327
328static void open_func (LexState *ls, FuncState *fs) {
329  lua_State *L = ls->L;
330  Proto *f = luaF_newproto(L);
331  fs->f = f;
332  fs->prev = ls->fs;  /* linked list of funcstates */
333  fs->ls = ls;
334  fs->L = L;
335  ls->fs = fs;
336  fs->pc = 0;
337  fs->lasttarget = -1;
338  fs->jpc = NO_JUMP;
339  fs->freereg = 0;
340  fs->nk = 0;
341  fs->np = 0;
342  fs->nlocvars = 0;
343  fs->nactvar = 0;
344  fs->bl = NULL;
345  f->source = ls->source;
346  f->maxstacksize = 2;  /* registers 0/1 are always valid */
347  fs->h = luaH_new(L, 0, 0);
348  /* anchor table of constants and prototype (to avoid being collected) */
349  sethvalue2s(L, L->top, fs->h);
350  incr_top(L);
351  setptvalue2s(L, L->top, f);
352  incr_top(L);
353}
354
355
356static void close_func (LexState *ls) {
357  lua_State *L = ls->L;
358  FuncState *fs = ls->fs;
359  Proto *f = fs->f;
360  removevars(ls, 0);
361  luaK_ret(fs, 0, 0);  /* final return */
362  luaM_reallocvector(L, f->code, f->sizecode, fs->pc, Instruction);
363  f->sizecode = fs->pc;
364  luaM_reallocvector(L, f->lineinfo, f->sizelineinfo, fs->pc, int);
365  f->sizelineinfo = fs->pc;
366  luaM_reallocvector(L, f->k, f->sizek, fs->nk, TValue);
367  f->sizek = fs->nk;
368  luaM_reallocvector(L, f->p, f->sizep, fs->np, Proto *);
369  f->sizep = fs->np;
370  luaM_reallocvector(L, f->locvars, f->sizelocvars, fs->nlocvars, LocVar);
371  f->sizelocvars = fs->nlocvars;
372  luaM_reallocvector(L, f->upvalues, f->sizeupvalues, f->nups, TString *);
373  f->sizeupvalues = f->nups;
374  lua_assert(luaG_checkcode(f));
375  lua_assert(fs->bl == NULL);
376  ls->fs = fs->prev;
377  L->top -= 2;  /* remove table and prototype from the stack */
378  /* last token read was anchored in defunct function; must reanchor it */
379  if (fs) anchor_token(ls);
380}
381
382
383Proto *luaY_parser (lua_State *L, ZIO *z, Mbuffer *buff, const char *name) {
384  struct LexState lexstate;
385  struct FuncState funcstate;
386  lexstate.buff = buff;
387  luaX_setinput(L, &lexstate, z, luaS_new(L, name));
388  open_func(&lexstate, &funcstate);
389  funcstate.f->is_vararg = VARARG_ISVARARG;  /* main func. is always vararg */
390  luaX_next(&lexstate);  /* read first token */
391  chunk(&lexstate);
392  check(&lexstate, TK_EOS);
393  close_func(&lexstate);
394  lua_assert(funcstate.prev == NULL);
395  lua_assert(funcstate.f->nups == 0);
396  lua_assert(lexstate.fs == NULL);
397  return funcstate.f;
398}
399
400
401
402/*============================================================*/
403/* GRAMMAR RULES */
404/*============================================================*/
405
406
407static void field (LexState *ls, expdesc *v) {
408  /* field -> ['.' | ':'] NAME */
409  FuncState *fs = ls->fs;
410  expdesc key;
411  luaK_exp2anyreg(fs, v);
412  luaX_next(ls);  /* skip the dot or colon */
413  checkname(ls, &key);
414  luaK_indexed(fs, v, &key);
415}
416
417
418static void yindex (LexState *ls, expdesc *v) {
419  /* index -> '[' expr ']' */
420  luaX_next(ls);  /* skip the '[' */
421  expr(ls, v);
422  luaK_exp2val(ls->fs, v);
423  checknext(ls, ']');
424}
425
426
427/*
428** {======================================================================
429** Rules for Constructors
430** =======================================================================
431*/
432
433
434struct ConsControl {
435  expdesc v;  /* last list item read */
436  expdesc *t;  /* table descriptor */
437  int nh;  /* total number of `record' elements */
438  int na;  /* total number of array elements */
439  int tostore;  /* number of array elements pending to be stored */
440};
441
442
443static void recfield (LexState *ls, struct ConsControl *cc) {
444  /* recfield -> (NAME | `['exp1`]') = exp1 */
445  FuncState *fs = ls->fs;
446  int reg = ls->fs->freereg;
447  expdesc key, val;
448  int rkkey;
449  if (ls->t.token == TK_NAME) {
450    luaY_checklimit(fs, cc->nh, MAX_INT, "items in a constructor");
451    checkname(ls, &key);
452  }
453  else  /* ls->t.token == '[' */
454    yindex(ls, &key);
455  cc->nh++;
456  checknext(ls, '=');
457  rkkey = luaK_exp2RK(fs, &key);
458  expr(ls, &val);
459  luaK_codeABC(fs, OP_SETTABLE, cc->t->u.s.info, rkkey, luaK_exp2RK(fs, &val));
460  fs->freereg = reg;  /* free registers */
461}
462
463
464static void closelistfield (FuncState *fs, struct ConsControl *cc) {
465  if (cc->v.k == VVOID) return;  /* there is no list item */
466  luaK_exp2nextreg(fs, &cc->v);
467  cc->v.k = VVOID;
468  if (cc->tostore == LFIELDS_PER_FLUSH) {
469    luaK_setlist(fs, cc->t->u.s.info, cc->na, cc->tostore);  /* flush */
470    cc->tostore = 0;  /* no more items pending */
471  }
472}
473
474
475static void lastlistfield (FuncState *fs, struct ConsControl *cc) {
476  if (cc->tostore == 0) return;
477  if (hasmultret(cc->v.k)) {
478    luaK_setmultret(fs, &cc->v);
479    luaK_setlist(fs, cc->t->u.s.info, cc->na, LUA_MULTRET);
480    cc->na--;  /* do not count last expression (unknown number of elements) */
481  }
482  else {
483    if (cc->v.k != VVOID)
484      luaK_exp2nextreg(fs, &cc->v);
485    luaK_setlist(fs, cc->t->u.s.info, cc->na, cc->tostore);
486  }
487}
488
489
490static void listfield (LexState *ls, struct ConsControl *cc) {
491  expr(ls, &cc->v);
492  luaY_checklimit(ls->fs, cc->na, MAX_INT, "items in a constructor");
493  cc->na++;
494  cc->tostore++;
495}
496
497
498static void constructor (LexState *ls, expdesc *t) {
499  /* constructor -> ?? */
500  FuncState *fs = ls->fs;
501  int line = ls->linenumber;
502  int pc = luaK_codeABC(fs, OP_NEWTABLE, 0, 0, 0);
503  struct ConsControl cc;
504  cc.na = cc.nh = cc.tostore = 0;
505  cc.t = t;
506  init_exp(t, VRELOCABLE, pc);
507  init_exp(&cc.v, VVOID, 0);  /* no value (yet) */
508  luaK_exp2nextreg(ls->fs, t);  /* fix it at stack top (for gc) */
509  checknext(ls, '{');
510  do {
511    lua_assert(cc.v.k == VVOID || cc.tostore > 0);
512    if (ls->t.token == '}') break;
513    closelistfield(fs, &cc);
514    switch(ls->t.token) {
515      case TK_NAME: {  /* may be listfields or recfields */
516        luaX_lookahead(ls);
517        if (ls->lookahead.token != '=')  /* expression? */
518          listfield(ls, &cc);
519        else
520          recfield(ls, &cc);
521        break;
522      }
523      case '[': {  /* constructor_item -> recfield */
524        recfield(ls, &cc);
525        break;
526      }
527      default: {  /* constructor_part -> listfield */
528        listfield(ls, &cc);
529        break;
530      }
531    }
532  } while (testnext(ls, ',') || testnext(ls, ';'));
533  check_match(ls, '}', '{', line);
534  lastlistfield(fs, &cc);
535  SETARG_B(fs->f->code[pc], luaO_int2fb(cc.na)); /* set initial array size */
536  SETARG_C(fs->f->code[pc], luaO_int2fb(cc.nh));  /* set initial table size */
537}
538
539/* }====================================================================== */
540
541
542
543static void parlist (LexState *ls) {
544  /* parlist -> [ param { `,' param } ] */
545  FuncState *fs = ls->fs;
546  Proto *f = fs->f;
547  int nparams = 0;
548  f->is_vararg = 0;
549  if (ls->t.token != ')') {  /* is `parlist' not empty? */
550    do {
551      switch (ls->t.token) {
552        case TK_NAME: {  /* param -> NAME */
553          new_localvar(ls, str_checkname(ls), nparams++);
554          break;
555        }
556        case TK_DOTS: {  /* param -> `...' */
557          luaX_next(ls);
558#if defined(LUA_COMPAT_VARARG)
559          /* use `arg' as default name */
560          new_localvarliteral(ls, "arg", nparams++);
561          f->is_vararg = VARARG_HASARG | VARARG_NEEDSARG;
562#endif
563          f->is_vararg |= VARARG_ISVARARG;
564          break;
565        }
566        default: luaX_syntaxerror(ls, "<name> or " LUA_QL("...") " expected");
567      }
568    } while (!f->is_vararg && testnext(ls, ','));
569  }
570  adjustlocalvars(ls, nparams);
571  f->numparams = cast_byte(fs->nactvar - (f->is_vararg & VARARG_HASARG));
572  luaK_reserveregs(fs, fs->nactvar);  /* reserve register for parameters */
573}
574
575
576static void body (LexState *ls, expdesc *e, int needself, int line) {
577  /* body ->  `(' parlist `)' chunk END */
578  FuncState new_fs;
579  open_func(ls, &new_fs);
580  new_fs.f->linedefined = line;
581  checknext(ls, '(');
582  if (needself) {
583    new_localvarliteral(ls, "self", 0);
584    adjustlocalvars(ls, 1);
585  }
586  parlist(ls);
587  checknext(ls, ')');
588  chunk(ls);
589  new_fs.f->lastlinedefined = ls->linenumber;
590  check_match(ls, TK_END, TK_FUNCTION, line);
591  close_func(ls);
592  pushclosure(ls, &new_fs, e);
593}
594
595
596static int explist1 (LexState *ls, expdesc *v) {
597  /* explist1 -> expr { `,' expr } */
598  int n = 1;  /* at least one expression */
599  expr(ls, v);
600  while (testnext(ls, ',')) {
601    luaK_exp2nextreg(ls->fs, v);
602    expr(ls, v);
603    n++;
604  }
605  return n;
606}
607
608
609static void funcargs (LexState *ls, expdesc *f) {
610  FuncState *fs = ls->fs;
611  expdesc args;
612  int base, nparams;
613  int line = ls->linenumber;
614  switch (ls->t.token) {
615    case '(': {  /* funcargs -> `(' [ explist1 ] `)' */
616      if (line != ls->lastline)
617        luaX_syntaxerror(ls,"ambiguous syntax (function call x new statement)");
618      luaX_next(ls);
619      if (ls->t.token == ')')  /* arg list is empty? */
620        args.k = VVOID;
621      else {
622        explist1(ls, &args);
623        luaK_setmultret(fs, &args);
624      }
625      check_match(ls, ')', '(', line);
626      break;
627    }
628    case '{': {  /* funcargs -> constructor */
629      constructor(ls, &args);
630      break;
631    }
632    case TK_STRING: {  /* funcargs -> STRING */
633      codestring(ls, &args, ls->t.seminfo.ts);
634      luaX_next(ls);  /* must use `seminfo' before `next' */
635      break;
636    }
637    default: {
638      luaX_syntaxerror(ls, "function arguments expected");
639      return;
640    }
641  }
642  lua_assert(f->k == VNONRELOC);
643  base = f->u.s.info;  /* base register for call */
644  if (hasmultret(args.k))
645    nparams = LUA_MULTRET;  /* open call */
646  else {
647    if (args.k != VVOID)
648      luaK_exp2nextreg(fs, &args);  /* close last argument */
649    nparams = fs->freereg - (base+1);
650  }
651  init_exp(f, VCALL, luaK_codeABC(fs, OP_CALL, base, nparams+1, 2));
652  luaK_fixline(fs, line);
653  fs->freereg = base+1;  /* call remove function and arguments and leaves
654                            (unless changed) one result */
655}
656
657
658
659
660/*
661** {======================================================================
662** Expression parsing
663** =======================================================================
664*/
665
666
667static void prefixexp (LexState *ls, expdesc *v) {
668  /* prefixexp -> NAME | '(' expr ')' */
669  switch (ls->t.token) {
670    case '(': {
671      int line = ls->linenumber;
672      luaX_next(ls);
673      expr(ls, v);
674      check_match(ls, ')', '(', line);
675      luaK_dischargevars(ls->fs, v);
676      return;
677    }
678    case TK_NAME: {
679      singlevar(ls, v);
680      return;
681    }
682    default: {
683      luaX_syntaxerror(ls, "unexpected symbol");
684      return;
685    }
686  }
687}
688
689
690static void primaryexp (LexState *ls, expdesc *v) {
691  /* primaryexp ->
692        prefixexp { `.' NAME | `[' exp `]' | `:' NAME funcargs | funcargs } */
693  FuncState *fs = ls->fs;
694  prefixexp(ls, v);
695  for (;;) {
696    switch (ls->t.token) {
697      case '.': {  /* field */
698        field(ls, v);
699        break;
700      }
701      case '[': {  /* `[' exp1 `]' */
702        expdesc key;
703        luaK_exp2anyreg(fs, v);
704        yindex(ls, &key);
705        luaK_indexed(fs, v, &key);
706        break;
707      }
708      case ':': {  /* `:' NAME funcargs */
709        expdesc key;
710        luaX_next(ls);
711        checkname(ls, &key);
712        luaK_self(fs, v, &key);
713        funcargs(ls, v);
714        break;
715      }
716      case '(': case TK_STRING: case '{': {  /* funcargs */
717        luaK_exp2nextreg(fs, v);
718        funcargs(ls, v);
719        break;
720      }
721      default: return;
722    }
723  }
724}
725
726
727static void simpleexp (LexState *ls, expdesc *v) {
728  /* simpleexp -> NUMBER | STRING | NIL | true | false | ... |
729                  constructor | FUNCTION body | primaryexp */
730  switch (ls->t.token) {
731    case TK_NUMBER: {
732      init_exp(v, VKNUM, 0);
733      v->u.nval = ls->t.seminfo.r;
734      break;
735    }
736    case TK_STRING: {
737      codestring(ls, v, ls->t.seminfo.ts);
738      break;
739    }
740    case TK_NIL: {
741      init_exp(v, VNIL, 0);
742      break;
743    }
744    case TK_TRUE: {
745      init_exp(v, VTRUE, 0);
746      break;
747    }
748    case TK_FALSE: {
749      init_exp(v, VFALSE, 0);
750      break;
751    }
752    case TK_DOTS: {  /* vararg */
753      FuncState *fs = ls->fs;
754      check_condition(ls, fs->f->is_vararg,
755                      "cannot use " LUA_QL("...") " outside a vararg function");
756      fs->f->is_vararg &= ~VARARG_NEEDSARG;  /* don't need 'arg' */
757      init_exp(v, VVARARG, luaK_codeABC(fs, OP_VARARG, 0, 1, 0));
758      break;
759    }
760    case '{': {  /* constructor */
761      constructor(ls, v);
762      return;
763    }
764    case TK_FUNCTION: {
765      luaX_next(ls);
766      body(ls, v, 0, ls->linenumber);
767      return;
768    }
769    default: {
770      primaryexp(ls, v);
771      return;
772    }
773  }
774  luaX_next(ls);
775}
776
777
778static UnOpr getunopr (int op) {
779  switch (op) {
780    case TK_NOT: return OPR_NOT;
781    case '-': return OPR_MINUS;
782    case '#': return OPR_LEN;
783    default: return OPR_NOUNOPR;
784  }
785}
786
787
788static BinOpr getbinopr (int op) {
789  switch (op) {
790    case '+': return OPR_ADD;
791    case '-': return OPR_SUB;
792    case '*': return OPR_MUL;
793    case '/': return OPR_DIV;
794    case '%': return OPR_MOD;
795    case '^': return OPR_POW;
796    case TK_CONCAT: return OPR_CONCAT;
797    case TK_NE: return OPR_NE;
798    case TK_EQ: return OPR_EQ;
799    case '<': return OPR_LT;
800    case TK_LE: return OPR_LE;
801    case '>': return OPR_GT;
802    case TK_GE: return OPR_GE;
803    case TK_AND: return OPR_AND;
804    case TK_OR: return OPR_OR;
805    default: return OPR_NOBINOPR;
806  }
807}
808
809
810static const struct {
811  lu_byte left;  /* left priority for each binary operator */
812  lu_byte right; /* right priority */
813} priority[] = {  /* ORDER OPR */
814   {6, 6}, {6, 6}, {7, 7}, {7, 7}, {7, 7},  /* `+' `-' `/' `%' */
815   {10, 9}, {5, 4},                 /* power and concat (right associative) */
816   {3, 3}, {3, 3},                  /* equality and inequality */
817   {3, 3}, {3, 3}, {3, 3}, {3, 3},  /* order */
818   {2, 2}, {1, 1}                   /* logical (and/or) */
819};
820
821#define UNARY_PRIORITY  8  /* priority for unary operators */
822
823
824/*
825** subexpr -> (simpleexp | unop subexpr) { binop subexpr }
826** where `binop' is any binary operator with a priority higher than `limit'
827*/
828static BinOpr subexpr (LexState *ls, expdesc *v, unsigned int limit) {
829  BinOpr op;
830  UnOpr uop;
831  enterlevel(ls);
832  uop = getunopr(ls->t.token);
833  if (uop != OPR_NOUNOPR) {
834    luaX_next(ls);
835    subexpr(ls, v, UNARY_PRIORITY);
836    luaK_prefix(ls->fs, uop, v);
837  }
838  else simpleexp(ls, v);
839  /* expand while operators have priorities higher than `limit' */
840  op = getbinopr(ls->t.token);
841  while (op != OPR_NOBINOPR && priority[op].left > limit) {
842    expdesc v2;
843    BinOpr nextop;
844    luaX_next(ls);
845    luaK_infix(ls->fs, op, v);
846    /* read sub-expression with higher priority */
847    nextop = subexpr(ls, &v2, priority[op].right);
848    luaK_posfix(ls->fs, op, v, &v2);
849    op = nextop;
850  }
851  leavelevel(ls);
852  return op;  /* return first untreated operator */
853}
854
855
856static void expr (LexState *ls, expdesc *v) {
857  subexpr(ls, v, 0);
858}
859
860/* }==================================================================== */
861
862
863
864/*
865** {======================================================================
866** Rules for Statements
867** =======================================================================
868*/
869
870
871static int block_follow (int token) {
872  switch (token) {
873    case TK_ELSE: case TK_ELSEIF: case TK_END:
874    case TK_UNTIL: case TK_EOS:
875      return 1;
876    default: return 0;
877  }
878}
879
880
881static void block (LexState *ls) {
882  /* block -> chunk */
883  FuncState *fs = ls->fs;
884  BlockCnt bl;
885  enterblock(fs, &bl, 0);
886  chunk(ls);
887  lua_assert(bl.breaklist == NO_JUMP);
888  leaveblock(fs);
889}
890
891
892/*
893** structure to chain all variables in the left-hand side of an
894** assignment
895*/
896struct LHS_assign {
897  struct LHS_assign *prev;
898  expdesc v;  /* variable (global, local, upvalue, or indexed) */
899};
900
901
902/*
903** check whether, in an assignment to a local variable, the local variable
904** is needed in a previous assignment (to a table). If so, save original
905** local value in a safe place and use this safe copy in the previous
906** assignment.
907*/
908static void check_conflict (LexState *ls, struct LHS_assign *lh, expdesc *v) {
909  FuncState *fs = ls->fs;
910  int extra = fs->freereg;  /* eventual position to save local variable */
911  int conflict = 0;
912  for (; lh; lh = lh->prev) {
913    if (lh->v.k == VINDEXED) {
914      if (lh->v.u.s.info == v->u.s.info) {  /* conflict? */
915        conflict = 1;
916        lh->v.u.s.info = extra;  /* previous assignment will use safe copy */
917      }
918      if (lh->v.u.s.aux == v->u.s.info) {  /* conflict? */
919        conflict = 1;
920        lh->v.u.s.aux = extra;  /* previous assignment will use safe copy */
921      }
922    }
923  }
924  if (conflict) {
925    luaK_codeABC(fs, OP_MOVE, fs->freereg, v->u.s.info, 0);  /* make copy */
926    luaK_reserveregs(fs, 1);
927  }
928}
929
930
931static void assignment (LexState *ls, struct LHS_assign *lh, int nvars) {
932  expdesc e;
933  check_condition(ls, VLOCAL <= lh->v.k && lh->v.k <= VINDEXED,
934                      "syntax error");
935  if (testnext(ls, ',')) {  /* assignment -> `,' primaryexp assignment */
936    struct LHS_assign nv;
937    nv.prev = lh;
938    primaryexp(ls, &nv.v);
939    if (nv.v.k == VLOCAL)
940      check_conflict(ls, lh, &nv.v);
941    luaY_checklimit(ls->fs, nvars, LUAI_MAXCCALLS - ls->L->nCcalls,
942                    "variables in assignment");
943    assignment(ls, &nv, nvars+1);
944  }
945  else {  /* assignment -> `=' explist1 */
946    int nexps;
947    checknext(ls, '=');
948    nexps = explist1(ls, &e);
949    if (nexps != nvars) {
950      adjust_assign(ls, nvars, nexps, &e);
951      if (nexps > nvars)
952        ls->fs->freereg -= nexps - nvars;  /* remove extra values */
953    }
954    else {
955      luaK_setoneret(ls->fs, &e);  /* close last expression */
956      luaK_storevar(ls->fs, &lh->v, &e);
957      return;  /* avoid default */
958    }
959  }
960  init_exp(&e, VNONRELOC, ls->fs->freereg-1);  /* default assignment */
961  luaK_storevar(ls->fs, &lh->v, &e);
962}
963
964
965static int cond (LexState *ls) {
966  /* cond -> exp */
967  expdesc v;
968  expr(ls, &v);  /* read condition */
969  if (v.k == VNIL) v.k = VFALSE;  /* `falses' are all equal here */
970  luaK_goiftrue(ls->fs, &v);
971  return v.f;
972}
973
974
975static void breakstat (LexState *ls) {
976  FuncState *fs = ls->fs;
977  BlockCnt *bl = fs->bl;
978  int upval = 0;
979  while (bl && !bl->isbreakable) {
980    upval |= bl->upval;
981    bl = bl->previous;
982  }
983  if (!bl)
984    luaX_syntaxerror(ls, "no loop to break");
985  if (upval)
986    luaK_codeABC(fs, OP_CLOSE, bl->nactvar, 0, 0);
987  luaK_concat(fs, &bl->breaklist, luaK_jump(fs));
988}
989
990
991static void whilestat (LexState *ls, int line) {
992  /* whilestat -> WHILE cond DO block END */
993  FuncState *fs = ls->fs;
994  int whileinit;
995  int condexit;
996  BlockCnt bl;
997  luaX_next(ls);  /* skip WHILE */
998  whileinit = luaK_getlabel(fs);
999  condexit = cond(ls);
1000  enterblock(fs, &bl, 1);
1001  checknext(ls, TK_DO);
1002  block(ls);
1003  luaK_patchlist(fs, luaK_jump(fs), whileinit);
1004  check_match(ls, TK_END, TK_WHILE, line);
1005  leaveblock(fs);
1006  luaK_patchtohere(fs, condexit);  /* false conditions finish the loop */
1007}
1008
1009
1010static void repeatstat (LexState *ls, int line) {
1011  /* repeatstat -> REPEAT block UNTIL cond */
1012  int condexit;
1013  FuncState *fs = ls->fs;
1014  int repeat_init = luaK_getlabel(fs);
1015  BlockCnt bl1, bl2;
1016  enterblock(fs, &bl1, 1);  /* loop block */
1017  enterblock(fs, &bl2, 0);  /* scope block */
1018  luaX_next(ls);  /* skip REPEAT */
1019  chunk(ls);
1020  check_match(ls, TK_UNTIL, TK_REPEAT, line);
1021  condexit = cond(ls);  /* read condition (inside scope block) */
1022  if (!bl2.upval) {  /* no upvalues? */
1023    leaveblock(fs);  /* finish scope */
1024    luaK_patchlist(ls->fs, condexit, repeat_init);  /* close the loop */
1025  }
1026  else {  /* complete semantics when there are upvalues */
1027    breakstat(ls);  /* if condition then break */
1028    luaK_patchtohere(ls->fs, condexit);  /* else... */
1029    leaveblock(fs);  /* finish scope... */
1030    luaK_patchlist(ls->fs, luaK_jump(fs), repeat_init);  /* and repeat */
1031  }
1032  leaveblock(fs);  /* finish loop */
1033}
1034
1035
1036static int exp1 (LexState *ls) {
1037  expdesc e;
1038  int k;
1039  expr(ls, &e);
1040  k = e.k;
1041  luaK_exp2nextreg(ls->fs, &e);
1042  return k;
1043}
1044
1045
1046static void forbody (LexState *ls, int base, int line, int nvars, int isnum) {
1047  /* forbody -> DO block */
1048  BlockCnt bl;
1049  FuncState *fs = ls->fs;
1050  int prep, endfor;
1051  adjustlocalvars(ls, 3);  /* control variables */
1052  checknext(ls, TK_DO);
1053  prep = isnum ? luaK_codeAsBx(fs, OP_FORPREP, base, NO_JUMP) : luaK_jump(fs);
1054  enterblock(fs, &bl, 0);  /* scope for declared variables */
1055  adjustlocalvars(ls, nvars);
1056  luaK_reserveregs(fs, nvars);
1057  block(ls);
1058  leaveblock(fs);  /* end of scope for declared variables */
1059  luaK_patchtohere(fs, prep);
1060  endfor = (isnum) ? luaK_codeAsBx(fs, OP_FORLOOP, base, NO_JUMP) :
1061                     luaK_codeABC(fs, OP_TFORLOOP, base, 0, nvars);
1062  luaK_fixline(fs, line);  /* pretend that `OP_FOR' starts the loop */
1063  luaK_patchlist(fs, (isnum ? endfor : luaK_jump(fs)), prep + 1);
1064}
1065
1066
1067static void fornum (LexState *ls, TString *varname, int line) {
1068  /* fornum -> NAME = exp1,exp1[,exp1] forbody */
1069  FuncState *fs = ls->fs;
1070  int base = fs->freereg;
1071  new_localvarliteral(ls, "(for index)", 0);
1072  new_localvarliteral(ls, "(for limit)", 1);
1073  new_localvarliteral(ls, "(for step)", 2);
1074  new_localvar(ls, varname, 3);
1075  checknext(ls, '=');
1076  exp1(ls);  /* initial value */
1077  checknext(ls, ',');
1078  exp1(ls);  /* limit */
1079  if (testnext(ls, ','))
1080    exp1(ls);  /* optional step */
1081  else {  /* default step = 1 */
1082    luaK_codeABx(fs, OP_LOADK, fs->freereg, luaK_numberK(fs, 1));
1083    luaK_reserveregs(fs, 1);
1084  }
1085  forbody(ls, base, line, 1, 1);
1086}
1087
1088
1089static void forlist (LexState *ls, TString *indexname) {
1090  /* forlist -> NAME {,NAME} IN explist1 forbody */
1091  FuncState *fs = ls->fs;
1092  expdesc e;
1093  int nvars = 0;
1094  int line;
1095  int base = fs->freereg;
1096  /* create control variables */
1097  new_localvarliteral(ls, "(for generator)", nvars++);
1098  new_localvarliteral(ls, "(for state)", nvars++);
1099  new_localvarliteral(ls, "(for control)", nvars++);
1100  /* create declared variables */
1101  new_localvar(ls, indexname, nvars++);
1102  while (testnext(ls, ','))
1103    new_localvar(ls, str_checkname(ls), nvars++);
1104  checknext(ls, TK_IN);
1105  line = ls->linenumber;
1106  adjust_assign(ls, 3, explist1(ls, &e), &e);
1107  luaK_checkstack(fs, 3);  /* extra space to call generator */
1108  forbody(ls, base, line, nvars - 3, 0);
1109}
1110
1111
1112static void forstat (LexState *ls, int line) {
1113  /* forstat -> FOR (fornum | forlist) END */
1114  FuncState *fs = ls->fs;
1115  TString *varname;
1116  BlockCnt bl;
1117  enterblock(fs, &bl, 1);  /* scope for loop and control variables */
1118  luaX_next(ls);  /* skip `for' */
1119  varname = str_checkname(ls);  /* first variable name */
1120  switch (ls->t.token) {
1121    case '=': fornum(ls, varname, line); break;
1122    case ',': case TK_IN: forlist(ls, varname); break;
1123    default: luaX_syntaxerror(ls, LUA_QL("=") " or " LUA_QL("in") " expected");
1124  }
1125  check_match(ls, TK_END, TK_FOR, line);
1126  leaveblock(fs);  /* loop scope (`break' jumps to this point) */
1127}
1128
1129
1130static int test_then_block (LexState *ls) {
1131  /* test_then_block -> [IF | ELSEIF] cond THEN block */
1132  int condexit;
1133  luaX_next(ls);  /* skip IF or ELSEIF */
1134  condexit = cond(ls);
1135  checknext(ls, TK_THEN);
1136  block(ls);  /* `then' part */
1137  return condexit;
1138}
1139
1140
1141static void ifstat (LexState *ls, int line) {
1142  /* ifstat -> IF cond THEN block {ELSEIF cond THEN block} [ELSE block] END */
1143  FuncState *fs = ls->fs;
1144  int flist;
1145  int escapelist = NO_JUMP;
1146  flist = test_then_block(ls);  /* IF cond THEN block */
1147  while (ls->t.token == TK_ELSEIF) {
1148    luaK_concat(fs, &escapelist, luaK_jump(fs));
1149    luaK_patchtohere(fs, flist);
1150    flist = test_then_block(ls);  /* ELSEIF cond THEN block */
1151  }
1152  if (ls->t.token == TK_ELSE) {
1153    luaK_concat(fs, &escapelist, luaK_jump(fs));
1154    luaK_patchtohere(fs, flist);
1155    luaX_next(ls);  /* skip ELSE (after patch, for correct line info) */
1156    block(ls);  /* `else' part */
1157  }
1158  else
1159    luaK_concat(fs, &escapelist, flist);
1160  luaK_patchtohere(fs, escapelist);
1161  check_match(ls, TK_END, TK_IF, line);
1162}
1163
1164
1165static void localfunc (LexState *ls) {
1166  expdesc v, b;
1167  FuncState *fs = ls->fs;
1168  new_localvar(ls, str_checkname(ls), 0);
1169  init_exp(&v, VLOCAL, fs->freereg);
1170  luaK_reserveregs(fs, 1);
1171  adjustlocalvars(ls, 1);
1172  body(ls, &b, 0, ls->linenumber);
1173  luaK_storevar(fs, &v, &b);
1174  /* debug information will only see the variable after this point! */
1175  getlocvar(fs, fs->nactvar - 1).startpc = fs->pc;
1176}
1177
1178
1179static void localstat (LexState *ls) {
1180  /* stat -> LOCAL NAME {`,' NAME} [`=' explist1] */
1181  int nvars = 0;
1182  int nexps;
1183  expdesc e;
1184  do {
1185    new_localvar(ls, str_checkname(ls), nvars++);
1186  } while (testnext(ls, ','));
1187  if (testnext(ls, '='))
1188    nexps = explist1(ls, &e);
1189  else {
1190    e.k = VVOID;
1191    nexps = 0;
1192  }
1193  adjust_assign(ls, nvars, nexps, &e);
1194  adjustlocalvars(ls, nvars);
1195}
1196
1197
1198static int funcname (LexState *ls, expdesc *v) {
1199  /* funcname -> NAME {field} [`:' NAME] */
1200  int needself = 0;
1201  singlevar(ls, v);
1202  while (ls->t.token == '.')
1203    field(ls, v);
1204  if (ls->t.token == ':') {
1205    needself = 1;
1206    field(ls, v);
1207  }
1208  return needself;
1209}
1210
1211
1212static void funcstat (LexState *ls, int line) {
1213  /* funcstat -> FUNCTION funcname body */
1214  int needself;
1215  expdesc v, b;
1216  luaX_next(ls);  /* skip FUNCTION */
1217  needself = funcname(ls, &v);
1218  body(ls, &b, needself, line);
1219  luaK_storevar(ls->fs, &v, &b);
1220  luaK_fixline(ls->fs, line);  /* definition `happens' in the first line */
1221}
1222
1223
1224static void exprstat (LexState *ls) {
1225  /* stat -> func | assignment */
1226  FuncState *fs = ls->fs;
1227  struct LHS_assign v;
1228  primaryexp(ls, &v.v);
1229  if (v.v.k == VCALL)  /* stat -> func */
1230    SETARG_C(getcode(fs, &v.v), 1);  /* call statement uses no results */
1231  else {  /* stat -> assignment */
1232    v.prev = NULL;
1233    assignment(ls, &v, 1);
1234  }
1235}
1236
1237
1238static void retstat (LexState *ls) {
1239  /* stat -> RETURN explist */
1240  FuncState *fs = ls->fs;
1241  expdesc e;
1242  int first, nret;  /* registers with returned values */
1243  luaX_next(ls);  /* skip RETURN */
1244  if (block_follow(ls->t.token) || ls->t.token == ';')
1245    first = nret = 0;  /* return no values */
1246  else {
1247    nret = explist1(ls, &e);  /* optional return values */
1248    if (hasmultret(e.k)) {
1249      luaK_setmultret(fs, &e);
1250      if (e.k == VCALL && nret == 1) {  /* tail call? */
1251        SET_OPCODE(getcode(fs,&e), OP_TAILCALL);
1252        lua_assert(GETARG_A(getcode(fs,&e)) == fs->nactvar);
1253      }
1254      first = fs->nactvar;
1255      nret = LUA_MULTRET;  /* return all values */
1256    }
1257    else {
1258      if (nret == 1)  /* only one single value? */
1259        first = luaK_exp2anyreg(fs, &e);
1260      else {
1261        luaK_exp2nextreg(fs, &e);  /* values must go to the `stack' */
1262        first = fs->nactvar;  /* return all `active' values */
1263        lua_assert(nret == fs->freereg - first);
1264      }
1265    }
1266  }
1267  luaK_ret(fs, first, nret);
1268}
1269
1270
1271static int statement (LexState *ls) {
1272  int line = ls->linenumber;  /* may be needed for error messages */
1273  switch (ls->t.token) {
1274    case TK_IF: {  /* stat -> ifstat */
1275      ifstat(ls, line);
1276      return 0;
1277    }
1278    case TK_WHILE: {  /* stat -> whilestat */
1279      whilestat(ls, line);
1280      return 0;
1281    }
1282    case TK_DO: {  /* stat -> DO block END */
1283      luaX_next(ls);  /* skip DO */
1284      block(ls);
1285      check_match(ls, TK_END, TK_DO, line);
1286      return 0;
1287    }
1288    case TK_FOR: {  /* stat -> forstat */
1289      forstat(ls, line);
1290      return 0;
1291    }
1292    case TK_REPEAT: {  /* stat -> repeatstat */
1293      repeatstat(ls, line);
1294      return 0;
1295    }
1296    case TK_FUNCTION: {
1297      funcstat(ls, line);  /* stat -> funcstat */
1298      return 0;
1299    }
1300    case TK_LOCAL: {  /* stat -> localstat */
1301      luaX_next(ls);  /* skip LOCAL */
1302      if (testnext(ls, TK_FUNCTION))  /* local function? */
1303        localfunc(ls);
1304      else
1305        localstat(ls);
1306      return 0;
1307    }
1308    case TK_RETURN: {  /* stat -> retstat */
1309      retstat(ls);
1310      return 1;  /* must be last statement */
1311    }
1312    case TK_BREAK: {  /* stat -> breakstat */
1313      luaX_next(ls);  /* skip BREAK */
1314      breakstat(ls);
1315      return 1;  /* must be last statement */
1316    }
1317    default: {
1318      exprstat(ls);
1319      return 0;  /* to avoid warnings */
1320    }
1321  }
1322}
1323
1324
1325static void chunk (LexState *ls) {
1326  /* chunk -> { stat [`;'] } */
1327  int islast = 0;
1328  enterlevel(ls);
1329  while (!islast && !block_follow(ls->t.token)) {
1330    islast = statement(ls);
1331    testnext(ls, ';');
1332    lua_assert(ls->fs->f->maxstacksize >= ls->fs->freereg &&
1333               ls->fs->freereg >= ls->fs->nactvar);
1334    ls->fs->freereg = ls->fs->nactvar;  /* free registers */
1335  }
1336  leavelevel(ls);
1337}
1338
1339/* }====================================================================== */
Note: See TracBrowser for help on using the repository browser.