summaryrefslogtreecommitdiffstats
path: root/js/src/frontend/Parser.cpp
diff options
context:
space:
mode:
authorwolfbeast <mcwerewolf@wolfbeast.com>2019-04-05 21:32:55 +0200
committerwolfbeast <mcwerewolf@wolfbeast.com>2019-04-05 21:32:55 +0200
commit11a1f58b9a0ebf83c17087a89e6b4ba83748374a (patch)
tree86c539b27aab1dccfe18de803e80a44ad1a161ad /js/src/frontend/Parser.cpp
parent1ee96e39db760004c33a235ea691ab06bac21375 (diff)
downloadUXP-11a1f58b9a0ebf83c17087a89e6b4ba83748374a.tar
UXP-11a1f58b9a0ebf83c17087a89e6b4ba83748374a.tar.gz
UXP-11a1f58b9a0ebf83c17087a89e6b4ba83748374a.tar.lz
UXP-11a1f58b9a0ebf83c17087a89e6b4ba83748374a.tar.xz
UXP-11a1f58b9a0ebf83c17087a89e6b4ba83748374a.zip
Track strict mode errors in unary deletions correctly when
syntax-parsing.
Diffstat (limited to 'js/src/frontend/Parser.cpp')
-rw-r--r--js/src/frontend/Parser.cpp19
1 files changed, 17 insertions, 2 deletions
diff --git a/js/src/frontend/Parser.cpp b/js/src/frontend/Parser.cpp
index afbf4c4c9..f625595a2 100644
--- a/js/src/frontend/Parser.cpp
+++ b/js/src/frontend/Parser.cpp
@@ -643,6 +643,17 @@ Parser<ParseHandler>::strictModeError(unsigned errorNumber, ...)
template <typename ParseHandler>
bool
+Parser<ParseHandler>::strictModeErrorAt(uint32_t offset, unsigned errorNumber, ...)
+{
+ va_list args;
+ va_start(args, errorNumber);
+ bool res = reportHelper(ParseStrictError, pc->sc()->strict(), offset, errorNumber, args);
+ va_end(args);
+ return res;
+}
+
+template <typename ParseHandler>
+bool
Parser<ParseHandler>::reportWithNode(ParseReportKind kind, bool strict, Node pn, unsigned errorNumber, ...)
{
uint32_t offset = (pn ? handler.getPosition(pn) : pos()).begin;
@@ -8031,6 +8042,10 @@ Parser<ParseHandler>::unaryExpr(YieldHandling yieldHandling, TripledotHandling t
}
case TOK_DELETE: {
+ uint32_t exprOffset;
+ if (!tokenStream.peekOffset(&exprOffset, TokenStream::Operand))
+ return null();
+
Node expr = unaryExpr(yieldHandling, TripledotProhibited);
if (!expr)
return null();
@@ -8038,9 +8053,9 @@ Parser<ParseHandler>::unaryExpr(YieldHandling yieldHandling, TripledotHandling t
// Per spec, deleting any unary expression is valid -- it simply
// returns true -- except for one case that is illegal in strict mode.
if (handler.isNameAnyParentheses(expr)) {
- bool strict = pc->sc()->strict();
- if (!reportWithNode(ParseStrictError, strict, expr, JSMSG_DEPRECATED_DELETE_OPERAND))
+ if (!strictModeErrorAt(exprOffset, JSMSG_DEPRECATED_DELETE_OPERAND))
return null();
+
pc->sc()->setBindingsAccessedDynamically();
}