ref: b4fb12662da6de2f9853162572f4907b39943870
parent: 0ac4cce8b0cb0f052c871576b4fb394b414504a7
author: Tor Andersson <[email protected]>
date: Fri Jan 2 08:39:56 EST 2015
Rename next/accept/expect macros in lexer and parser. Make the names regular, and don't conflict with libc function accept().
--- a/jslex.c
+++ b/jslex.c
@@ -149,11 +149,6 @@
return 0;
}
-#define PEEK (J->lexchar)
-#define NEXT() jsY_next(J)
-#define ACCEPT(x) (PEEK == x ? (NEXT(), 1) : 0)
-#define EXPECT(x) if (!ACCEPT(x)) jsY_error(J, "expected '%c'", x)
-
static void jsY_next(js_State *J)
{
Rune c;
@@ -168,15 +163,19 @@
J->lexchar = c;
}
+#define jsY_accept(J, x) (J->lexchar == x ? (jsY_next(J), 1) : 0)
+
+#define jsY_expect(J, x) if (!jsY_accept(J, x)) jsY_error(J, "expected '%c'", x)
+
static void jsY_unescape(js_State *J)
{
- if (ACCEPT('\\')) {
- if (ACCEPT('u')) {
+ if (jsY_accept(J, '\\')) {
+ if (jsY_accept(J, 'u')) {
int x = 0;
- if (!jsY_ishex(PEEK)) goto error; x |= jsY_tohex(PEEK) << 12; NEXT();
- if (!jsY_ishex(PEEK)) goto error; x |= jsY_tohex(PEEK) << 8; NEXT();
- if (!jsY_ishex(PEEK)) goto error; x |= jsY_tohex(PEEK) << 4; NEXT();
- if (!jsY_ishex(PEEK)) goto error; x |= jsY_tohex(PEEK);
+ if (!jsY_ishex(J->lexchar)) goto error; x |= jsY_tohex(J->lexchar) << 12; jsY_next(J);
+ if (!jsY_ishex(J->lexchar)) goto error; x |= jsY_tohex(J->lexchar) << 8; jsY_next(J);
+ if (!jsY_ishex(J->lexchar)) goto error; x |= jsY_tohex(J->lexchar) << 4; jsY_next(J);
+ if (!jsY_ishex(J->lexchar)) goto error; x |= jsY_tohex(J->lexchar);
J->lexchar = x;
return;
}
@@ -212,21 +211,21 @@
static void lexlinecomment(js_State *J)
{
- while (PEEK && PEEK != '\n')
- NEXT();
+ while (J->lexchar && J->lexchar != '\n')
+ jsY_next(J);
}
static int lexcomment(js_State *J)
{
/* already consumed initial '/' '*' sequence */
- while (PEEK != 0) {
- if (ACCEPT('*')) {
- while (PEEK == '*')
- NEXT();
- if (ACCEPT('/'))
+ while (J->lexchar != 0) {
+ if (jsY_accept(J, '*')) {
+ while (J->lexchar == '*')
+ jsY_next(J);
+ if (jsY_accept(J, '/'))
return 0;
}
- NEXT();
+ jsY_next(J);
}
return -1;
}
@@ -234,11 +233,11 @@
static double lexhex(js_State *J)
{
double n = 0;
- if (!jsY_ishex(PEEK))
+ if (!jsY_ishex(J->lexchar))
jsY_error(J, "malformed hexadecimal number");
- while (jsY_ishex(PEEK)) {
- n = n * 16 + jsY_tohex(PEEK);
- NEXT();
+ while (jsY_ishex(J->lexchar)) {
+ n = n * 16 + jsY_tohex(J->lexchar);
+ jsY_next(J);
}
return n;
}
@@ -248,11 +247,11 @@
static double lexinteger(js_State *J)
{
double n = 0;
- if (!jsY_isdec(PEEK))
+ if (!jsY_isdec(J->lexchar))
jsY_error(J, "malformed number");
- while (jsY_isdec(PEEK)) {
- n = n * 10 + (PEEK - '0');
- NEXT();
+ while (jsY_isdec(J->lexchar)) {
+ n = n * 10 + (J->lexchar - '0');
+ jsY_next(J);
}
return n;
}
@@ -261,10 +260,10 @@
{
double n = 0;
double d = 1;
- while (jsY_isdec(PEEK)) {
- n = n * 10 + (PEEK - '0');
+ while (jsY_isdec(J->lexchar)) {
+ n = n * 10 + (J->lexchar - '0');
d = d * 10;
- NEXT();
+ jsY_next(J);
}
return n / d;
}
@@ -272,9 +271,9 @@
static double lexexponent(js_State *J)
{
double sign;
- if (ACCEPT('e') || ACCEPT('E')) {
- if (ACCEPT('-')) sign = -1;
- else if (ACCEPT('+')) sign = 1;
+ if (jsY_accept(J, 'e') || jsY_accept(J, 'E')) {
+ if (jsY_accept(J, '-')) sign = -1;
+ else if (jsY_accept(J, '+')) sign = 1;
else sign = 1;
return sign * lexinteger(J);
}
@@ -286,23 +285,23 @@
double n;
double e;
- if (ACCEPT('0')) {
- if (ACCEPT('x') || ACCEPT('X')) {
+ if (jsY_accept(J, '0')) {
+ if (jsY_accept(J, 'x') || jsY_accept(J, 'X')) {
J->number = lexhex(J);
return TK_NUMBER;
}
- if (jsY_isdec(PEEK))
+ if (jsY_isdec(J->lexchar))
jsY_error(J, "number with leading zero");
n = 0;
- if (ACCEPT('.'))
+ if (jsY_accept(J, '.'))
n += lexfraction(J);
- } else if (ACCEPT('.')) {
- if (!jsY_isdec(PEEK))
+ } else if (jsY_accept(J, '.')) {
+ if (!jsY_isdec(J->lexchar))
return '.';
n = lexfraction(J);
} else {
n = lexinteger(J);
- if (ACCEPT('.'))
+ if (jsY_accept(J, '.'))
n += lexfraction(J);
}
@@ -312,7 +311,7 @@
else if (e > 0)
n *= pow(10, e);
- if (jsY_isidentifierstart(PEEK))
+ if (jsY_isidentifierstart(J->lexchar))
jsY_error(J, "number with letter suffix");
J->number = n;
@@ -325,39 +324,39 @@
{
const char *s = J->source - 1;
- if (ACCEPT('0')) {
- if (ACCEPT('x') || ACCEPT('X')) {
+ if (jsY_accept(J, '0')) {
+ if (jsY_accept(J, 'x') || jsY_accept(J, 'X')) {
J->number = lexhex(J);
return TK_NUMBER;
}
- if (jsY_isdec(PEEK))
+ if (jsY_isdec(J->lexchar))
jsY_error(J, "number with leading zero");
- if (ACCEPT('.')) {
- while (jsY_isdec(PEEK))
- NEXT();
+ if (jsY_accept(J, '.')) {
+ while (jsY_isdec(J->lexchar))
+ jsY_next(J);
}
- } else if (ACCEPT('.')) {
- if (!jsY_isdec(PEEK))
+ } else if (jsY_accept(J, '.')) {
+ if (!jsY_isdec(J->lexchar))
return '.';
- while (jsY_isdec(PEEK))
- NEXT();
+ while (jsY_isdec(J->lexchar))
+ jsY_next(J);
} else {
- while (jsY_isdec(PEEK))
- NEXT();
- if (ACCEPT('.')) {
- while (jsY_isdec(PEEK))
- NEXT();
+ while (jsY_isdec(J->lexchar))
+ jsY_next(J);
+ if (jsY_accept(J, '.')) {
+ while (jsY_isdec(J->lexchar))
+ jsY_next(J);
}
}
- if (ACCEPT('e') || ACCEPT('E')) {
- if (PEEK == '-' || PEEK == '+')
- NEXT();
- while (jsY_isdec(PEEK))
- NEXT();
+ if (jsY_accept(J, 'e') || jsY_accept(J, 'E')) {
+ if (J->lexchar == '-' || J->lexchar == '+')
+ jsY_next(J);
+ while (jsY_isdec(J->lexchar))
+ jsY_next(J);
}
- if (jsY_isidentifierstart(PEEK))
+ if (jsY_isidentifierstart(J->lexchar))
jsY_error(J, "number with letter suffix");
J->number = js_strtod(s, NULL);
@@ -373,35 +372,35 @@
/* already consumed '\' */
- if (ACCEPT('\n'))
+ if (jsY_accept(J, '\n'))
return 0;
- switch (PEEK) {
+ switch (J->lexchar) {
case 'u':
- NEXT();
- if (!jsY_ishex(PEEK)) return 1; else { x |= jsY_tohex(PEEK) << 12; NEXT(); }
- if (!jsY_ishex(PEEK)) return 1; else { x |= jsY_tohex(PEEK) << 8; NEXT(); }
- if (!jsY_ishex(PEEK)) return 1; else { x |= jsY_tohex(PEEK) << 4; NEXT(); }
- if (!jsY_ishex(PEEK)) return 1; else { x |= jsY_tohex(PEEK); NEXT(); }
+ jsY_next(J);
+ if (!jsY_ishex(J->lexchar)) return 1; else { x |= jsY_tohex(J->lexchar) << 12; jsY_next(J); }
+ if (!jsY_ishex(J->lexchar)) return 1; else { x |= jsY_tohex(J->lexchar) << 8; jsY_next(J); }
+ if (!jsY_ishex(J->lexchar)) return 1; else { x |= jsY_tohex(J->lexchar) << 4; jsY_next(J); }
+ if (!jsY_ishex(J->lexchar)) return 1; else { x |= jsY_tohex(J->lexchar); jsY_next(J); }
textpush(J, x);
break;
case 'x':
- NEXT();
- if (!jsY_ishex(PEEK)) return 1; else { x |= jsY_tohex(PEEK) << 4; NEXT(); }
- if (!jsY_ishex(PEEK)) return 1; else { x |= jsY_tohex(PEEK); NEXT(); }
+ jsY_next(J);
+ if (!jsY_ishex(J->lexchar)) return 1; else { x |= jsY_tohex(J->lexchar) << 4; jsY_next(J); }
+ if (!jsY_ishex(J->lexchar)) return 1; else { x |= jsY_tohex(J->lexchar); jsY_next(J); }
textpush(J, x);
break;
- case '0': textpush(J, 0); NEXT(); break;
- case '\\': textpush(J, '\\'); NEXT(); break;
- case '\'': textpush(J, '\''); NEXT(); break;
- case '"': textpush(J, '"'); NEXT(); break;
- case 'b': textpush(J, '\b'); NEXT(); break;
- case 'f': textpush(J, '\f'); NEXT(); break;
- case 'n': textpush(J, '\n'); NEXT(); break;
- case 'r': textpush(J, '\r'); NEXT(); break;
- case 't': textpush(J, '\t'); NEXT(); break;
- case 'v': textpush(J, '\v'); NEXT(); break;
- default: textpush(J, PEEK); NEXT(); break;
+ case '0': textpush(J, 0); jsY_next(J); break;
+ case '\\': textpush(J, '\\'); jsY_next(J); break;
+ case '\'': textpush(J, '\''); jsY_next(J); break;
+ case '"': textpush(J, '"'); jsY_next(J); break;
+ case 'b': textpush(J, '\b'); jsY_next(J); break;
+ case 'f': textpush(J, '\f'); jsY_next(J); break;
+ case 'n': textpush(J, '\n'); jsY_next(J); break;
+ case 'r': textpush(J, '\r'); jsY_next(J); break;
+ case 't': textpush(J, '\t'); jsY_next(J); break;
+ case 'v': textpush(J, '\v'); jsY_next(J); break;
+ default: textpush(J, J->lexchar); jsY_next(J); break;
}
return 0;
}
@@ -410,23 +409,23 @@
{
const char *s;
- int q = PEEK;
- NEXT();
+ int q = J->lexchar;
+ jsY_next(J);
textinit(J);
- while (PEEK != q) {
- if (PEEK == 0 || PEEK == '\n')
+ while (J->lexchar != q) {
+ if (J->lexchar == 0 || J->lexchar == '\n')
jsY_error(J, "string not terminated");
- if (ACCEPT('\\')) {
+ if (jsY_accept(J, '\\')) {
if (lexescape(J))
jsY_error(J, "malformed escape sequence");
} else {
- textpush(J, PEEK);
- NEXT();
+ textpush(J, J->lexchar);
+ jsY_next(J);
}
}
- EXPECT(q);
+ jsY_expect(J, q);
s = textend(J);
@@ -465,29 +464,29 @@
textinit(J);
/* regexp body */
- while (PEEK != '/' || inclass) {
- if (PEEK == 0 || PEEK == '\n') {
+ while (J->lexchar != '/' || inclass) {
+ if (J->lexchar == 0 || J->lexchar == '\n') {
jsY_error(J, "regular expression not terminated");
- } else if (ACCEPT('\\')) {
- if (ACCEPT('/')) {
+ } else if (jsY_accept(J, '\\')) {
+ if (jsY_accept(J, '/')) {
textpush(J, '/');
} else {
textpush(J, '\\');
- if (PEEK == 0 || PEEK == '\n')
+ if (J->lexchar == 0 || J->lexchar == '\n')
jsY_error(J, "regular expression not terminated");
- textpush(J, PEEK);
- NEXT();
+ textpush(J, J->lexchar);
+ jsY_next(J);
}
} else {
- if (PEEK == '[' && !inclass)
+ if (J->lexchar == '[' && !inclass)
inclass = 1;
- if (PEEK == ']' && inclass)
+ if (J->lexchar == ']' && inclass)
inclass = 0;
- textpush(J, PEEK);
- NEXT();
+ textpush(J, J->lexchar);
+ jsY_next(J);
}
}
- EXPECT('/');
+ jsY_expect(J, '/');
s = textend(J);
@@ -494,11 +493,11 @@
/* regexp flags */
g = i = m = 0;
- while (jsY_isidentifierpart(PEEK)) {
- if (ACCEPT('g')) ++g;
- else if (ACCEPT('i')) ++i;
- else if (ACCEPT('m')) ++m;
- else jsY_error(J, "illegal flag in regular expression: %c", PEEK);
+ while (jsY_isidentifierpart(J->lexchar)) {
+ if (jsY_accept(J, 'g')) ++g;
+ else if (jsY_accept(J, 'i')) ++i;
+ else if (jsY_accept(J, 'm')) ++m;
+ else jsY_error(J, "illegal flag in regular expression: %c", J->lexchar);
}
if (g > 1 || i > 1 || m > 1)
@@ -533,10 +532,10 @@
while (1) {
J->lexline = J->line; /* save location of beginning of token */
- while (jsY_iswhite(PEEK))
- NEXT();
+ while (jsY_iswhite(J->lexchar))
+ jsY_next(J);
- if (ACCEPT('\n')) {
+ if (jsY_accept(J, '\n')) {
J->newline = 1;
if (isnlthcontext(J->lasttoken))
return ';';
@@ -543,17 +542,17 @@
continue;
}
- if (ACCEPT('/')) {
- if (ACCEPT('/')) {
+ if (jsY_accept(J, '/')) {
+ if (jsY_accept(J, '/')) {
lexlinecomment(J);
continue;
- } else if (ACCEPT('*')) {
+ } else if (jsY_accept(J, '*')) {
if (lexcomment(J))
jsY_error(J, "multi-line comment not terminated");
continue;
} else if (isregexpcontext(J->lasttoken)) {
return lexregexp(J);
- } else if (ACCEPT('=')) {
+ } else if (jsY_accept(J, '=')) {
return TK_DIV_ASS;
} else {
return '/';
@@ -560,22 +559,22 @@
}
}
- if (PEEK >= '0' && PEEK <= '9') {
+ if (J->lexchar >= '0' && J->lexchar <= '9') {
return lexnumber(J);
}
- switch (PEEK) {
- case '(': NEXT(); return '(';
- case ')': NEXT(); return ')';
- case ',': NEXT(); return ',';
- case ':': NEXT(); return ':';
- case ';': NEXT(); return ';';
- case '?': NEXT(); return '?';
- case '[': NEXT(); return '[';
- case ']': NEXT(); return ']';
- case '{': NEXT(); return '{';
- case '}': NEXT(); return '}';
- case '~': NEXT(); return '~';
+ switch (J->lexchar) {
+ case '(': jsY_next(J); return '(';
+ case ')': jsY_next(J); return ')';
+ case ',': jsY_next(J); return ',';
+ case ':': jsY_next(J); return ':';
+ case ';': jsY_next(J); return ';';
+ case '?': jsY_next(J); return '?';
+ case '[': jsY_next(J); return '[';
+ case ']': jsY_next(J); return ']';
+ case '{': jsY_next(J); return '{';
+ case '}': jsY_next(J); return '}';
+ case '~': jsY_next(J); return '~';
case '\'':
case '"':
@@ -585,36 +584,36 @@
return lexnumber(J);
case '<':
- NEXT();
- if (ACCEPT('<')) {
- if (ACCEPT('='))
+ jsY_next(J);
+ if (jsY_accept(J, '<')) {
+ if (jsY_accept(J, '='))
return TK_SHL_ASS;
return TK_SHL;
}
- if (ACCEPT('='))
+ if (jsY_accept(J, '='))
return TK_LE;
return '<';
case '>':
- NEXT();
- if (ACCEPT('>')) {
- if (ACCEPT('>')) {
- if (ACCEPT('='))
+ jsY_next(J);
+ if (jsY_accept(J, '>')) {
+ if (jsY_accept(J, '>')) {
+ if (jsY_accept(J, '='))
return TK_USHR_ASS;
return TK_USHR;
}
- if (ACCEPT('='))
+ if (jsY_accept(J, '='))
return TK_SHR_ASS;
return TK_SHR;
}
- if (ACCEPT('='))
+ if (jsY_accept(J, '='))
return TK_GE;
return '>';
case '=':
- NEXT();
- if (ACCEPT('=')) {
- if (ACCEPT('='))
+ jsY_next(J);
+ if (jsY_accept(J, '=')) {
+ if (jsY_accept(J, '='))
return TK_STRICTEQ;
return TK_EQ;
}
@@ -621,9 +620,9 @@
return '=';
case '!':
- NEXT();
- if (ACCEPT('=')) {
- if (ACCEPT('='))
+ jsY_next(J);
+ if (jsY_accept(J, '=')) {
+ if (jsY_accept(J, '='))
return TK_STRICTNE;
return TK_NE;
}
@@ -630,52 +629,52 @@
return '!';
case '+':
- NEXT();
- if (ACCEPT('+'))
+ jsY_next(J);
+ if (jsY_accept(J, '+'))
return TK_INC;
- if (ACCEPT('='))
+ if (jsY_accept(J, '='))
return TK_ADD_ASS;
return '+';
case '-':
- NEXT();
- if (ACCEPT('-'))
+ jsY_next(J);
+ if (jsY_accept(J, '-'))
return TK_DEC;
- if (ACCEPT('='))
+ if (jsY_accept(J, '='))
return TK_SUB_ASS;
return '-';
case '*':
- NEXT();
- if (ACCEPT('='))
+ jsY_next(J);
+ if (jsY_accept(J, '='))
return TK_MUL_ASS;
return '*';
case '%':
- NEXT();
- if (ACCEPT('='))
+ jsY_next(J);
+ if (jsY_accept(J, '='))
return TK_MOD_ASS;
return '%';
case '&':
- NEXT();
- if (ACCEPT('&'))
+ jsY_next(J);
+ if (jsY_accept(J, '&'))
return TK_AND;
- if (ACCEPT('='))
+ if (jsY_accept(J, '='))
return TK_AND_ASS;
return '&';
case '|':
- NEXT();
- if (ACCEPT('|'))
+ jsY_next(J);
+ if (jsY_accept(J, '|'))
return TK_OR;
- if (ACCEPT('='))
+ if (jsY_accept(J, '='))
return TK_OR_ASS;
return '|';
case '^':
- NEXT();
- if (ACCEPT('='))
+ jsY_next(J);
+ if (jsY_accept(J, '='))
return TK_XOR_ASS;
return '^';
@@ -685,15 +684,15 @@
/* Handle \uXXXX escapes in identifiers */
jsY_unescape(J);
- if (jsY_isidentifierstart(PEEK)) {
+ if (jsY_isidentifierstart(J->lexchar)) {
textinit(J);
- textpush(J, PEEK);
+ textpush(J, J->lexchar);
- NEXT();
+ jsY_next(J);
jsY_unescape(J);
- while (jsY_isidentifierpart(PEEK)) {
- textpush(J, PEEK);
- NEXT();
+ while (jsY_isidentifierpart(J->lexchar)) {
+ textpush(J, J->lexchar);
+ jsY_next(J);
jsY_unescape(J);
}
@@ -702,9 +701,9 @@
return jsY_findkeyword(J, J->lexbuf.text);
}
- if (PEEK >= 0x20 && PEEK <= 0x7E)
- jsY_error(J, "unexpected character: '%c'", PEEK);
- jsY_error(J, "unexpected character: \\u%04X", PEEK);
+ if (J->lexchar >= 0x20 && J->lexchar <= 0x7E)
+ jsY_error(J, "unexpected character: '%c'", J->lexchar);
+ jsY_error(J, "unexpected character: \\u%04X", J->lexchar);
}
}
@@ -714,7 +713,7 @@
J->source = source;
J->line = 1;
J->lasttoken = 0;
- NEXT(); /* load first lookahead character */
+ jsY_next(J); /* load first lookahead character */
}
int jsY_lex(js_State *J)
@@ -727,20 +726,20 @@
while (1) {
J->lexline = J->line; /* save location of beginning of token */
- while (jsY_iswhite(PEEK) || PEEK == '\n')
- NEXT();
+ while (jsY_iswhite(J->lexchar) || J->lexchar == '\n')
+ jsY_next(J);
- if (PEEK >= '0' && PEEK <= '9') {
+ if (J->lexchar >= '0' && J->lexchar <= '9') {
return lexnumber(J);
}
- switch (PEEK) {
- case ',': NEXT(); return ',';
- case ':': NEXT(); return ':';
- case '[': NEXT(); return '[';
- case ']': NEXT(); return ']';
- case '{': NEXT(); return '{';
- case '}': NEXT(); return '}';
+ switch (J->lexchar) {
+ case ',': jsY_next(J); return ',';
+ case ':': jsY_next(J); return ':';
+ case '[': jsY_next(J); return '[';
+ case ']': jsY_next(J); return ']';
+ case '{': jsY_next(J); return '{';
+ case '}': jsY_next(J); return '}';
case '"':
return lexstring(J);
@@ -749,15 +748,15 @@
return lexnumber(J);
case 'f':
- NEXT(); EXPECT('a'); EXPECT('l'); EXPECT('s'); EXPECT('e');
+ jsY_next(J); jsY_expect(J, 'a'); jsY_expect(J, 'l'); jsY_expect(J, 's'); jsY_expect(J, 'e');
return TK_FALSE;
case 'n':
- NEXT(); EXPECT('u'); EXPECT('l'); EXPECT('l');
+ jsY_next(J); jsY_expect(J, 'u'); jsY_expect(J, 'l'); jsY_expect(J, 'l');
return TK_NULL;
case 't':
- NEXT(); EXPECT('r'); EXPECT('u'); EXPECT('e');
+ jsY_next(J); jsY_expect(J, 'r'); jsY_expect(J, 'u'); jsY_expect(J, 'e');
return TK_TRUE;
case 0:
@@ -764,8 +763,8 @@
return 0; /* EOF */
}
- if (PEEK >= 0x20 && PEEK <= 0x7E)
- jsY_error(J, "unexpected character: '%c'", PEEK);
- jsY_error(J, "unexpected character: \\u%04X", PEEK);
+ if (J->lexchar >= 0x20 && J->lexchar <= 0x7E)
+ jsY_error(J, "unexpected character: '%c'", J->lexchar);
+ jsY_error(J, "unexpected character: \\u%04X", J->lexchar);
}
}
--- a/jsparse.c
+++ b/jsparse.c
@@ -15,8 +15,6 @@
#define STM3(x,a,b,c) jsP_newnode(J, STM_ ## x, a, b, c, 0)
#define STM4(x,a,b,c,d) jsP_newnode(J, STM_ ## x, a, b, c, d)
-#define TOKSTR jsY_tokenstring(J->lookahead)
-
static js_Ast *expression(js_State *J, int notin);
static js_Ast *assignment(js_State *J, int notin);
static js_Ast *memberexp(js_State *J);
@@ -128,37 +126,25 @@
/* Lookahead */
-static void next(js_State *J)
+static void jsP_next(js_State *J)
{
J->astline = J->lexline;
J->lookahead = jsY_lex(J);
}
-static int accept(js_State *J, int t)
-{
- if (J->lookahead == t) {
- next(J);
- return 1;
- }
- return 0;
-}
+#define jsP_accept(J,x) (J->lookahead == x ? (jsP_next(J), 1) : 0)
-static void expect(js_State *J, int t)
-{
- if (accept(J, t))
- return;
- jsP_error(J, "unexpected token: %s (expected %s)", TOKSTR, jsY_tokenstring(t));
-}
+#define jsP_expect(J,x) if (!jsP_accept(J, x)) jsP_error(J, "unexpected token: %s (expected %s)", jsY_tokenstring(J->lookahead), jsY_tokenstring(x))
static void semicolon(js_State *J)
{
if (J->lookahead == ';') {
- next(J);
+ jsP_next(J);
return;
}
if (J->newline || J->lookahead == '}' || J->lookahead == 0)
return;
- jsP_error(J, "unexpected token: %s (expected ';')", TOKSTR);
+ jsP_error(J, "unexpected token: %s (expected ';')", jsY_tokenstring(J->lookahead));
}
/* Literals */
@@ -186,10 +172,10 @@
if (J->lookahead == TK_IDENTIFIER) {
checkfutureword(J, J->text);
a = jsP_newstrnode(J, AST_IDENTIFIER, J->text);
- next(J);
+ jsP_next(J);
return a;
}
- jsP_error(J, "unexpected token: %s (expected identifier)", TOKSTR);
+ jsP_error(J, "unexpected token: %s (expected identifier)", jsY_tokenstring(J->lookahead));
}
static js_Ast *identifieropt(js_State *J)
@@ -203,10 +189,10 @@
{
if (J->lookahead == TK_IDENTIFIER || J->lookahead >= TK_BREAK) {
js_Ast *a = jsP_newstrnode(J, AST_IDENTIFIER, J->text);
- next(J);
+ jsP_next(J);
return a;
}
- jsP_error(J, "unexpected token: %s (expected identifier or keyword)", TOKSTR);
+ jsP_error(J, "unexpected token: %s (expected identifier or keyword)", jsY_tokenstring(J->lookahead));
}
static js_Ast *arrayelement(js_State *J)
@@ -222,7 +208,7 @@
if (J->lookahead == ']')
return NULL;
head = tail = LIST(arrayelement(J));
- while (accept(J, ',')) {
+ while (jsP_accept(J, ',')) {
if (J->lookahead != ']')
tail = tail->b = LIST(arrayelement(J));
}
@@ -234,10 +220,10 @@
js_Ast *name;
if (J->lookahead == TK_NUMBER) {
name = jsP_newnumnode(J, EXP_NUMBER, J->number);
- next(J);
+ jsP_next(J);
} else if (J->lookahead == TK_STRING) {
name = jsP_newstrnode(J, EXP_STRING, J->text);
- next(J);
+ jsP_next(J);
} else {
name = identifiername(J);
}
@@ -253,22 +239,22 @@
if (J->lookahead != ':' && name->type == AST_IDENTIFIER) {
if (!strcmp(name->string, "get")) {
name = propname(J);
- expect(J, '(');
- expect(J, ')');
+ jsP_expect(J, '(');
+ jsP_expect(J, ')');
body = funbody(J);
return EXP3(PROP_GET, name, NULL, body);
}
if (!strcmp(name->string, "set")) {
name = propname(J);
- expect(J, '(');
+ jsP_expect(J, '(');
arg = identifier(J);
- expect(J, ')');
+ jsP_expect(J, ')');
body = funbody(J);
return EXP3(PROP_SET, name, LIST(arg), body);
}
}
- expect(J, ':');
+ jsP_expect(J, ':');
value = assignment(J, 0);
return EXP2(PROP_VAL, name, value);
}
@@ -279,7 +265,7 @@
if (J->lookahead == '}')
return NULL;
head = tail = LIST(propassign(J));
- while (accept(J, ',')) {
+ while (jsP_accept(J, ',')) {
if (J->lookahead == '}')
break;
tail = tail->b = LIST(propassign(J));
@@ -295,7 +281,7 @@
if (J->lookahead == ')')
return NULL;
head = tail = LIST(identifier(J));
- while (accept(J, ',')) {
+ while (jsP_accept(J, ',')) {
tail = tail->b = LIST(identifier(J));
}
return jsP_list(head);
@@ -305,9 +291,9 @@
{
js_Ast *a, *b, *c;
a = identifier(J);
- expect(J, '(');
+ jsP_expect(J, '(');
b = parameters(J);
- expect(J, ')');
+ jsP_expect(J, ')');
c = funbody(J);
return jsP_newnode(J, AST_FUNDEC, a, b, c, 0);
}
@@ -316,9 +302,9 @@
{
js_Ast *a, *b, *c;
a = identifier(J);
- expect(J, '(');
+ jsP_expect(J, '(');
b = parameters(J);
- expect(J, ')');
+ jsP_expect(J, ')');
c = funbody(J);
/* rewrite function statement as "var X = function X() {}" */
return STM1(VAR, LIST(EXP2(VAR, a, EXP3(FUN, a, b, c))));
@@ -328,9 +314,9 @@
{
js_Ast *a, *b, *c;
a = identifieropt(J);
- expect(J, '(');
+ jsP_expect(J, '(');
b = parameters(J);
- expect(J, ')');
+ jsP_expect(J, ')');
c = funbody(J);
return EXP3(FUN, a, b, c);
}
@@ -344,35 +330,35 @@
if (J->lookahead == TK_IDENTIFIER) {
checkfutureword(J, J->text);
a = jsP_newstrnode(J, EXP_IDENTIFIER, J->text);
- next(J);
+ jsP_next(J);
return a;
}
if (J->lookahead == TK_STRING) {
a = jsP_newstrnode(J, EXP_STRING, J->text);
- next(J);
+ jsP_next(J);
return a;
}
if (J->lookahead == TK_REGEXP) {
a = jsP_newstrnode(J, EXP_REGEXP, J->text);
a->number = J->number;
- next(J);
+ jsP_next(J);
return a;
}
if (J->lookahead == TK_NUMBER) {
a = jsP_newnumnode(J, EXP_NUMBER, J->number);
- next(J);
+ jsP_next(J);
return a;
}
- if (accept(J, TK_THIS)) return EXP0(THIS);
- if (accept(J, TK_NULL)) return EXP0(NULL);
- if (accept(J, TK_TRUE)) return EXP0(TRUE);
- if (accept(J, TK_FALSE)) return EXP0(FALSE);
- if (accept(J, '{')) { a = EXP1(OBJECT, objectliteral(J)); expect(J, '}'); return a; }
- if (accept(J, '[')) { a = EXP1(ARRAY, arrayliteral(J)); expect(J, ']'); return a; }
- if (accept(J, '(')) { a = expression(J, 0); expect(J, ')'); return a; }
+ if (jsP_accept(J, TK_THIS)) return EXP0(THIS);
+ if (jsP_accept(J, TK_NULL)) return EXP0(NULL);
+ if (jsP_accept(J, TK_TRUE)) return EXP0(TRUE);
+ if (jsP_accept(J, TK_FALSE)) return EXP0(FALSE);
+ if (jsP_accept(J, '{')) { a = EXP1(OBJECT, objectliteral(J)); jsP_expect(J, '}'); return a; }
+ if (jsP_accept(J, '[')) { a = EXP1(ARRAY, arrayliteral(J)); jsP_expect(J, ']'); return a; }
+ if (jsP_accept(J, '(')) { a = expression(J, 0); jsP_expect(J, ')'); return a; }
- jsP_error(J, "unexpected token in expression: %s", TOKSTR);
+ jsP_error(J, "unexpected token in expression: %s", jsY_tokenstring(J->lookahead));
}
static js_Ast *arguments(js_State *J)
@@ -381,7 +367,7 @@
if (J->lookahead == ')')
return NULL;
head = tail = LIST(assignment(J, 0));
- while (accept(J, ',')) {
+ while (jsP_accept(J, ',')) {
tail = tail->b = LIST(assignment(J, 0));
}
return jsP_list(head);
@@ -391,17 +377,17 @@
{
js_Ast *a, *b;
- if (accept(J, TK_NEW)) {
+ if (jsP_accept(J, TK_NEW)) {
a = memberexp(J);
- if (accept(J, '(')) {
+ if (jsP_accept(J, '(')) {
b = arguments(J);
- expect(J, ')');
+ jsP_expect(J, ')');
return EXP2(NEW, a, b);
}
return EXP1(NEW, a);
}
- if (accept(J, TK_FUNCTION))
+ if (jsP_accept(J, TK_FUNCTION))
return funexp(J);
return primary(J);
@@ -411,8 +397,8 @@
{
js_Ast *a = newexp(J);
loop:
- if (accept(J, '.')) { a = EXP2(MEMBER, a, identifiername(J)); goto loop; }
- if (accept(J, '[')) { a = EXP2(INDEX, a, expression(J, 0)); expect(J, ']'); goto loop; }
+ if (jsP_accept(J, '.')) { a = EXP2(MEMBER, a, identifiername(J)); goto loop; }
+ if (jsP_accept(J, '[')) { a = EXP2(INDEX, a, expression(J, 0)); jsP_expect(J, ']'); goto loop; }
return a;
}
@@ -420,9 +406,9 @@
{
js_Ast *a = newexp(J);
loop:
- if (accept(J, '.')) { a = EXP2(MEMBER, a, identifiername(J)); goto loop; }
- if (accept(J, '[')) { a = EXP2(INDEX, a, expression(J, 0)); expect(J, ']'); goto loop; }
- if (accept(J, '(')) { a = EXP2(CALL, a, arguments(J)); expect(J, ')'); goto loop; }
+ if (jsP_accept(J, '.')) { a = EXP2(MEMBER, a, identifiername(J)); goto loop; }
+ if (jsP_accept(J, '[')) { a = EXP2(INDEX, a, expression(J, 0)); jsP_expect(J, ']'); goto loop; }
+ if (jsP_accept(J, '(')) { a = EXP2(CALL, a, arguments(J)); jsP_expect(J, ')'); goto loop; }
return a;
}
@@ -429,22 +415,22 @@
static js_Ast *postfix(js_State *J)
{
js_Ast *a = callexp(J);
- if (!J->newline && accept(J, TK_INC)) return EXP1(POSTINC, a);
- if (!J->newline && accept(J, TK_DEC)) return EXP1(POSTDEC, a);
+ if (!J->newline && jsP_accept(J, TK_INC)) return EXP1(POSTINC, a);
+ if (!J->newline && jsP_accept(J, TK_DEC)) return EXP1(POSTDEC, a);
return a;
}
static js_Ast *unary(js_State *J)
{
- if (accept(J, TK_DELETE)) return EXP1(DELETE, unary(J));
- if (accept(J, TK_VOID)) return EXP1(VOID, unary(J));
- if (accept(J, TK_TYPEOF)) return EXP1(TYPEOF, unary(J));
- if (accept(J, TK_INC)) return EXP1(PREINC, unary(J));
- if (accept(J, TK_DEC)) return EXP1(PREDEC, unary(J));
- if (accept(J, '+')) return EXP1(POS, unary(J));
- if (accept(J, '-')) return EXP1(NEG, unary(J));
- if (accept(J, '~')) return EXP1(BITNOT, unary(J));
- if (accept(J, '!')) return EXP1(LOGNOT, unary(J));
+ if (jsP_accept(J, TK_DELETE)) return EXP1(DELETE, unary(J));
+ if (jsP_accept(J, TK_VOID)) return EXP1(VOID, unary(J));
+ if (jsP_accept(J, TK_TYPEOF)) return EXP1(TYPEOF, unary(J));
+ if (jsP_accept(J, TK_INC)) return EXP1(PREINC, unary(J));
+ if (jsP_accept(J, TK_DEC)) return EXP1(PREDEC, unary(J));
+ if (jsP_accept(J, '+')) return EXP1(POS, unary(J));
+ if (jsP_accept(J, '-')) return EXP1(NEG, unary(J));
+ if (jsP_accept(J, '~')) return EXP1(BITNOT, unary(J));
+ if (jsP_accept(J, '!')) return EXP1(LOGNOT, unary(J));
return postfix(J);
}
@@ -452,9 +438,9 @@
{
js_Ast *a = unary(J);
loop:
- if (accept(J, '*')) { a = EXP2(MUL, a, unary(J)); goto loop; }
- if (accept(J, '/')) { a = EXP2(DIV, a, unary(J)); goto loop; }
- if (accept(J, '%')) { a = EXP2(MOD, a, unary(J)); goto loop; }
+ if (jsP_accept(J, '*')) { a = EXP2(MUL, a, unary(J)); goto loop; }
+ if (jsP_accept(J, '/')) { a = EXP2(DIV, a, unary(J)); goto loop; }
+ if (jsP_accept(J, '%')) { a = EXP2(MOD, a, unary(J)); goto loop; }
return a;
}
@@ -462,8 +448,8 @@
{
js_Ast *a = multiplicative(J);
loop:
- if (accept(J, '+')) { a = EXP2(ADD, a, multiplicative(J)); goto loop; }
- if (accept(J, '-')) { a = EXP2(SUB, a, multiplicative(J)); goto loop; }
+ if (jsP_accept(J, '+')) { a = EXP2(ADD, a, multiplicative(J)); goto loop; }
+ if (jsP_accept(J, '-')) { a = EXP2(SUB, a, multiplicative(J)); goto loop; }
return a;
}
@@ -471,9 +457,9 @@
{
js_Ast *a = additive(J);
loop:
- if (accept(J, TK_SHL)) { a = EXP2(SHL, a, additive(J)); goto loop; }
- if (accept(J, TK_SHR)) { a = EXP2(SHR, a, additive(J)); goto loop; }
- if (accept(J, TK_USHR)) { a = EXP2(USHR, a, additive(J)); goto loop; }
+ if (jsP_accept(J, TK_SHL)) { a = EXP2(SHL, a, additive(J)); goto loop; }
+ if (jsP_accept(J, TK_SHR)) { a = EXP2(SHR, a, additive(J)); goto loop; }
+ if (jsP_accept(J, TK_USHR)) { a = EXP2(USHR, a, additive(J)); goto loop; }
return a;
}
@@ -481,12 +467,12 @@
{
js_Ast *a = shift(J);
loop:
- if (accept(J, '<')) { a = EXP2(LT, a, shift(J)); goto loop; }
- if (accept(J, '>')) { a = EXP2(GT, a, shift(J)); goto loop; }
- if (accept(J, TK_LE)) { a = EXP2(LE, a, shift(J)); goto loop; }
- if (accept(J, TK_GE)) { a = EXP2(GE, a, shift(J)); goto loop; }
- if (accept(J, TK_INSTANCEOF)) { a = EXP2(INSTANCEOF, a, shift(J)); goto loop; }
- if (!notin && accept(J, TK_IN)) { a = EXP2(IN, a, shift(J)); goto loop; }
+ if (jsP_accept(J, '<')) { a = EXP2(LT, a, shift(J)); goto loop; }
+ if (jsP_accept(J, '>')) { a = EXP2(GT, a, shift(J)); goto loop; }
+ if (jsP_accept(J, TK_LE)) { a = EXP2(LE, a, shift(J)); goto loop; }
+ if (jsP_accept(J, TK_GE)) { a = EXP2(GE, a, shift(J)); goto loop; }
+ if (jsP_accept(J, TK_INSTANCEOF)) { a = EXP2(INSTANCEOF, a, shift(J)); goto loop; }
+ if (!notin && jsP_accept(J, TK_IN)) { a = EXP2(IN, a, shift(J)); goto loop; }
return a;
}
@@ -494,10 +480,10 @@
{
js_Ast *a = relational(J, notin);
loop:
- if (accept(J, TK_EQ)) { a = EXP2(EQ, a, relational(J, notin)); goto loop; }
- if (accept(J, TK_NE)) { a = EXP2(NE, a, relational(J, notin)); goto loop; }
- if (accept(J, TK_STRICTEQ)) { a = EXP2(STRICTEQ, a, relational(J, notin)); goto loop; }
- if (accept(J, TK_STRICTNE)) { a = EXP2(STRICTNE, a, relational(J, notin)); goto loop; }
+ if (jsP_accept(J, TK_EQ)) { a = EXP2(EQ, a, relational(J, notin)); goto loop; }
+ if (jsP_accept(J, TK_NE)) { a = EXP2(NE, a, relational(J, notin)); goto loop; }
+ if (jsP_accept(J, TK_STRICTEQ)) { a = EXP2(STRICTEQ, a, relational(J, notin)); goto loop; }
+ if (jsP_accept(J, TK_STRICTNE)) { a = EXP2(STRICTNE, a, relational(J, notin)); goto loop; }
return a;
}
@@ -504,7 +490,7 @@
static js_Ast *bitand(js_State *J, int notin)
{
js_Ast *a = equality(J, notin);
- while (accept(J, '&'))
+ while (jsP_accept(J, '&'))
a = EXP2(BITAND, a, equality(J, notin));
return a;
}
@@ -512,7 +498,7 @@
static js_Ast *bitxor(js_State *J, int notin)
{
js_Ast *a = bitand(J, notin);
- while (accept(J, '^'))
+ while (jsP_accept(J, '^'))
a = EXP2(BITXOR, a, bitand(J, notin));
return a;
}
@@ -520,7 +506,7 @@
static js_Ast *bitor(js_State *J, int notin)
{
js_Ast *a = bitxor(J, notin);
- while (accept(J, '|'))
+ while (jsP_accept(J, '|'))
a = EXP2(BITOR, a, bitxor(J, notin));
return a;
}
@@ -528,7 +514,7 @@
static js_Ast *logand(js_State *J, int notin)
{
js_Ast *a = bitor(J, notin);
- if (accept(J, TK_AND))
+ if (jsP_accept(J, TK_AND))
a = EXP2(LOGAND, a, logand(J, notin));
return a;
}
@@ -536,7 +522,7 @@
static js_Ast *logor(js_State *J, int notin)
{
js_Ast *a = logand(J, notin);
- if (accept(J, TK_OR))
+ if (jsP_accept(J, TK_OR))
a = EXP2(LOGOR, a, logor(J, notin));
return a;
}
@@ -545,9 +531,9 @@
{
js_Ast *a, *b, *c;
a = logor(J, notin);
- if (accept(J, '?')) {
+ if (jsP_accept(J, '?')) {
b = assignment(J, 0);
- expect(J, ':');
+ jsP_expect(J, ':');
c = assignment(J, notin);
return EXP3(COND, a, b, c);
}
@@ -557,18 +543,18 @@
static js_Ast *assignment(js_State *J, int notin)
{
js_Ast *a = conditional(J, notin);
- if (accept(J, '=')) return EXP2(ASS, a, assignment(J, notin));
- if (accept(J, TK_MUL_ASS)) return EXP2(ASS_MUL, a, assignment(J, notin));
- if (accept(J, TK_DIV_ASS)) return EXP2(ASS_DIV, a, assignment(J, notin));
- if (accept(J, TK_MOD_ASS)) return EXP2(ASS_MOD, a, assignment(J, notin));
- if (accept(J, TK_ADD_ASS)) return EXP2(ASS_ADD, a, assignment(J, notin));
- if (accept(J, TK_SUB_ASS)) return EXP2(ASS_SUB, a, assignment(J, notin));
- if (accept(J, TK_SHL_ASS)) return EXP2(ASS_SHL, a, assignment(J, notin));
- if (accept(J, TK_SHR_ASS)) return EXP2(ASS_SHR, a, assignment(J, notin));
- if (accept(J, TK_USHR_ASS)) return EXP2(ASS_USHR, a, assignment(J, notin));
- if (accept(J, TK_AND_ASS)) return EXP2(ASS_BITAND, a, assignment(J, notin));
- if (accept(J, TK_XOR_ASS)) return EXP2(ASS_BITXOR, a, assignment(J, notin));
- if (accept(J, TK_OR_ASS)) return EXP2(ASS_BITOR, a, assignment(J, notin));
+ if (jsP_accept(J, '=')) return EXP2(ASS, a, assignment(J, notin));
+ if (jsP_accept(J, TK_MUL_ASS)) return EXP2(ASS_MUL, a, assignment(J, notin));
+ if (jsP_accept(J, TK_DIV_ASS)) return EXP2(ASS_DIV, a, assignment(J, notin));
+ if (jsP_accept(J, TK_MOD_ASS)) return EXP2(ASS_MOD, a, assignment(J, notin));
+ if (jsP_accept(J, TK_ADD_ASS)) return EXP2(ASS_ADD, a, assignment(J, notin));
+ if (jsP_accept(J, TK_SUB_ASS)) return EXP2(ASS_SUB, a, assignment(J, notin));
+ if (jsP_accept(J, TK_SHL_ASS)) return EXP2(ASS_SHL, a, assignment(J, notin));
+ if (jsP_accept(J, TK_SHR_ASS)) return EXP2(ASS_SHR, a, assignment(J, notin));
+ if (jsP_accept(J, TK_USHR_ASS)) return EXP2(ASS_USHR, a, assignment(J, notin));
+ if (jsP_accept(J, TK_AND_ASS)) return EXP2(ASS_BITAND, a, assignment(J, notin));
+ if (jsP_accept(J, TK_XOR_ASS)) return EXP2(ASS_BITXOR, a, assignment(J, notin));
+ if (jsP_accept(J, TK_OR_ASS)) return EXP2(ASS_BITOR, a, assignment(J, notin));
return a;
}
@@ -575,7 +561,7 @@
static js_Ast *expression(js_State *J, int notin)
{
js_Ast *a = assignment(J, notin);
- while (accept(J, ','))
+ while (jsP_accept(J, ','))
a = EXP2(COMMA, a, assignment(J, notin));
return a;
}
@@ -585,7 +571,7 @@
static js_Ast *vardec(js_State *J, int notin)
{
js_Ast *a = identifier(J);
- if (accept(J, '='))
+ if (jsP_accept(J, '='))
return EXP2(VAR, a, assignment(J, notin));
return EXP1(VAR, a);
}
@@ -594,7 +580,7 @@
{
js_Ast *head, *tail;
head = tail = LIST(vardec(J, notin));
- while (accept(J, ','))
+ while (jsP_accept(J, ','))
tail = tail->b = LIST(vardec(J, notin));
return jsP_list(head);
}
@@ -614,20 +600,20 @@
{
js_Ast *a, *b;
- if (accept(J, TK_CASE)) {
+ if (jsP_accept(J, TK_CASE)) {
a = expression(J, 0);
- expect(J, ':');
+ jsP_expect(J, ':');
b = statementlist(J);
return STM2(CASE, a, b);
}
- if (accept(J, TK_DEFAULT)) {
- expect(J, ':');
+ if (jsP_accept(J, TK_DEFAULT)) {
+ jsP_expect(J, ':');
a = statementlist(J);
return STM1(DEFAULT, a);
}
- jsP_error(J, "unexpected token in switch: %s (expected 'case' or 'default')", TOKSTR);
+ jsP_error(J, "unexpected token in switch: %s (expected 'case' or 'default')", jsY_tokenstring(J->lookahead));
}
static js_Ast *caselist(js_State *J)
@@ -644,9 +630,9 @@
static js_Ast *block(js_State *J)
{
js_Ast *a;
- expect(J, '{');
+ jsP_expect(J, '{');
a = statementlist(J);
- expect(J, '}');
+ jsP_expect(J, '}');
return STM1(BLOCK, a);
}
@@ -655,7 +641,7 @@
js_Ast *a = NULL;
if (J->lookahead != end)
a = expression(J, 0);
- expect(J, end);
+ jsP_expect(J, end);
return a;
}
@@ -662,22 +648,22 @@
static js_Ast *forstatement(js_State *J)
{
js_Ast *a, *b, *c, *d;
- expect(J, '(');
- if (accept(J, TK_VAR)) {
+ jsP_expect(J, '(');
+ if (jsP_accept(J, TK_VAR)) {
a = vardeclist(J, 1);
- if (accept(J, ';')) {
+ if (jsP_accept(J, ';')) {
b = forexpression(J, ';');
c = forexpression(J, ')');
d = statement(J);
return STM4(FOR_VAR, a, b, c, d);
}
- if (accept(J, TK_IN)) {
+ if (jsP_accept(J, TK_IN)) {
b = expression(J, 0);
- expect(J, ')');
+ jsP_expect(J, ')');
c = statement(J);
return STM3(FOR_IN_VAR, a, b, c);
}
- jsP_error(J, "unexpected token in for-var-statement: %s", TOKSTR);
+ jsP_error(J, "unexpected token in for-var-statement: %s", jsY_tokenstring(J->lookahead));
}
if (J->lookahead != ';')
@@ -684,19 +670,19 @@
a = expression(J, 1);
else
a = NULL;
- if (accept(J, ';')) {
+ if (jsP_accept(J, ';')) {
b = forexpression(J, ';');
c = forexpression(J, ')');
d = statement(J);
return STM4(FOR, a, b, c, d);
}
- if (accept(J, TK_IN)) {
+ if (jsP_accept(J, TK_IN)) {
b = expression(J, 0);
- expect(J, ')');
+ jsP_expect(J, ')');
c = statement(J);
return STM3(FOR_IN, a, b, c);
}
- jsP_error(J, "unexpected token in for-statement: %s", TOKSTR);
+ jsP_error(J, "unexpected token in for-statement: %s", jsY_tokenstring(J->lookahead));
}
static js_Ast *statement(js_State *J)
@@ -707,7 +693,7 @@
return block(J);
}
- if (accept(J, TK_VAR)) {
+ if (jsP_accept(J, TK_VAR)) {
a = vardeclist(J, 0);
semicolon(J);
return STM1(VAR, a);
@@ -714,16 +700,16 @@
}
/* empty statement */
- if (accept(J, ';')) {
+ if (jsP_accept(J, ';')) {
return STM0(EMPTY);
}
- if (accept(J, TK_IF)) {
- expect(J, '(');
+ if (jsP_accept(J, TK_IF)) {
+ jsP_expect(J, '(');
a = expression(J, 0);
- expect(J, ')');
+ jsP_expect(J, ')');
b = statement(J);
- if (accept(J, TK_ELSE))
+ if (jsP_accept(J, TK_ELSE))
c = statement(J);
else
c = NULL;
@@ -730,41 +716,41 @@
return STM3(IF, a, b, c);
}
- if (accept(J, TK_DO)) {
+ if (jsP_accept(J, TK_DO)) {
a = statement(J);
- expect(J, TK_WHILE);
- expect(J, '(');
+ jsP_expect(J, TK_WHILE);
+ jsP_expect(J, '(');
b = expression(J, 0);
- expect(J, ')');
+ jsP_expect(J, ')');
semicolon(J);
return STM2(DO, a, b);
}
- if (accept(J, TK_WHILE)) {
- expect(J, '(');
+ if (jsP_accept(J, TK_WHILE)) {
+ jsP_expect(J, '(');
a = expression(J, 0);
- expect(J, ')');
+ jsP_expect(J, ')');
b = statement(J);
return STM2(WHILE, a, b);
}
- if (accept(J, TK_FOR)) {
+ if (jsP_accept(J, TK_FOR)) {
return forstatement(J);
}
- if (accept(J, TK_CONTINUE)) {
+ if (jsP_accept(J, TK_CONTINUE)) {
a = identifieropt(J);
semicolon(J);
return STM1(CONTINUE, a);
}
- if (accept(J, TK_BREAK)) {
+ if (jsP_accept(J, TK_BREAK)) {
a = identifieropt(J);
semicolon(J);
return STM1(BREAK, a);
}
- if (accept(J, TK_RETURN)) {
+ if (jsP_accept(J, TK_RETURN)) {
if (J->lookahead != ';' && J->lookahead != '}' && J->lookahead != 0)
a = expression(J, 0);
else
@@ -773,53 +759,53 @@
return STM1(RETURN, a);
}
- if (accept(J, TK_WITH)) {
- expect(J, '(');
+ if (jsP_accept(J, TK_WITH)) {
+ jsP_expect(J, '(');
a = expression(J, 0);
- expect(J, ')');
+ jsP_expect(J, ')');
b = statement(J);
return STM2(WITH, a, b);
}
- if (accept(J, TK_SWITCH)) {
- expect(J, '(');
+ if (jsP_accept(J, TK_SWITCH)) {
+ jsP_expect(J, '(');
a = expression(J, 0);
- expect(J, ')');
- expect(J, '{');
+ jsP_expect(J, ')');
+ jsP_expect(J, '{');
b = caselist(J);
- expect(J, '}');
+ jsP_expect(J, '}');
return STM2(SWITCH, a, b);
}
- if (accept(J, TK_THROW)) {
+ if (jsP_accept(J, TK_THROW)) {
a = expression(J, 0);
semicolon(J);
return STM1(THROW, a);
}
- if (accept(J, TK_TRY)) {
+ if (jsP_accept(J, TK_TRY)) {
a = block(J);
b = c = d = NULL;
- if (accept(J, TK_CATCH)) {
- expect(J, '(');
+ if (jsP_accept(J, TK_CATCH)) {
+ jsP_expect(J, '(');
b = identifier(J);
- expect(J, ')');
+ jsP_expect(J, ')');
c = block(J);
}
- if (accept(J, TK_FINALLY)) {
+ if (jsP_accept(J, TK_FINALLY)) {
d = block(J);
}
if (!b && !d)
- jsP_error(J, "unexpected token in try: %s (expected 'catch' or 'finally')", TOKSTR);
+ jsP_error(J, "unexpected token in try: %s (expected 'catch' or 'finally')", jsY_tokenstring(J->lookahead));
return STM4(TRY, a, b, c, d);
}
- if (accept(J, TK_DEBUGGER)) {
+ if (jsP_accept(J, TK_DEBUGGER)) {
semicolon(J);
return STM0(DEBUGGER);
}
- if (accept(J, TK_FUNCTION)) {
+ if (jsP_accept(J, TK_FUNCTION)) {
jsP_warning(J, "function statements are not standard");
return funstm(J);
}
@@ -827,7 +813,7 @@
/* labelled statement or expression statement */
if (J->lookahead == TK_IDENTIFIER) {
a = expression(J, 0);
- if (a->type == EXP_IDENTIFIER && accept(J, ':')) {
+ if (a->type == EXP_IDENTIFIER && jsP_accept(J, ':')) {
a->type = AST_IDENTIFIER;
b = statement(J);
return STM2(LABEL, a, b);
@@ -846,7 +832,7 @@
static js_Ast *scriptelement(js_State *J)
{
- if (accept(J, TK_FUNCTION))
+ if (jsP_accept(J, TK_FUNCTION))
return fundec(J);
return statement(J);
}
@@ -865,9 +851,9 @@
static js_Ast *funbody(js_State *J)
{
js_Ast *a;
- expect(J, '{');
+ jsP_expect(J, '{');
a = script(J, '}');
- expect(J, '}');
+ jsP_expect(J, '}');
return a;
}
@@ -951,7 +937,7 @@
js_Ast *p;
jsY_initlex(J, filename, source);
- next(J);
+ jsP_next(J);
p = script(J, 0);
if (p)
jsP_foldconst(p);
@@ -964,7 +950,7 @@
js_Ast *p = NULL;
if (params) {
jsY_initlex(J, filename, params);
- next(J);
+ jsP_next(J);
p = parameters(J);
}
return EXP3(FUN, NULL, p, jsP_parse(J, filename, body));