commit 3e45496295bef65692f690d1633a9ce6ad9408b0
parent e30327728ca4efc3fb8591cf3ea0b65cafbd907a
Author: Roberto Ierusalimschy <roberto@inf.puc-rio.br>
Date: Mon, 3 Apr 2000 10:44:33 -0300
syntactical details
Diffstat:
M | lparser.c | | | 30 | +++++++++++++----------------- |
1 file changed, 13 insertions(+), 17 deletions(-)
diff --git a/lparser.c b/lparser.c
@@ -1,5 +1,5 @@
/*
-** $Id: lparser.c,v 1.73 2000/03/24 17:26:08 roberto Exp roberto $
+** $Id: lparser.c,v 1.74 2000/03/29 20:19:20 roberto Exp roberto $
** LL(1) Parser and code generator for Lua
** See Copyright Notice in lua.h
*/
@@ -901,17 +901,16 @@ static int funcname (LexState *ls, expdesc *v) {
}
-static int funcstat (LexState *ls, int line) {
+static void funcstat (LexState *ls, int line) {
/* funcstat -> FUNCTION funcname body */
int needself;
expdesc v;
if (ls->fs->prev) /* inside other function? */
- return 0;
+ luaK_error(ls, "cannot nest this kind of function declaration");
setline_and_next(ls); /* skip FUNCTION */
needself = funcname(ls, &v);
body(ls, needself, line);
luaK_storevar(ls, &v);
- return 1;
}
@@ -969,42 +968,39 @@ static int stat (LexState *ls) {
case TK_IF: /* stat -> IF ifpart END */
ifpart(ls);
check_END(ls, TK_IF, line);
- return 1;
+ break;
case TK_WHILE: /* stat -> whilestat */
whilestat(ls, line);
- return 1;
+ break;
case TK_DO: { /* stat -> DO block END */
setline_and_next(ls); /* skip DO */
block(ls);
check_END(ls, TK_DO, line);
- return 1;
+ break;
}
case TK_REPEAT: /* stat -> repeatstat */
repeatstat(ls, line);
- return 1;
+ break;
case TK_FUNCTION: /* stat -> funcstat */
- return funcstat(ls, line);
+ funcstat(ls, line);
+ break;
case TK_LOCAL: /* stat -> localstat */
localstat(ls);
- return 1;
+ break;
case TK_NAME: case '%': /* stat -> namestat */
namestat(ls);
- return 1;
-
- case TK_RETURN: case TK_END: case TK_UNTIL:
- case ';': case TK_ELSE: case TK_ELSEIF: case TK_EOS: /* `stat' follow */
- return 0;
+ break;
default:
- error_unexpected(ls);
- return 0; /* to avoid warnings */
+ return 0; /* no statement */
}
+ return 1;
}