diff options
author | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2009-10-11 17:02:19 -0300 |
---|---|---|
committer | Roberto Ierusalimschy <roberto@inf.puc-rio.br> | 2009-10-11 17:02:19 -0300 |
commit | 916587508c117decb2f4d70677fa06be18803874 (patch) | |
tree | 24f930dcb544c9ddb5a15394537b5d7d8e64169e | |
parent | a5382b763c2faa4c47e55ee0e49889b4c47daac4 (diff) | |
download | lua-916587508c117decb2f4d70677fa06be18803874.tar.gz lua-916587508c117decb2f4d70677fa06be18803874.tar.bz2 lua-916587508c117decb2f4d70677fa06be18803874.zip |
parser keeps list of active local variables in a single dynamic array,
therefore saving C stack space
-rw-r--r-- | ldo.c | 10 | ||||
-rw-r--r-- | llex.h | 3 | ||||
-rw-r--r-- | lparser.c | 80 | ||||
-rw-r--r-- | lparser.h | 14 | ||||
-rw-r--r-- | ltests.c | 3 | ||||
-rw-r--r-- | lua.h | 4 | ||||
-rw-r--r-- | luaconf.h | 9 |
7 files changed, 76 insertions, 47 deletions
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: ldo.c,v 2.67 2009/09/14 14:30:39 roberto Exp roberto $ | 2 | ** $Id: ldo.c,v 2.68 2009/09/28 16:32:50 roberto Exp roberto $ |
3 | ** Stack and Call structure of Lua | 3 | ** Stack and Call structure of Lua |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -563,6 +563,7 @@ int luaD_pcall (lua_State *L, Pfunc func, void *u, | |||
563 | struct SParser { /* data to `f_parser' */ | 563 | struct SParser { /* data to `f_parser' */ |
564 | ZIO *z; | 564 | ZIO *z; |
565 | Mbuffer buff; /* buffer to be used by the scanner */ | 565 | Mbuffer buff; /* buffer to be used by the scanner */ |
566 | Varlist varl; /* list of local variables (to be used by the parser) */ | ||
566 | const char *name; | 567 | const char *name; |
567 | }; | 568 | }; |
568 | 569 | ||
@@ -573,8 +574,9 @@ static void f_parser (lua_State *L, void *ud) { | |||
573 | struct SParser *p = cast(struct SParser *, ud); | 574 | struct SParser *p = cast(struct SParser *, ud); |
574 | int c = luaZ_lookahead(p->z); | 575 | int c = luaZ_lookahead(p->z); |
575 | luaC_checkGC(L); | 576 | luaC_checkGC(L); |
576 | tf = (c == LUA_SIGNATURE[0]) ? luaU_undump(L, p->z, &p->buff, p->name) | 577 | tf = (c == LUA_SIGNATURE[0]) |
577 | : luaY_parser(L, p->z, &p->buff, p->name); | 578 | ? luaU_undump(L, p->z, &p->buff, p->name) |
579 | : luaY_parser(L, p->z, &p->buff, &p->varl, p->name); | ||
578 | setptvalue2s(L, L->top, tf); | 580 | setptvalue2s(L, L->top, tf); |
579 | incr_top(L); | 581 | incr_top(L); |
580 | cl = luaF_newLclosure(L, tf->sizeupvalues, hvalue(gt(L))); | 582 | cl = luaF_newLclosure(L, tf->sizeupvalues, hvalue(gt(L))); |
@@ -589,9 +591,11 @@ int luaD_protectedparser (lua_State *L, ZIO *z, const char *name) { | |||
589 | struct SParser p; | 591 | struct SParser p; |
590 | int status; | 592 | int status; |
591 | p.z = z; p.name = name; | 593 | p.z = z; p.name = name; |
594 | p.varl.actvar = NULL; p.varl.nactvar = p.varl.actvarsize = 0; | ||
592 | luaZ_initbuffer(L, &p.buff); | 595 | luaZ_initbuffer(L, &p.buff); |
593 | status = luaD_pcall(L, f_parser, &p, savestack(L, L->top), L->errfunc); | 596 | status = luaD_pcall(L, f_parser, &p, savestack(L, L->top), L->errfunc); |
594 | luaZ_freebuffer(L, &p.buff); | 597 | luaZ_freebuffer(L, &p.buff); |
598 | luaM_freearray(L, p.varl.actvar, p.varl.actvarsize); | ||
595 | return status; | 599 | return status; |
596 | } | 600 | } |
597 | 601 | ||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: llex.h,v 1.60 2007/05/11 17:28:56 roberto Exp roberto $ | 2 | ** $Id: llex.h,v 1.61 2007/10/25 16:45:47 roberto Exp roberto $ |
3 | ** Lexical Analyzer | 3 | ** Lexical Analyzer |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -58,6 +58,7 @@ typedef struct LexState { | |||
58 | struct lua_State *L; | 58 | struct lua_State *L; |
59 | ZIO *z; /* input stream */ | 59 | ZIO *z; /* input stream */ |
60 | Mbuffer *buff; /* buffer for tokens */ | 60 | Mbuffer *buff; /* buffer for tokens */ |
61 | struct Varlist *varl; /* list of all active local variables */ | ||
61 | TString *source; /* current source name */ | 62 | TString *source; /* current source name */ |
62 | char decpoint; /* locale decimal point */ | 63 | char decpoint; /* locale decimal point */ |
63 | } LexState; | 64 | } LexState; |
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lparser.c,v 2.67 2009/09/28 16:32:50 roberto Exp roberto $ | 2 | ** $Id: lparser.c,v 2.68 2009/09/30 15:38:37 roberto Exp roberto $ |
3 | ** Lua Parser | 3 | ** Lua Parser |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -27,9 +27,14 @@ | |||
27 | 27 | ||
28 | 28 | ||
29 | 29 | ||
30 | /* maximum number of local variables per function (must be smaller | ||
31 | than 250, due to the bytecode format) */ | ||
32 | #define MAXVARS 200 | ||
33 | |||
34 | |||
30 | #define hasmultret(k) ((k) == VCALL || (k) == VVARARG) | 35 | #define hasmultret(k) ((k) == VCALL || (k) == VVARARG) |
31 | 36 | ||
32 | #define getlocvar(fs, i) ((fs)->f->locvars[(fs)->actvar[i].idx]) | 37 | |
33 | 38 | ||
34 | #define luaY_checklimit(fs,v,l,m) if ((v)>(l)) errorlimit(fs,l,m) | 39 | #define luaY_checklimit(fs,v,l,m) if ((v)>(l)) errorlimit(fs,l,m) |
35 | 40 | ||
@@ -157,15 +162,26 @@ static int registerlocalvar (LexState *ls, TString *varname) { | |||
157 | } | 162 | } |
158 | 163 | ||
159 | 164 | ||
160 | #define new_localvarliteral(ls,v,n) \ | 165 | #define new_localvarliteral(ls,v) \ |
161 | new_localvar(ls, luaX_newstring(ls, "" v, (sizeof(v)/sizeof(char))-1), n) | 166 | new_localvar(ls, luaX_newstring(ls, "" v, (sizeof(v)/sizeof(char))-1)) |
162 | 167 | ||
163 | 168 | ||
164 | static void new_localvar (LexState *ls, TString *name, int n) { | 169 | static void new_localvar (LexState *ls, TString *name) { |
165 | FuncState *fs = ls->fs; | 170 | FuncState *fs = ls->fs; |
171 | Varlist *vl = ls->varl; | ||
166 | int reg = registerlocalvar(ls, name); | 172 | int reg = registerlocalvar(ls, name); |
167 | luaY_checklimit(fs, fs->nactvar+n+1, LUAI_MAXVARS, "local variables"); | 173 | luaY_checklimit(fs, vl->nactvar + 1 - fs->firstlocal, |
168 | fs->actvar[fs->nactvar+n].idx = cast(unsigned short, reg); | 174 | MAXVARS, "local variables"); |
175 | luaM_growvector(ls->L, vl->actvar, vl->nactvar + 1, | ||
176 | vl->actvarsize, vardesc, MAX_INT, "local variables"); | ||
177 | vl->actvar[vl->nactvar++].idx = cast(unsigned short, reg); | ||
178 | } | ||
179 | |||
180 | |||
181 | static LocVar *getlocvar (FuncState *fs, int i) { | ||
182 | int idx = fs->ls->varl->actvar[fs->firstlocal + i].idx; | ||
183 | lua_assert(idx < fs->nlocvars); | ||
184 | return &fs->f->locvars[idx]; | ||
169 | } | 185 | } |
170 | 186 | ||
171 | 187 | ||
@@ -173,14 +189,15 @@ static void adjustlocalvars (LexState *ls, int nvars) { | |||
173 | FuncState *fs = ls->fs; | 189 | FuncState *fs = ls->fs; |
174 | fs->nactvar = cast_byte(fs->nactvar + nvars); | 190 | fs->nactvar = cast_byte(fs->nactvar + nvars); |
175 | for (; nvars; nvars--) { | 191 | for (; nvars; nvars--) { |
176 | getlocvar(fs, fs->nactvar - nvars).startpc = fs->pc; | 192 | getlocvar(fs, fs->nactvar - nvars)->startpc = fs->pc; |
177 | } | 193 | } |
178 | } | 194 | } |
179 | 195 | ||
180 | 196 | ||
181 | static void removevars (FuncState *fs, int tolevel) { | 197 | static void removevars (FuncState *fs, int tolevel) { |
198 | fs->ls->varl->nactvar -= (fs->nactvar - tolevel); | ||
182 | while (fs->nactvar > tolevel) | 199 | while (fs->nactvar > tolevel) |
183 | getlocvar(fs, --fs->nactvar).endpc = fs->pc; | 200 | getlocvar(fs, --fs->nactvar)->endpc = fs->pc; |
184 | } | 201 | } |
185 | 202 | ||
186 | 203 | ||
@@ -212,7 +229,7 @@ static int indexupvalue (FuncState *fs, TString *name, expdesc *v) { | |||
212 | static int searchvar (FuncState *fs, TString *n) { | 229 | static int searchvar (FuncState *fs, TString *n) { |
213 | int i; | 230 | int i; |
214 | for (i=fs->nactvar-1; i >= 0; i--) { | 231 | for (i=fs->nactvar-1; i >= 0; i--) { |
215 | if (n == getlocvar(fs, i).varname) | 232 | if (n == getlocvar(fs, i)->varname) |
216 | return i; | 233 | return i; |
217 | } | 234 | } |
218 | return -1; /* not found */ | 235 | return -1; /* not found */ |
@@ -350,6 +367,7 @@ static void open_func (LexState *ls, FuncState *fs) { | |||
350 | fs->nups = 0; | 367 | fs->nups = 0; |
351 | fs->nlocvars = 0; | 368 | fs->nlocvars = 0; |
352 | fs->nactvar = 0; | 369 | fs->nactvar = 0; |
370 | fs->firstlocal = ls->varl->nactvar; | ||
353 | fs->envreg = NO_REG; | 371 | fs->envreg = NO_REG; |
354 | fs->bl = NULL; | 372 | fs->bl = NULL; |
355 | fs->h = luaH_new(L); | 373 | fs->h = luaH_new(L); |
@@ -392,13 +410,15 @@ static void close_func (LexState *ls) { | |||
392 | } | 410 | } |
393 | 411 | ||
394 | 412 | ||
395 | Proto *luaY_parser (lua_State *L, ZIO *z, Mbuffer *buff, const char *name) { | 413 | Proto *luaY_parser (lua_State *L, ZIO *z, Mbuffer *buff, Varlist *varl, |
414 | const char *name) { | ||
396 | struct LexState lexstate; | 415 | struct LexState lexstate; |
397 | struct FuncState funcstate; | 416 | struct FuncState funcstate; |
398 | TString *tname = luaS_new(L, name); | 417 | TString *tname = luaS_new(L, name); |
399 | setsvalue2s(L, L->top, tname); /* protect name */ | 418 | setsvalue2s(L, L->top, tname); /* protect name */ |
400 | incr_top(L); | 419 | incr_top(L); |
401 | lexstate.buff = buff; | 420 | lexstate.buff = buff; |
421 | lexstate.varl = varl; | ||
402 | luaX_setinput(L, &lexstate, z, tname); | 422 | luaX_setinput(L, &lexstate, z, tname); |
403 | open_func(&lexstate, &funcstate); | 423 | open_func(&lexstate, &funcstate); |
404 | funcstate.f->is_vararg = 1; /* main func. is always vararg */ | 424 | funcstate.f->is_vararg = 1; /* main func. is always vararg */ |
@@ -565,7 +585,8 @@ static void parlist (LexState *ls) { | |||
565 | do { | 585 | do { |
566 | switch (ls->t.token) { | 586 | switch (ls->t.token) { |
567 | case TK_NAME: { /* param -> NAME */ | 587 | case TK_NAME: { /* param -> NAME */ |
568 | new_localvar(ls, str_checkname(ls), nparams++); | 588 | new_localvar(ls, str_checkname(ls)); |
589 | nparams++; | ||
569 | break; | 590 | break; |
570 | } | 591 | } |
571 | case TK_DOTS: { /* param -> `...' */ | 592 | case TK_DOTS: { /* param -> `...' */ |
@@ -590,7 +611,7 @@ static void body (LexState *ls, expdesc *e, int needself, int line) { | |||
590 | new_fs.f->linedefined = line; | 611 | new_fs.f->linedefined = line; |
591 | checknext(ls, '('); | 612 | checknext(ls, '('); |
592 | if (needself) { | 613 | if (needself) { |
593 | new_localvarliteral(ls, "self", 0); | 614 | new_localvarliteral(ls, "self"); |
594 | adjustlocalvars(ls, 1); | 615 | adjustlocalvars(ls, 1); |
595 | } | 616 | } |
596 | parlist(ls); | 617 | parlist(ls); |
@@ -1083,10 +1104,10 @@ static void fornum (LexState *ls, TString *varname, int line) { | |||
1083 | /* fornum -> NAME = exp1,exp1[,exp1] forbody */ | 1104 | /* fornum -> NAME = exp1,exp1[,exp1] forbody */ |
1084 | FuncState *fs = ls->fs; | 1105 | FuncState *fs = ls->fs; |
1085 | int base = fs->freereg; | 1106 | int base = fs->freereg; |
1086 | new_localvarliteral(ls, "(for index)", 0); | 1107 | new_localvarliteral(ls, "(for index)"); |
1087 | new_localvarliteral(ls, "(for limit)", 1); | 1108 | new_localvarliteral(ls, "(for limit)"); |
1088 | new_localvarliteral(ls, "(for step)", 2); | 1109 | new_localvarliteral(ls, "(for step)"); |
1089 | new_localvar(ls, varname, 3); | 1110 | new_localvar(ls, varname); |
1090 | checknext(ls, '='); | 1111 | checknext(ls, '='); |
1091 | exp1(ls); /* initial value */ | 1112 | exp1(ls); /* initial value */ |
1092 | checknext(ls, ','); | 1113 | checknext(ls, ','); |
@@ -1105,17 +1126,19 @@ static void forlist (LexState *ls, TString *indexname) { | |||
1105 | /* forlist -> NAME {,NAME} IN explist1 forbody */ | 1126 | /* forlist -> NAME {,NAME} IN explist1 forbody */ |
1106 | FuncState *fs = ls->fs; | 1127 | FuncState *fs = ls->fs; |
1107 | expdesc e; | 1128 | expdesc e; |
1108 | int nvars = 0; | 1129 | int nvars = 4; /* gen, state, control, plus at least one declared var */ |
1109 | int line; | 1130 | int line; |
1110 | int base = fs->freereg; | 1131 | int base = fs->freereg; |
1111 | /* create control variables */ | 1132 | /* create control variables */ |
1112 | new_localvarliteral(ls, "(for generator)", nvars++); | 1133 | new_localvarliteral(ls, "(for generator)"); |
1113 | new_localvarliteral(ls, "(for state)", nvars++); | 1134 | new_localvarliteral(ls, "(for state)"); |
1114 | new_localvarliteral(ls, "(for control)", nvars++); | 1135 | new_localvarliteral(ls, "(for control)"); |
1115 | /* create declared variables */ | 1136 | /* create declared variables */ |
1116 | new_localvar(ls, indexname, nvars++); | 1137 | new_localvar(ls, indexname); |
1117 | while (testnext(ls, ',')) | 1138 | while (testnext(ls, ',')) { |
1118 | new_localvar(ls, str_checkname(ls), nvars++); | 1139 | new_localvar(ls, str_checkname(ls)); |
1140 | nvars++; | ||
1141 | } | ||
1119 | checknext(ls, TK_IN); | 1142 | checknext(ls, TK_IN); |
1120 | line = ls->linenumber; | 1143 | line = ls->linenumber; |
1121 | adjust_assign(ls, 3, explist1(ls, &e), &e); | 1144 | adjust_assign(ls, 3, explist1(ls, &e), &e); |
@@ -1180,14 +1203,14 @@ static void ifstat (LexState *ls, int line) { | |||
1180 | static void localfunc (LexState *ls) { | 1203 | static void localfunc (LexState *ls) { |
1181 | expdesc v, b; | 1204 | expdesc v, b; |
1182 | FuncState *fs = ls->fs; | 1205 | FuncState *fs = ls->fs; |
1183 | new_localvar(ls, str_checkname(ls), 0); | 1206 | new_localvar(ls, str_checkname(ls)); |
1184 | init_exp(&v, VLOCAL, fs->freereg); | 1207 | init_exp(&v, VLOCAL, fs->freereg); |
1185 | luaK_reserveregs(fs, 1); | 1208 | luaK_reserveregs(fs, 1); |
1186 | adjustlocalvars(ls, 1); | 1209 | adjustlocalvars(ls, 1); |
1187 | body(ls, &b, 0, ls->linenumber); | 1210 | body(ls, &b, 0, ls->linenumber); |
1188 | luaK_storevar(fs, &v, &b); | 1211 | luaK_storevar(fs, &v, &b); |
1189 | /* debug information will only see the variable after this point! */ | 1212 | /* debug information will only see the variable after this point! */ |
1190 | getlocvar(fs, fs->nactvar - 1).startpc = fs->pc; | 1213 | getlocvar(fs, fs->nactvar - 1)->startpc = fs->pc; |
1191 | } | 1214 | } |
1192 | 1215 | ||
1193 | 1216 | ||
@@ -1197,7 +1220,8 @@ static void localstat (LexState *ls) { | |||
1197 | int nexps; | 1220 | int nexps; |
1198 | expdesc e; | 1221 | expdesc e; |
1199 | do { | 1222 | do { |
1200 | new_localvar(ls, str_checkname(ls), nvars++); | 1223 | new_localvar(ls, str_checkname(ls)); |
1224 | nvars++; | ||
1201 | } while (testnext(ls, ',')); | 1225 | } while (testnext(ls, ',')); |
1202 | if (testnext(ls, '=')) | 1226 | if (testnext(ls, '=')) |
1203 | nexps = explist1(ls, &e); | 1227 | nexps = explist1(ls, &e); |
@@ -1243,7 +1267,7 @@ static void instat (LexState *ls, int line) { | |||
1243 | BlockCnt bl; | 1267 | BlockCnt bl; |
1244 | luaX_next(ls); /* skip IN */ | 1268 | luaX_next(ls); /* skip IN */ |
1245 | enterblock(fs, &bl, 0); /* scope for environment variable */ | 1269 | enterblock(fs, &bl, 0); /* scope for environment variable */ |
1246 | new_localvarliteral(ls, "(environment)", 0); | 1270 | new_localvarliteral(ls, "(environment)"); |
1247 | fs->envreg = exp1(ls); /* new environment */ | 1271 | fs->envreg = exp1(ls); /* new environment */ |
1248 | adjustlocalvars(ls, 1); | 1272 | adjustlocalvars(ls, 1); |
1249 | checknext(ls, TK_DO); | 1273 | checknext(ls, TK_DO); |
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lparser.h,v 1.59 2009/09/28 16:32:50 roberto Exp roberto $ | 2 | ** $Id: lparser.h,v 1.60 2009/09/30 15:38:37 roberto Exp roberto $ |
3 | ** Lua Parser | 3 | ** Lua Parser |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -51,6 +51,14 @@ typedef struct vardesc { | |||
51 | } vardesc; | 51 | } vardesc; |
52 | 52 | ||
53 | 53 | ||
54 | /* list of all active local variables */ | ||
55 | typedef struct Varlist { | ||
56 | vardesc *actvar; | ||
57 | int nactvar; | ||
58 | int actvarsize; | ||
59 | } Varlist; | ||
60 | |||
61 | |||
54 | struct BlockCnt; /* defined in lparser.c */ | 62 | struct BlockCnt; /* defined in lparser.c */ |
55 | 63 | ||
56 | 64 | ||
@@ -68,16 +76,16 @@ typedef struct FuncState { | |||
68 | int freereg; /* first free register */ | 76 | int freereg; /* first free register */ |
69 | int nk; /* number of elements in `k' */ | 77 | int nk; /* number of elements in `k' */ |
70 | int np; /* number of elements in `p' */ | 78 | int np; /* number of elements in `p' */ |
79 | int firstlocal; /* index of first local var of this function */ | ||
71 | short nlocvars; /* number of elements in `locvars' */ | 80 | short nlocvars; /* number of elements in `locvars' */ |
72 | lu_byte nactvar; /* number of active local variables */ | 81 | lu_byte nactvar; /* number of active local variables */ |
73 | lu_byte nups; /* number of upvalues */ | 82 | lu_byte nups; /* number of upvalues */ |
74 | lu_byte envreg; /* register holding current lexical environment */ | 83 | lu_byte envreg; /* register holding current lexical environment */ |
75 | vardesc actvar[LUAI_MAXVARS]; /* stack of active variables */ | ||
76 | } FuncState; | 84 | } FuncState; |
77 | 85 | ||
78 | 86 | ||
79 | LUAI_FUNC Proto *luaY_parser (lua_State *L, ZIO *z, Mbuffer *buff, | 87 | LUAI_FUNC Proto *luaY_parser (lua_State *L, ZIO *z, Mbuffer *buff, |
80 | const char *name); | 88 | Varlist *varl, const char *name); |
81 | 89 | ||
82 | 90 | ||
83 | #endif | 91 | #endif |
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: ltests.c,v 2.74 2009/09/30 20:49:25 roberto Exp roberto $ | 2 | ** $Id: ltests.c,v 2.75 2009/10/05 16:44:33 roberto Exp roberto $ |
3 | ** Internal Module for Debugging of the Lua Implementation | 3 | ** Internal Module for Debugging of the Lua Implementation |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -491,7 +491,6 @@ static int get_limits (lua_State *L) { | |||
491 | lua_createtable(L, 0, 5); | 491 | lua_createtable(L, 0, 5); |
492 | setnameval(L, "BITS_INT", LUAI_BITSINT); | 492 | setnameval(L, "BITS_INT", LUAI_BITSINT); |
493 | setnameval(L, "LFPF", LFIELDS_PER_FLUSH); | 493 | setnameval(L, "LFPF", LFIELDS_PER_FLUSH); |
494 | setnameval(L, "MAXVARS", LUAI_MAXVARS); | ||
495 | setnameval(L, "MAXSTACK", MAXSTACK); | 494 | setnameval(L, "MAXSTACK", MAXSTACK); |
496 | setnameval(L, "NUM_OPCODES", NUM_OPCODES); | 495 | setnameval(L, "NUM_OPCODES", NUM_OPCODES); |
497 | return 1; | 496 | return 1; |
@@ -1,6 +1,6 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: lua.h,v 1.244 2009/09/21 12:09:52 roberto Exp roberto $ | 2 | ** $Id: lua.h,v 1.245 2009/10/05 16:44:33 roberto Exp roberto $ |
3 | ** Lua - An Extensible Extension Language | 3 | ** Lua - A Scripting Language |
4 | ** Lua.org, PUC-Rio, Brazil (http://www.lua.org) | 4 | ** Lua.org, PUC-Rio, Brazil (http://www.lua.org) |
5 | ** See Copyright Notice at the end of this file | 5 | ** See Copyright Notice at the end of this file |
6 | */ | 6 | */ |
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | ** $Id: luaconf.h,v 1.109 2009/08/25 19:58:08 roberto Exp roberto $ | 2 | ** $Id: luaconf.h,v 1.110 2009/09/28 16:32:50 roberto Exp roberto $ |
3 | ** Configuration file for Lua | 3 | ** Configuration file for Lua |
4 | ** See Copyright Notice in lua.h | 4 | ** See Copyright Notice in lua.h |
5 | */ | 5 | */ |
@@ -455,13 +455,6 @@ | |||
455 | 455 | ||
456 | 456 | ||
457 | /* | 457 | /* |
458 | @@ LUAI_MAXVARS is the maximum number of local variables per function | ||
459 | @* (must be smaller than 250). | ||
460 | */ | ||
461 | #define LUAI_MAXVARS 200 | ||
462 | |||
463 | |||
464 | /* | ||
465 | @@ LUAL_BUFFERSIZE is the buffer size used by the lauxlib buffer system. | 458 | @@ LUAL_BUFFERSIZE is the buffer size used by the lauxlib buffer system. |
466 | */ | 459 | */ |
467 | #define LUAL_BUFFERSIZE BUFSIZ | 460 | #define LUAL_BUFFERSIZE BUFSIZ |