Ce script ne doit pas être installé directement. C'est une librairie destinée à être incluse dans d'autres scripts avec la méta-directive // @require https://update.greasyfork.org/scripts/506614/1441300/ESTreeProcessor.js
// ==UserScript==
// @name ESTreeProcessor
// @namespace https://github.com/mapomatic
// @version 2.0.1
// @description Compiles a string containing Javascript to an ESTree object and/or executes an ESTree object in Javascript
// @author MapOMatic
// @license GNU GPLv3
// ==/UserScript==
// TODO:
// - Add support for classes
// - Probably a lot more I haven't discovered yet.
/* eslint-disable */
const ESTreeProcessor = (function() {
'use strict';
// This is a copy of the esprima-next library. The Node.js build has been modified to work with userscripts.
// The following copyright notice applies to the espima-next library.
// Copyright JS Foundation and other contributors, https://js.foundation/
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright
// notice, this list of conditions and the following disclaimer in the
// documentation and/or other materials provided with the distribution.
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
// THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
const esprima = (function() {
'use strict';
const Syntax = {
AssignmentExpression: 'AssignmentExpression',
AssignmentPattern: 'AssignmentPattern',
ArrayExpression: 'ArrayExpression',
ArrayPattern: 'ArrayPattern',
ArrowFunctionExpression: 'ArrowFunctionExpression',
AwaitExpression: 'AwaitExpression',
BlockStatement: 'BlockStatement',
BinaryExpression: 'BinaryExpression',
BreakStatement: 'BreakStatement',
CallExpression: 'CallExpression',
CatchClause: 'CatchClause',
ChainExpression: 'ChainExpression',
ClassBody: 'ClassBody',
ClassDeclaration: 'ClassDeclaration',
ClassExpression: 'ClassExpression',
ConditionalExpression: 'ConditionalExpression',
ContinueStatement: 'ContinueStatement',
Decorator: 'Decorator',
DoWhileStatement: 'DoWhileStatement',
DebuggerStatement: 'DebuggerStatement',
EmptyStatement: 'EmptyStatement',
ExportAllDeclaration: 'ExportAllDeclaration',
ExportDefaultDeclaration: 'ExportDefaultDeclaration',
ExportNamedDeclaration: 'ExportNamedDeclaration',
ExportSpecifier: 'ExportSpecifier',
ExpressionStatement: 'ExpressionStatement',
ForStatement: 'ForStatement',
ForOfStatement: 'ForOfStatement',
ForInStatement: 'ForInStatement',
FunctionDeclaration: 'FunctionDeclaration',
FunctionExpression: 'FunctionExpression',
Identifier: 'Identifier',
IfStatement: 'IfStatement',
ImportAttribute: 'ImportAttribute',
ImportExpression: 'ImportExpression',
ImportDeclaration: 'ImportDeclaration',
ImportDefaultSpecifier: 'ImportDefaultSpecifier',
ImportNamespaceSpecifier: 'ImportNamespaceSpecifier',
ImportSpecifier: 'ImportSpecifier',
Literal: 'Literal',
LabeledStatement: 'LabeledStatement',
LogicalExpression: 'LogicalExpression',
MemberExpression: 'MemberExpression',
MetaProperty: 'MetaProperty',
MethodDefinition: 'MethodDefinition',
NewExpression: 'NewExpression',
ObjectExpression: 'ObjectExpression',
ObjectPattern: 'ObjectPattern',
Program: 'Program',
Property: 'Property',
PrivateIdentifier: 'PrivateIdentifier',
RestElement: 'RestElement',
ReturnStatement: 'ReturnStatement',
SequenceExpression: 'SequenceExpression',
SpreadElement: 'SpreadElement',
StaticBlock: 'StaticBlock',
Super: 'Super',
SwitchCase: 'SwitchCase',
SwitchStatement: 'SwitchStatement',
TaggedTemplateExpression: 'TaggedTemplateExpression',
TemplateElement: 'TemplateElement',
TemplateLiteral: 'TemplateLiteral',
ThisExpression: 'ThisExpression',
ThrowStatement: 'ThrowStatement',
TryStatement: 'TryStatement',
UnaryExpression: 'UnaryExpression',
UpdateExpression: 'UpdateExpression',
VariableDeclaration: 'VariableDeclaration',
VariableDeclarator: 'VariableDeclarator',
WhileStatement: 'WhileStatement',
WithStatement: 'WithStatement',
YieldExpression: 'YieldExpression'
};
class CommentHandler {
attach;
comments;
stack;
leading;
trailing;
constructor() {
this.attach = !1, this.comments = [], this.stack = [], this.leading = [], this.trailing = [];
}
insertInnerComments(e, t) {
if (e.type === 'BlockStatement' && e.body.length === 0) {
const s = [];
for (let e = this.leading.length - 1; e >= 0; --e) {
const i = this.leading[e];
t.end.offset >= i.start && (s.unshift(i.comment), this.leading.splice(e, 1), this.trailing.splice(e, 1));
}
s.length && (e.innerComments = s);
}
}
findTrailingComments(e) {
let t = [];
if (this.trailing.length > 0) {
for (let s = this.trailing.length - 1; s >= 0; --s) {
const i = this.trailing[s];
i.start >= e.end.offset && t.unshift(i.comment);
}
return this.trailing.length = 0, t;
}
const s = this.stack[this.stack.length - 1];
if (s && s.node.trailingComments) {
const i = s.node.trailingComments[0];
i && i.range[0] >= e.end.offset && (t = s.node.trailingComments, delete s.node.trailingComments);
}
return t;
}
findLeadingComments(e) {
const t = [];
let s;
for (; this.stack.length > 0;) {
const t = this.stack[this.stack.length - 1];
if (!(t && t.start >= e.start.offset)) break;
s = t.node, this.stack.pop();
}
if (s) {
for (let i = (s.leadingComments ? s.leadingComments.length : 0) - 1; i >= 0; --i) {
const r = s.leadingComments[i];
r.range[1] <= e.start.offset && (t.unshift(r), s.leadingComments.splice(i, 1));
}
return s.leadingComments && s.leadingComments.length === 0 && delete s.leadingComments, t;
}
for (let s = this.leading.length - 1; s >= 0; --s) {
const i = this.leading[s];
i.start <= e.start.offset && (t.unshift(i.comment), this.leading.splice(s, 1));
}
return t;
}
visitNode(e, t) {
if (e.type === 'Program' && e.body.length > 0) return;
this.insertInnerComments(e, t);
const s = this.findTrailingComments(t);
const i = this.findLeadingComments(t);
i.length > 0 && (e.leadingComments = i), s.length > 0 && (e.trailingComments = s), this.stack.push({
node: e,
start: t.start.offset
});
}
visitComment(e, t) {
const s = e.type[0] === 'L' ? 'Line' : 'Block';
const i = {
type: s,
value: e.value
};
if (e.range && (i.range = e.range), e.loc && (i.loc = e.loc), this.comments.push(i), this.attach) {
const i = {
comment: {
type: s,
value: e.value,
range: [t.start.offset, t.end.offset]
},
start: t.start.offset
};
e.loc && (i.comment.loc = e.loc), e.type = s, this.leading.push(i), this.trailing.push(i);
}
}
visit(e, t) {
e.type === 'LineComment' || e.type === 'BlockComment' ? this.visitComment(e, t) : this.attach && this.visitNode(e, t);
}
}
const Regex = {
NonAsciiIdentifierStart: /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u05D0-\u05EA\u05EF-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1878\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CE9-\u1CEC\u1CEE-\u1CF3\u1CF5\u1CF6\u1CFA\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2118-\u211D\u2124\u2126\u2128\u212A-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309B-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEF\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7BF\uA7C2-\uA7C6\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA8FE\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB67\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE35\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2\uDD00-\uDD23\uDF00-\uDF1C\uDF27\uDF30-\uDF45\uDFE0-\uDFF6]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD44\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC5F\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDEB8\uDF00-\uDF1A]|\uD806[\uDC00-\uDC2B\uDCA0-\uDCDF\uDCFF\uDDA0-\uDDA7\uDDAA-\uDDD0\uDDE1\uDDE3\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE89\uDE9D\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46\uDD60-\uDD65\uDD67\uDD68\uDD6A-\uDD89\uDD98\uDEE0-\uDEF2]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDE40-\uDE7F\uDF00-\uDF4A\uDF50\uDF93-\uDF9F\uDFE0\uDFE1\uDFE3]|\uD821[\uDC00-\uDFF7]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD50-\uDD52\uDD64-\uDD67\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD838[\uDD00-\uDD2C\uDD37-\uDD3D\uDD4E\uDEC0-\uDEEB]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43\uDD4B]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]/,
// eslint-disable-next-line no-misleading-character-class
NonAsciiIdentifierPart: /[\xAA\xB5\xB7\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05EF-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u07FD\u0800-\u082D\u0840-\u085B\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u08D3-\u08E1\u08E3-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u09FC\u09FE\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0AF9-\u0AFF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58-\u0C5A\u0C60-\u0C63\u0C66-\u0C6F\u0C80-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D00-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D54-\u0D57\u0D5F-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1369-\u1371\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1878\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19DA\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CD0-\u1CD2\u1CD4-\u1CFA\u1D00-\u1DF9\u1DFB-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u200C\u200D\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2118-\u211D\u2124\u2126\u2128\u212A-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEF\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA7BF\uA7C2-\uA7C6\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C5\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA8FD-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB67\uAB70-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE35\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2\uDD00-\uDD27\uDD30-\uDD39\uDF00-\uDF1C\uDF27\uDF30-\uDF50\uDFE0-\uDFF6]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD44-\uDD46\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDC9-\uDDCC\uDDD0-\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE37\uDE3E\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF00-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3B-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF50\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC00-\uDC4A\uDC50-\uDC59\uDC5E\uDC5F\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDDD8-\uDDDD\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB8\uDEC0-\uDEC9\uDF00-\uDF1A\uDF1D-\uDF2B\uDF30-\uDF39]|\uD806[\uDC00-\uDC3A\uDCA0-\uDCE9\uDCFF\uDDA0-\uDDA7\uDDAA-\uDDD7\uDDDA-\uDDE1\uDDE3\uDDE4\uDE00-\uDE3E\uDE47\uDE50-\uDE99\uDE9D\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC36\uDC38-\uDC40\uDC50-\uDC59\uDC72-\uDC8F\uDC92-\uDCA7\uDCA9-\uDCB6\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD47\uDD50-\uDD59\uDD60-\uDD65\uDD67\uDD68\uDD6A-\uDD8E\uDD90\uDD91\uDD93-\uDD98\uDDA0-\uDDA9\uDEE0-\uDEF6]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDE40-\uDE7F\uDF00-\uDF4A\uDF4F-\uDF87\uDF8F-\uDF9F\uDFE0\uDFE1\uDFE3]|\uD821[\uDC00-\uDFF7]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD50-\uDD52\uDD64-\uDD67\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A\uDD00-\uDD2C\uDD30-\uDD3D\uDD40-\uDD49\uDD4E\uDEC0-\uDEF9]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6\uDD00-\uDD4B\uDD50-\uDD59]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/
};
const Character = {
fromCodePoint: e => (e < 65536 ? String.fromCharCode(e) : String.fromCharCode(55296 + (e - 65536 >> 10)) + String.fromCharCode(56320 + (e - 65536 & 1023))),
isStringWellFormedUnicode(e) {
for (let t = 0; t < e.length; t++) {
let s = e.charCodeAt(t);
if (s >= 55296 && s <= 56319) {
if (t === e.length - 1) return !1;
if (t++, s = e.charCodeAt(t), s < 56320 && s > 57343) return !1;
} else if (s >= 56320 && s <= 57343) return !1;
}
return !0;
},
isWhiteSpace: e => e === 32 || e === 9 || e === 11 || e === 12 || e === 160 || e >= 5760 && [5760, 8192, 8193, 8194, 8195, 8196, 8197, 8198, 8199, 8200, 8201, 8202, 8239, 8287, 12288, 65279].indexOf(e) >= 0,
isLineTerminator: e => e === 10 || e === 13 || e === 8232 || e === 8233,
isIdentifierStart: e => e === 36 || e === 95 || e >= 65 && e <= 90 || e >= 97 && e <= 122 || e === 92 || e >= 128 && Regex.NonAsciiIdentifierStart.test(Character.fromCodePoint(e)),
isIdentifierPart: e => e === 36 || e === 95 || e >= 65 && e <= 90 || e >= 97 && e <= 122 || e >= 48 && e <= 57 || e === 92 || e >= 128 && Regex.NonAsciiIdentifierPart.test(Character.fromCodePoint(e)),
isDecimalDigit: e => e >= 48 && e <= 57,
isDecimalDigitChar: e => e.length === 1 && Character.isDecimalDigit(e.charCodeAt(0)),
isHexDigit: e => e >= 48 && e <= 57 || e >= 65 && e <= 70 || e >= 97 && e <= 102,
isHexDigitChar: e => e.length === 1 && Character.isHexDigit(e.charCodeAt(0)),
isOctalDigit: e => e >= 48 && e <= 55,
isOctalDigitChar: e => e.length === 1 && Character.isOctalDigit(e.charCodeAt(0))
};
class JSXClosingElement {
type;
name;
constructor(e) {
this.type = 'JSXClosingElement', this.name = e;
}
}
const JSXClosingFragment = class {
type;
constructor() {
this.type = 'JSXClosingFragment';
}
};
const JSXElement = class {
type;
openingElement;
children;
closingElement;
constructor(e, t, s) {
this.type = 'JSXElement', this.openingElement = e, this.children = t, this.closingElement = s;
}
};
const JSXEmptyExpression = class {
type;
constructor() {
this.type = 'JSXEmptyExpression';
}
};
const JSXExpressionContainer = class {
type;
expression;
constructor(e) {
this.type = 'JSXExpressionContainer', this.expression = e;
}
};
const JSXIdentifier = class {
type;
name;
constructor(e) {
this.type = 'JSXIdentifier', this.name = e;
}
};
const JSXMemberExpression = class {
type;
object;
property;
constructor(e, t) {
this.type = 'JSXMemberExpression', this.object = e, this.property = t;
}
};
const JSXAttribute = class {
type;
name;
value;
constructor(e, t) {
this.type = 'JSXAttribute', this.name = e, this.value = t;
}
};
const JSXNamespacedName = class {
type;
namespace;
name;
constructor(e, t) {
this.type = 'JSXNamespacedName', this.namespace = e, this.name = t;
}
};
const JSXOpeningElement = class {
type;
name;
selfClosing;
attributes;
constructor(e, t, s) {
this.type = 'JSXOpeningElement', this.name = e, this.selfClosing = t, this.attributes = s;
}
};
const JSXOpeningFragment = class {
type;
selfClosing;
constructor(e) {
this.type = 'JSXOpeningFragment', this.selfClosing = e;
}
};
const JSXSpreadAttribute = class {
type;
argument;
constructor(e) {
this.type = 'JSXSpreadAttribute', this.argument = e;
}
};
const JSXText = class {
type;
value;
raw;
constructor(e, t) {
this.type = 'JSXText', this.value = e, this.raw = t;
}
};
const ArrayExpression = class {
type;
elements;
constructor(e) {
this.type = 'ArrayExpression', this.elements = e;
}
};
const ArrayPattern = class {
type;
elements;
constructor(e) {
this.type = 'ArrayPattern', this.elements = e;
}
};
const ArrowFunctionExpression = class {
type;
id;
params;
body;
generator;
expression;
async;
constructor(e, t, s, i) {
this.type = 'ArrowFunctionExpression', this.id = null, this.params = e, this.body = t, this.generator = !1, this.expression = s, this.async = i;
}
};
const AssignmentExpression = class {
type;
operator;
left;
right;
constructor(e, t, s) {
this.type = 'AssignmentExpression', this.operator = e, this.left = t, this.right = s;
}
};
const AssignmentPattern = class {
type;
left;
right;
constructor(e, t) {
this.type = 'AssignmentPattern', this.left = e, this.right = t;
}
};
const AsyncFunctionDeclaration = class {
type;
id;
params;
body;
generator;
expression;
async;
constructor(e, t, s, i) {
this.type = 'FunctionDeclaration', this.id = e, this.params = t, this.body = s, this.generator = i, this.expression = !1, this.async = !0;
}
};
const AwaitExpression = class {
type;
argument;
constructor(e) {
this.type = 'AwaitExpression', this.argument = e;
}
};
const BigIntLiteral = class {
type;
value;
raw;
bigint;
constructor(e, t, s) {
this.type = 'Literal', this.value = e, this.raw = t, this.bigint = s;
}
};
const BinaryExpression = class {
type;
operator;
left;
right;
constructor(e, t, s) {
this.type = 'BinaryExpression', this.operator = e, this.left = t, this.right = s;
}
};
const BlockStatement = class {
type;
body;
constructor(e) {
this.type = 'BlockStatement', this.body = e;
}
};
const BreakStatement = class {
type;
label;
constructor(e) {
this.type = 'BreakStatement', this.label = e;
}
};
const CallExpression = class {
type;
callee;
arguments;
optional;
constructor(e, t, s) {
this.type = 'CallExpression', this.callee = e, this.arguments = t, this.optional = s;
}
};
const CatchClause = class {
type;
param;
body;
constructor(e, t) {
this.type = 'CatchClause', this.param = e, this.body = t;
}
};
const ChainExpression = class {
type;
expression;
constructor(e) {
this.type = 'ChainExpression', this.expression = e;
}
};
const ClassBody = class {
type;
body;
constructor(e) {
this.type = 'ClassBody', this.body = e;
}
};
const ClassDeclaration = class {
type;
id;
superClass;
body;
decorators;
constructor(e, t, s, i) {
this.type = 'ClassDeclaration', this.id = e, this.superClass = t, this.body = s, this.decorators = i;
}
};
const ClassExpression = class {
type;
id;
superClass;
body;
decorators;
constructor(e, t, s, i) {
this.type = 'ClassExpression', this.id = e, this.superClass = t, this.body = s, this.decorators = i;
}
};
const ConditionalExpression = class {
type;
test;
consequent;
alternate;
constructor(e, t, s) {
this.type = 'ConditionalExpression', this.test = e, this.consequent = t, this.alternate = s;
}
};
const ContinueStatement = class {
type;
label;
constructor(e) {
this.type = 'ContinueStatement', this.label = e;
}
};
const DebuggerStatement = class {
type;
constructor() {
this.type = 'DebuggerStatement';
}
};
const Decorator = class {
type;
expression;
constructor(e) {
this.type = 'Decorator', this.expression = e;
}
};
const Directive = class {
type;
expression;
directive;
constructor(e, t) {
this.type = 'ExpressionStatement', this.expression = e, this.directive = t;
}
};
const DoWhileStatement = class {
type;
body;
test;
constructor(e, t) {
this.type = 'DoWhileStatement', this.body = e, this.test = t;
}
};
const EmptyStatement = class {
type;
constructor() {
this.type = 'EmptyStatement';
}
};
const ExportAllDeclaration = class {
type;
source;
exported;
assertions;
constructor(e, t, s) {
this.type = 'ExportAllDeclaration', this.source = e, this.exported = t, this.assertions = s;
}
};
const ExportDefaultDeclaration = class {
type;
declaration;
constructor(e) {
this.type = 'ExportDefaultDeclaration', this.declaration = e;
}
};
const ExportNamedDeclaration = class {
type;
declaration;
specifiers;
source;
assertions;
constructor(e, t, s, i) {
this.type = 'ExportNamedDeclaration', this.declaration = e, this.specifiers = t, this.source = s, this.assertions = i;
}
};
const ExportSpecifier = class {
type;
exported;
local;
constructor(e, t) {
this.type = 'ExportSpecifier', this.exported = t, this.local = e;
}
};
const ExpressionStatement = class {
type;
expression;
constructor(e) {
this.type = 'ExpressionStatement', this.expression = e;
}
};
const ForInStatement = class {
type;
left;
right;
body;
each;
constructor(e, t, s) {
this.type = 'ForInStatement', this.left = e, this.right = t, this.body = s, this.each = !1;
}
};
const ForOfStatement = class {
type;
await;
left;
right;
body;
constructor(e, t, s, i) {
this.type = 'ForOfStatement', this.await = i, this.left = e, this.right = t, this.body = s;
}
};
const ForStatement = class {
type;
init;
test;
update;
body;
constructor(e, t, s, i) {
this.type = 'ForStatement', this.init = e, this.test = t, this.update = s, this.body = i;
}
};
const FunctionDeclaration = class {
type;
id;
params;
body;
generator;
expression;
async;
constructor(e, t, s, i) {
this.type = 'FunctionDeclaration', this.id = e, this.params = t, this.body = s, this.generator = i, this.expression = !1, this.async = !1;
}
};
const FunctionExpression = class {
type;
id;
params;
body;
generator;
expression;
async;
constructor(e, t, s, i, r) {
this.type = 'FunctionExpression', this.id = e, this.params = t, this.body = s, this.generator = i, this.expression = !1, this.async = r;
}
};
const Identifier = class {
type;
name;
constructor(e) {
this.type = 'Identifier', this.name = e;
}
};
const IfStatement = class {
type;
test;
consequent;
alternate;
constructor(e, t, s) {
this.type = 'IfStatement', this.test = e, this.consequent = t, this.alternate = s;
}
};
const ImportAttribute = class {
type;
key;
value;
constructor(e, t) {
this.type = 'ImportAttribute', this.key = e, this.value = t;
}
};
const ImportExpression = class {
type;
source;
attributes;
constructor(e, t) {
this.type = 'ImportExpression', this.source = e, this.attributes = t;
}
};
const ImportDeclaration = class {
type;
specifiers;
source;
assertions;
constructor(e, t, s) {
this.type = 'ImportDeclaration', this.specifiers = e, this.source = t, this.assertions = s;
}
};
const ImportDefaultSpecifier = class {
type;
local;
constructor(e) {
this.type = 'ImportDefaultSpecifier', this.local = e;
}
};
const ImportNamespaceSpecifier = class {
type;
local;
constructor(e) {
this.type = 'ImportNamespaceSpecifier', this.local = e;
}
};
const ImportSpecifier = class {
type;
local;
imported;
constructor(e, t) {
this.type = 'ImportSpecifier', this.local = e, this.imported = t;
}
};
const LabeledStatement = class {
type;
label;
body;
constructor(e, t) {
this.type = 'LabeledStatement', this.label = e, this.body = t;
}
};
const Literal = class {
type;
value;
raw;
constructor(e, t) {
this.type = 'Literal', this.value = e, this.raw = t;
}
};
const LogicalExpression = class {
type;
operator;
left;
right;
constructor(e, t, s) {
this.type = 'LogicalExpression', this.operator = e, this.left = t, this.right = s;
}
};
const MemberExpression = class {
type;
computed;
object;
property;
optional;
constructor(e, t, s, i) {
this.type = 'MemberExpression', this.computed = e, this.object = t, this.property = s, this.optional = i;
}
};
const MetaProperty = class {
type;
meta;
property;
constructor(e, t) {
this.type = 'MetaProperty', this.meta = e, this.property = t;
}
};
const MethodDefinition = class {
type;
key;
computed;
value;
kind;
static;
decorators;
constructor(e, t, s, i, r, n) {
this.type = 'MethodDefinition', this.key = e, this.computed = t, this.value = s, this.kind = i, this.static = r, this.decorators = n;
}
};
const Module = class {
type;
body;
sourceType;
constructor(e) {
this.type = 'Program', this.body = e, this.sourceType = 'module';
}
};
const NewExpression = class {
type;
callee;
arguments;
constructor(e, t) {
this.type = 'NewExpression', this.callee = e, this.arguments = t;
}
};
const ObjectExpression = class {
type;
properties;
constructor(e) {
this.type = 'ObjectExpression', this.properties = e;
}
};
const ObjectPattern = class {
type;
properties;
constructor(e) {
this.type = 'ObjectPattern', this.properties = e;
}
};
const PrivateIdentifier = class {
type;
name;
constructor(e) {
this.type = 'PrivateIdentifier', this.name = e;
}
};
const Program = class {
type;
body;
sourceType;
constructor(e, t) {
this.type = 'Program', this.sourceType = e, this.body = t;
}
};
const Property = class {
type;
key;
computed;
value;
kind;
method;
shorthand;
constructor(e, t, s, i, r, n) {
this.type = 'Property', this.key = t, this.computed = s, this.value = i, this.kind = e, this.method = r, this.shorthand = n;
}
};
const PropertyDefinition = class {
type;
key;
computed;
value;
static;
decorators;
constructor(e, t, s, i, r) {
this.type = 'Property', this.key = e, this.computed = t, this.value = s, this.static = i, this.decorators = r;
}
};
const RegexLiteral = class {
type;
value;
raw;
regex;
constructor(e, t, s, i) {
this.type = 'Literal', this.value = e, this.raw = t, this.regex = {
pattern: s,
flags: i
};
}
};
const RestElement = class {
type;
argument;
constructor(e) {
this.type = 'RestElement', this.argument = e;
}
};
const ReturnStatement = class {
type;
argument;
constructor(e) {
this.type = 'ReturnStatement', this.argument = e;
}
};
const Script = class {
type;
body;
sourceType;
constructor(e) {
this.type = 'Program', this.body = e, this.sourceType = 'script';
}
};
const SequenceExpression = class {
type;
expressions;
constructor(e) {
this.type = 'SequenceExpression', this.expressions = e;
}
};
const SpreadElement = class {
type;
argument;
constructor(e) {
this.type = 'SpreadElement', this.argument = e;
}
};
const StaticBlock = class {
type;
body;
constructor(e) {
this.type = 'StaticBlock', this.body = e;
}
};
const Super = class {
type;
constructor() {
this.type = 'Super';
}
};
const SwitchCase = class {
type;
test;
consequent;
constructor(e, t) {
this.type = 'SwitchCase', this.test = e, this.consequent = t;
}
};
const SwitchStatement = class {
type;
discriminant;
cases;
constructor(e, t) {
this.type = 'SwitchStatement', this.discriminant = e, this.cases = t;
}
};
const TaggedTemplateExpression = class {
type;
tag;
quasi;
constructor(e, t) {
this.type = 'TaggedTemplateExpression', this.tag = e, this.quasi = t;
}
};
const TemplateElement = class {
type;
value;
tail;
constructor(e, t) {
this.type = 'TemplateElement', this.value = e, this.tail = t;
}
};
const TemplateLiteral = class {
type;
quasis;
expressions;
constructor(e, t) {
this.type = 'TemplateLiteral', this.quasis = e, this.expressions = t;
}
};
const ThisExpression = class {
type;
constructor() {
this.type = 'ThisExpression';
}
};
const ThrowStatement = class {
type;
argument;
constructor(e) {
this.type = 'ThrowStatement', this.argument = e;
}
};
const TryStatement = class {
type;
block;
handler;
finalizer;
constructor(e, t, s) {
this.type = 'TryStatement', this.block = e, this.handler = t, this.finalizer = s;
}
};
const UnaryExpression = class {
type;
operator;
argument;
prefix;
constructor(e, t) {
this.type = 'UnaryExpression', this.operator = e, this.argument = t, this.prefix = !0;
}
};
const UpdateExpression = class {
type;
operator;
argument;
prefix;
constructor(e, t, s) {
this.type = 'UpdateExpression', this.operator = e, this.argument = t, this.prefix = s;
}
};
const VariableDeclaration = class {
type;
declarations;
kind;
constructor(e, t) {
this.type = 'VariableDeclaration', this.declarations = e, this.kind = t;
}
};
const VariableDeclarator = class {
type;
id;
init;
constructor(e, t) {
this.type = 'VariableDeclarator', this.id = e, this.init = t;
}
};
const WhileStatement = class {
type;
test;
body;
constructor(e, t) {
this.type = 'WhileStatement', this.test = e, this.body = t;
}
};
const WithStatement = class {
type;
object;
body;
constructor(e, t) {
this.type = 'WithStatement', this.object = e, this.body = t;
}
};
const YieldExpression = class {
type;
argument;
delegate;
constructor(e, t) {
this.type = 'YieldExpression', this.argument = e, this.delegate = t;
}
};
function assert(e, t) {
if (!e) throw new Error(`ASSERT: ${t}`);
}
const ErrorHandler = class {
errors;
tolerant;
constructor() {
this.errors = [], this.tolerant = !1;
}
recordError(e) {
this.errors.push(e);
}
tolerate(e) {
if (!this.tolerant) throw e;
this.recordError(e);
}
constructError(e, t) {
let s = new Error(e);
try {
throw s;
} catch (e) {
Object.create && Object.defineProperty && (s = Object.create(e), Object.defineProperty(s, 'column', {
value: t
}));
}
return s;
}
createError(e, t, s, i) {
const r = `Line ${t}: ${i}`;
const n = this.constructError(r, s);
n.index = e, n.lineNumber = t, n.description = i;
return n;
}
throwError(e, t, s, i) {
throw this.createError(e, t, s, i);
}
tolerateError(e, t, s, i) {
const r = this.createError(e, t, s, i);
if (!this.tolerant) throw r;
this.recordError(r);
}
};
const Messages = {
AsyncFunctionInSingleStatementContext: 'Async functions can only be declared at the top level or inside a block.',
BadImportCallArity: 'Unexpected token',
BadGetterArity: 'Getter must not have any formal parameters',
BadSetterArity: 'Setter must have exactly one formal parameter',
BadSetterRestParameter: 'Setter function argument must not be a rest parameter',
CannotUseImportMetaOutsideAModule: "Cannot use 'import.meta' outside a module",
ConstructorIsAsync: 'Class constructor may not be an async method',
ConstructorIsPrivate: 'Class constructor may not be a private method',
ConstructorSpecialMethod: 'Class constructor may not be an accessor',
DeclarationMissingInitializer: 'Missing initializer in %0 declaration',
DefaultRestParameter: 'Unexpected token =',
DefaultRestProperty: 'Unexpected token =',
DuplicateBinding: 'Duplicate binding %0',
DuplicateConstructor: 'A class may only have one constructor',
DuplicateParameter: 'Duplicate parameter name not allowed in this context',
DuplicateProtoProperty: 'Duplicate __proto__ fields are not allowed in object literals',
ForInOfLoopInitializer: '%0 loop variable declaration may not have an initializer',
GeneratorInLegacyContext: 'Generator declarations are not allowed in legacy contexts',
IllegalBreak: 'Illegal break statement',
IllegalContinue: 'Illegal continue statement',
IllegalExportDeclaration: 'Unexpected token',
IllegalImportDeclaration: 'Unexpected token',
IllegalLanguageModeDirective: "Illegal 'use strict' directive in function with non-simple parameter list",
IllegalReturn: 'Illegal return statement',
InvalidEscapedReservedWord: 'Keyword must not contain escaped characters',
InvalidHexEscapeSequence: 'Invalid hexadecimal escape sequence',
InvalidLHSInAssignment: 'Invalid left-hand side in assignment',
InvalidLHSInForIn: 'Invalid left-hand side in for-in',
InvalidLHSInForLoop: 'Invalid left-hand side in for-loop',
InvalidModuleSpecifier: 'Unexpected token',
InvalidRegExp: 'Invalid regular expression',
InvalidTaggedTemplateOnOptionalChain: 'Invalid tagged template on optional chain',
InvalidUnicodeEscapeSequence: 'Invalid Unicode escape sequence',
LetInLexicalBinding: 'let is disallowed as a lexically bound name',
MissingFromClause: 'Unexpected token',
MultipleDefaultsInSwitch: 'More than one default clause in switch statement',
NewlineAfterThrow: 'Illegal newline after throw',
NoAsAfterImportNamespace: 'Unexpected token',
NoAsAndFromEscapeSequences: 'The `as` and `from` contextual keywords must not contain Unicode escape sequences.',
NoCatchOrFinally: 'Missing catch or finally after try',
NoSemicolonAfterDecorator: 'Decorators must not be followed by a semicolon.',
NumericSeperatorOneUnderscore: 'Numeric separator must be exactly one underscore',
NumericSeperatorNotAllowedHere: 'Numeric separator is not allowed here',
ParameterAfterRestParameter: 'Rest parameter must be last formal parameter',
PropertyAfterRestProperty: 'Unexpected token',
Redeclaration: "%0 '%1' has already been declared",
StaticPrototype: 'Classes may not have static property named prototype',
StrictCatchVariable: 'Catch variable may not be eval or arguments in strict mode',
StrictDelete: 'Delete of an unqualified identifier in strict mode.',
StrictFunction: 'In strict mode code, functions can only be declared at top level or inside a block',
StrictFunctionName: 'Function name may not be eval or arguments in strict mode',
StrictLHSAssignment: 'Assignment to eval or arguments is not allowed in strict mode',
StrictLHSPostfix: 'Postfix increment/decrement may not have eval or arguments operand in strict mode',
StrictLHSPrefix: 'Prefix increment/decrement may not have eval or arguments operand in strict mode',
StrictModeWith: 'Strict mode code may not include a with statement',
StrictOctalLiteral: 'Octal literals are not allowed in strict mode.',
StrictParamName: 'Parameter name eval or arguments is not allowed in strict mode',
StrictReservedWord: 'Use of future reserved word in strict mode',
StrictVarName: 'Variable name may not be eval or arguments in strict mode',
TemplateOctalLiteral: 'Octal literals are not allowed in template strings.',
TemplateEscape89: '\\8 and \\9 are not allowed in template strings.',
UnexpectedEOS: 'Unexpected end of input',
UnexpectedIdentifier: 'Unexpected identifier',
UnexpectedNumber: 'Unexpected number',
UnexpectedReserved: 'Unexpected reserved word',
UnexpectedString: 'Unexpected string',
UnexpectedSuper: "'super' keyword unexpected here",
UnexpectedTemplate: 'Unexpected quasi %0',
UnexpectedToken: 'Unexpected token %0',
UnexpectedTokenIllegal: 'Unexpected token ILLEGAL',
UnknownLabel: "Undefined label '%0'",
UnterminatedRegExp: 'Invalid regular expression: missing /'
};
const TokenName = {};
function hexValue(e) {
return '0123456789abcdef'.indexOf(e.toLowerCase());
}
function octalValue(e) {
return '01234567'.indexOf(e);
}
TokenName[1] = 'Boolean', TokenName[2] = '<end>', TokenName[3] = 'Identifier', TokenName[4] = 'Keyword', TokenName[5] = 'Null', TokenName[6] = 'Numeric', TokenName[7] = 'Punctuator', TokenName[8] = 'String', TokenName[9] = 'RegularExpression', TokenName[10] = 'Template';
const Scanner = class {
source;
errorHandler;
trackComment;
isModule;
index;
lineNumber;
lineStart;
curlyStack;
length;
constructor(e, t) {
this.source = e, this.errorHandler = t, this.trackComment = !1, this.isModule = !1, this.length = e.length, this.index = 0, this.lineNumber = e.length > 0 ? 1 : 0, this.lineStart = 0, this.curlyStack = [];
}
saveState() {
return {
index: this.index,
lineNumber: this.lineNumber,
lineStart: this.lineStart,
curlyStack: this.curlyStack.slice()
};
}
restoreState(e) {
this.index = e.index, this.lineNumber = e.lineNumber, this.lineStart = e.lineStart, this.curlyStack = e.curlyStack;
}
eof() {
return this.index >= this.length;
}
throwUnexpectedToken(e = Messages.UnexpectedTokenIllegal) {
return this.errorHandler.throwError(this.index, this.lineNumber, this.index - this.lineStart + 1, e);
}
tolerateUnexpectedToken(e = Messages.UnexpectedTokenIllegal) {
this.errorHandler.tolerateError(this.index, this.lineNumber, this.index - this.lineStart + 1, e);
}
skipSingleLineComment(e) {
let t; let s; let
i = [];
for (this.trackComment && (i = [], t = this.index - e, s = {
start: {
line: this.lineNumber,
column: this.index - this.lineStart - e
},
end: {}
}); !this.eof();) {
const r = this.source.charCodeAt(this.index);
if (++this.index, Character.isLineTerminator(r)) {
if (this.trackComment) {
s.end = {
line: this.lineNumber,
column: this.index - this.lineStart - 1
};
const r = {
multiLine: !1,
slice: [t + e, this.index - 1],
range: [t, this.index - 1],
loc: s
};
i.push(r);
}
return r === 13 && this.source.charCodeAt(this.index) === 10 && ++this.index, ++this.lineNumber, this.lineStart = this.index, i;
}
}
if (this.trackComment) {
s.end = {
line: this.lineNumber,
column: this.index - this.lineStart
};
const r = {
multiLine: !1,
slice: [t + e, this.index],
range: [t, this.index],
loc: s
};
i.push(r);
}
return i;
}
skipMultiLineComment() {
let e; let t; let
s = [];
for (this.trackComment && (s = [], e = this.index - 2, t = {
start: {
line: this.lineNumber,
column: this.index - this.lineStart - 2
},
end: {}
}); !this.eof();) {
const i = this.source.charCodeAt(this.index);
if (Character.isLineTerminator(i)) i === 13 && this.source.charCodeAt(this.index + 1) === 10 && ++this.index, ++this.lineNumber, ++this.index, this.lineStart = this.index;
else if (i === 42) {
if (this.source.charCodeAt(this.index + 1) === 47) {
if (this.index += 2, this.trackComment) {
t.end = {
line: this.lineNumber,
column: this.index - this.lineStart
};
const i = {
multiLine: !0,
slice: [e + 2, this.index - 2],
range: [e, this.index],
loc: t
};
s.push(i);
}
return s;
}++this.index;
} else ++this.index;
}
if (this.trackComment) {
t.end = {
line: this.lineNumber,
column: this.index - this.lineStart
};
const i = {
multiLine: !0,
slice: [e + 2, this.index],
range: [e, this.index],
loc: t
};
s.push(i);
}
return this.tolerateUnexpectedToken(), s;
}
scanComments() {
let e;
this.trackComment && (e = []);
let t = this.index === 0;
for (; !this.eof();) {
let s = this.source.charCodeAt(this.index);
if (Character.isWhiteSpace(s)) ++this.index;
else if (Character.isLineTerminator(s)) ++this.index, s === 13 && this.source.charCodeAt(this.index) === 10 && ++this.index, ++this.lineNumber, this.lineStart = this.index, t = !0;
else if (s === 47) {
if (s = this.source.charCodeAt(this.index + 1), s === 47) {
this.index += 2;
const s = this.skipSingleLineComment(2);
this.trackComment && (e = e.concat(s)), t = !0;
} else {
if (s !== 42) break;
{
this.index += 2;
const t = this.skipMultiLineComment();
this.trackComment && (e = e.concat(t));
}
}
} else if (t && s === 45) {
if (this.source.charCodeAt(this.index + 1) !== 45 || this.source.charCodeAt(this.index + 2) !== 62) break;
{
this.index += 3;
const t = this.skipSingleLineComment(3);
this.trackComment && (e = e.concat(t));
}
} else {
if (s !== 60 || this.isModule) break;
if (this.source.slice(this.index + 1, this.index + 4) !== '!--') break;
{
this.index += 4;
const t = this.skipSingleLineComment(4);
this.trackComment && (e = e.concat(t));
}
}
}
return e;
}
isFutureReservedWord(e) {
switch (e) {
case 'enum':
case 'export':
case 'import':
case 'super':
return !0;
default:
return !1;
}
}
isStrictModeReservedWord(e) {
switch (e) {
case 'implements':
case 'interface':
case 'package':
case 'private':
case 'protected':
case 'public':
case 'static':
case 'yield':
case 'let':
return !0;
default:
return !1;
}
}
isRestrictedWord(e) {
return e === 'eval' || e === 'arguments';
}
isKeyword(e) {
switch (e.length) {
case 2:
return e === 'if' || e === 'in' || e === 'do';
case 3:
return e === 'var' || e === 'for' || e === 'new' || e === 'try' || e === 'let';
case 4:
return e === 'this' || e === 'else' || e === 'case' || e === 'void' || e === 'with' || e === 'enum';
case 5:
return e === 'while' || e === 'break' || e === 'catch' || e === 'throw' || e === 'const' || e === 'yield' || e === 'class' || e === 'super';
case 6:
return e === 'return' || e === 'typeof' || e === 'delete' || e === 'switch' || e === 'export' || e === 'import';
case 7:
return e === 'default' || e === 'finally' || e === 'extends';
case 8:
return e === 'function' || e === 'continue' || e === 'debugger';
case 10:
return e === 'instanceof';
default:
return !1;
}
}
codePointAt(e) {
let t = this.source.charCodeAt(e);
if (t >= 55296 && t <= 56319) {
const s = this.source.charCodeAt(e + 1);
if (s >= 56320 && s <= 57343) {
t = 1024 * (t - 55296) + s - 56320 + 65536;
}
}
return t;
}
scanHexEscape(e) {
const t = e === 'u' ? 4 : 2;
let s = 0;
for (let e = 0; e < t; ++e) {
if (this.eof() || !Character.isHexDigit(this.source.charCodeAt(this.index))) return null;
s = 16 * s + hexValue(this.source[this.index++]);
}
return String.fromCharCode(s);
}
tryToScanUnicodeCodePointEscape() {
let e = this.source[this.index];
let t = 0;
if (e === '}') return null;
for (; !this.eof() && (e = this.source[this.index++], Character.isHexDigit(e.charCodeAt(0)));) t = 16 * t + hexValue(e);
return t > 1114111 || e !== '}' ? null : Character.fromCodePoint(t);
}
scanUnicodeCodePointEscape() {
const e = this.tryToScanUnicodeCodePointEscape();
return e === null ? this.throwUnexpectedToken() : e;
}
getIdentifier() {
const e = this.index++;
for (; !this.eof();) {
const t = this.source.charCodeAt(this.index);
if (t === 92) return this.index = e, this.getComplexIdentifier();
if (t >= 55296 && t < 57343) return this.index = e, this.getComplexIdentifier();
if (!Character.isIdentifierPart(t)) break;
++this.index;
}
return this.source.slice(e, this.index);
}
getComplexIdentifier() {
let e; let t = this.codePointAt(this.index);
let s = Character.fromCodePoint(t);
for (this.index += s.length, t === 92 && (this.source.charCodeAt(this.index) !== 117 && this.throwUnexpectedToken(), ++this.index, this.source[this.index] === '{' ? (++this.index, e = this.scanUnicodeCodePointEscape()) : (e = this.scanHexEscape('u'), e !== null && e !== '\\' && Character.isIdentifierStart(e.charCodeAt(0)) || this.throwUnexpectedToken()), s = e); !this.eof() && (t = this.codePointAt(this.index), Character.isIdentifierPart(t));) e = Character.fromCodePoint(t), s += e, this.index += e.length, t === 92 && (s = s.substr(0, s.length - 1), this.source.charCodeAt(this.index) !== 117 && this.throwUnexpectedToken(), ++this.index, this.source[this.index] === '{' ? (++this.index, e = this.scanUnicodeCodePointEscape()) : (e = this.scanHexEscape('u'), e !== null && e !== '\\' && Character.isIdentifierPart(e.charCodeAt(0)) || this.throwUnexpectedToken()), s += e);
return s;
}
octalToDecimal(e) {
let t = e !== '0';
let s = octalValue(e);
return !this.eof() && Character.isOctalDigit(this.source.charCodeAt(this.index)) && (t = !0, s = 8 * s + octalValue(this.source[this.index++]), '0123'.indexOf(e) >= 0 && !this.eof() && Character.isOctalDigit(this.source.charCodeAt(this.index)) && (s = 8 * s + octalValue(this.source[this.index++]))), {
code: s,
octal: t
};
}
scanIdentifier() {
let e;
const t = this.index;
const s = this.source.charCodeAt(t) === 92;
const i = s ? this.getComplexIdentifier() : this.getIdentifier();
if (e = i.length === 1 ? 3 : this.isKeyword(i) ? 4 : i === 'null' ? 5 : i === 'true' || i === 'false' ? 1 : 3, e !== 3 && t + i.length !== this.index) {
const e = this.index;
this.index = t, this.tolerateUnexpectedToken(Messages.InvalidEscapedReservedWord), this.index = e;
}
return {
type: e,
value: i,
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: t,
end: this.index,
escaped: s
};
}
scanPunctuator() {
const e = this.index;
let t = this.source[this.index];
switch (t) {
case '(':
case '{':
t === '{' && this.curlyStack.push('{'), ++this.index;
break;
case '.':
++this.index, this.source[this.index] === '.' && this.source[this.index + 1] === '.' && (this.index += 2, t = '...');
break;
case '}':
++this.index, this.curlyStack.pop();
break;
case '?':
++this.index, this.source[this.index] === '?' && (++this.index, this.source[this.index] === '=' ? (++this.index, t = '??=') : t = '??'), this.source[this.index] !== '.' || /^\d$/.test(this.source[this.index + 1]) || (++this.index, t = '?.');
break;
case '#':
case ')':
case ';':
case ',':
case '[':
case ']':
case ':':
case '~':
case '@':
++this.index;
break;
default:
t = this.source.substr(this.index, 4), t === '>>>=' ? this.index += 4 : (t = t.substr(0, 3), t === '===' || t === '!==' || t === '>>>' || t === '<<=' || t === '>>=' || t === '**=' || t === '&&=' || t === '||=' ? this.index += 3 : (t = t.substr(0, 2), t === '&&' || t === '||' || t === '==' || t === '!=' || t === '+=' || t === '-=' || t === '*=' || t === '/=' || t === '++' || t === '--' || t === '<<' || t === '>>' || t === '&=' || t === '|=' || t === '^=' || t === '%=' || t === '<=' || t === '>=' || t === '=>' || t === '**' ? this.index += 2 : (t = this.source[this.index], '<>=!+-*%&|^/'.indexOf(t) >= 0 && ++this.index)));
}
return this.index === e && this.throwUnexpectedToken(), {
type: 7,
value: t,
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: e,
end: this.index
};
}
scanHexLiteral(e) {
const t = this.scanLiteralPart(Character.isHexDigitChar);
return t.length === 0 && this.throwUnexpectedToken(), this.source[this.index] === 'n' ? (this.index++, {
type: 6,
value: BigInt(`0x${t}`),
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: e,
end: this.index
}) : (Character.isIdentifierStart(this.source.charCodeAt(this.index)) && this.throwUnexpectedToken(), {
type: 6,
value: parseInt(`0x${t}`, 16),
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: e,
end: this.index
});
}
scanBinaryLiteral(e) {
let t; const
s = this.scanLiteralPart((e => e === '0' || e === '1'));
return s.length === 0 && this.throwUnexpectedToken(), this.source[this.index] === 'n' ? (this.index++, {
type: 6,
value: BigInt(`0b${s}`),
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: e,
end: this.index
}) : (this.eof() || (t = this.source.charCodeAt(this.index), (Character.isIdentifierStart(t) || Character.isDecimalDigit(t)) && this.throwUnexpectedToken()), {
type: 6,
value: parseInt(s, 2),
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: e,
end: this.index
});
}
scanOctalLiteral(e, t) {
let s = '';
let i = !1;
return Character.isOctalDigit(e.charCodeAt(0)) ? (i = !0, s = `0${this.source[this.index++]}`) : ++this.index, s += this.scanLiteralPart(Character.isOctalDigitChar), i || s.length !== 0 || this.throwUnexpectedToken(), this.source[this.index] === 'n' ? (this.index++, {
type: 6,
value: BigInt(`0o${s}`),
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: t,
end: this.index
}) : ((Character.isIdentifierStart(this.source.charCodeAt(this.index)) || Character.isDecimalDigit(this.source.charCodeAt(this.index))) && this.throwUnexpectedToken(), {
type: 6,
value: parseInt(s, 8),
octal: i,
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: t,
end: this.index
});
}
isImplicitOctalLiteral() {
for (let e = this.index + 1; e < this.length; ++e) {
const t = this.source[e];
if (t === '8' || t === '9' || t === 'n') return !1;
if (!Character.isOctalDigit(t.charCodeAt(0))) return !0;
}
return !0;
}
scanLiteralPart(e) {
let t = '';
for (this.source[this.index] === '_' && this.throwUnexpectedToken(Messages.NumericSeperatorNotAllowedHere); this.source[this.index] && (e(this.source[this.index]) || this.source[this.index] === '_');) this.source[this.index] !== '_' && (t += this.source[this.index]), this.index++, this.source[this.index - 1] === '_' && this.source[this.index] === '_' && this.throwUnexpectedToken(Messages.NumericSeperatorOneUnderscore);
return this.source[this.index - 1] === '_' && this.throwUnexpectedToken(Messages.NumericSeperatorNotAllowedHere), t;
}
scanNumericLiteral() {
const e = this.index;
let t = this.source[e];
assert(Character.isDecimalDigit(t.charCodeAt(0)) || t === '.', 'Numeric literal must start with a decimal digit or a decimal point');
let s = '';
if (t !== '.') {
if (s = this.source[this.index++], t = this.source[this.index], s === '0') {
if (t === 'x' || t === 'X') return ++this.index, this.scanHexLiteral(e);
if (t === 'b' || t === 'B') return ++this.index, this.scanBinaryLiteral(e);
if (t === 'o' || t === 'O') return this.scanOctalLiteral(t, e);
if (t && Character.isOctalDigit(t.charCodeAt(0)) && this.isImplicitOctalLiteral()) return this.scanOctalLiteral(t, e);
}
this.index--, s = this.scanLiteralPart(Character.isDecimalDigitChar), t = this.source[this.index];
}
if (t === '.' && (s += this.source[this.index++], s += this.scanLiteralPart(Character.isDecimalDigitChar), t = this.source[this.index]), t === 'e' || t === 'E') s += this.source[this.index++], t = this.source[this.index], t !== '+' && t !== '-' || (s += this.source[this.index++]), Character.isDecimalDigit(this.source.charCodeAt(this.index)) ? s += this.scanLiteralPart(Character.isDecimalDigitChar) : this.throwUnexpectedToken();
else if (t === 'n') {
return s.length > 1 && s[0] === '0' && this.throwUnexpectedToken(), this.index++, {
type: 6,
value: BigInt(s),
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: e,
end: this.index
};
}
return Character.isIdentifierStart(this.source.charCodeAt(this.index)) && this.throwUnexpectedToken(), {
type: 6,
value: parseFloat(s),
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: e,
end: this.index
};
}
scanStringLiteral() {
const e = this.index;
let t = this.source[e];
assert(t === "'" || t === '"', 'String literal must starts with a quote'), ++this.index;
let s = !1;
let i = '';
for (; !this.eof();) {
let e = this.source[this.index++];
if (e === t) {
t = '';
break;
}
if (e === '\\') {
if (e = this.source[this.index++], e && Character.isLineTerminator(e.charCodeAt(0))) ++this.lineNumber, e === '\r' && this.source[this.index] === '\n' && ++this.index, this.lineStart = this.index;
else {
switch (e) {
case 'u':
if (this.source[this.index] === '{') ++this.index, i += this.scanUnicodeCodePointEscape();
else {
const t = this.scanHexEscape(e);
t === null && this.throwUnexpectedToken(), i += t;
}
break;
case 'x':
const t = this.scanHexEscape(e);
t === null && this.throwUnexpectedToken(Messages.InvalidHexEscapeSequence), i += t;
break;
case 'n':
i += '\n';
break;
case 'r':
i += '\r';
break;
case 't':
i += '\t';
break;
case 'b':
i += '\b';
break;
case 'f':
i += '\f';
break;
case 'v':
i += '\v';
break;
case '8':
case '9':
i += e, this.tolerateUnexpectedToken();
break;
default:
if (e && Character.isOctalDigit(e.charCodeAt(0))) {
const t = this.octalToDecimal(e);
s = t.octal || s, i += String.fromCharCode(t.code);
} else i += e;
}
}
} else {
if (Character.isLineTerminator(e.charCodeAt(0))) break;
i += e;
}
}
return t !== '' && (this.index = e, this.throwUnexpectedToken()), {
type: 8,
value: i,
octal: s,
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: e,
end: this.index
};
}
scanTemplate() {
let e = '';
let t = !1;
const s = this.index;
const i = this.source[s] === '`';
let r = !1;
let n = null;
let a = 2;
for (++this.index; !this.eof();) {
let s = this.source[this.index++];
if (s === '`') {
a = 1, r = !0, t = !0;
break;
}
if (s === '$') {
if (this.source[this.index] === '{') {
this.curlyStack.push('${'), ++this.index, t = !0;
break;
}
e += s;
} else {
if (n !== null) continue;
if (s === '\\') {
if (s = this.source[this.index++], Character.isLineTerminator(s.charCodeAt(0))) ++this.lineNumber, s === '\r' && this.source[this.index] === '\n' && ++this.index, this.lineStart = this.index;
else {
switch (s) {
case 'n':
e += '\n';
break;
case 'r':
e += '\r';
break;
case 't':
e += '\t';
break;
case 'u':
if (this.source[this.index] === '{') {
++this.index;
const t = this.tryToScanUnicodeCodePointEscape();
t === null ? n = 'u' : e += t;
} else {
const t = this.scanHexEscape(s);
t === null ? n = 'u' : e += t;
}
break;
case 'x':
const t = this.scanHexEscape(s);
t === null ? n = 'x' : e += t;
break;
case 'b':
e += '\b';
break;
case 'f':
e += '\f';
break;
case 'v':
e += '\v';
break;
default:
s === '0' ? Character.isDecimalDigit(this.source.charCodeAt(this.index)) ? n = '0' : e += '\0' : Character.isDecimalDigitChar(s) ? n = s : e += s;
}
}
} else Character.isLineTerminator(s.charCodeAt(0)) ? (++this.lineNumber, s === '\r' && this.source[this.index] === '\n' && ++this.index, this.lineStart = this.index, e += '\n') : e += s;
}
}
return t || this.throwUnexpectedToken(), i || this.curlyStack.pop(), {
type: 10,
value: this.source.slice(s + 1, this.index - a),
cooked: n === null ? e : null,
head: i,
tail: r,
notEscapeSequenceHead: n,
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: s,
end: this.index
};
}
testRegExp(e, t) {
let s = e;
t.indexOf('u') >= 0 && (s = s.replace(/\\u\{([0-9a-fA-F]+)\}|\\u([a-fA-F0-9]{4})/g, ((e, t, s) => {
const i = parseInt(t || s, 16);
return i > 1114111 && this.throwUnexpectedToken(Messages.InvalidRegExp), i <= 65535 ? String.fromCharCode(i) : '';
})).replace(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g, ''));
try {
RegExp(s);
} catch (e) {
this.throwUnexpectedToken(Messages.InvalidRegExp);
}
try {
return new RegExp(e, t);
} catch (e) {
return null;
}
}
scanRegExpBody() {
let e = this.source[this.index];
assert(e === '/', 'Regular expression literal must start with a slash');
let t = this.source[this.index++];
let s = !1;
let i = !1;
for (; !this.eof();) {
if (e = this.source[this.index++], t += e, e === '\\') e = this.source[this.index++], Character.isLineTerminator(e.charCodeAt(0)) && this.throwUnexpectedToken(Messages.UnterminatedRegExp), t += e;
else if (Character.isLineTerminator(e.charCodeAt(0))) this.throwUnexpectedToken(Messages.UnterminatedRegExp);
else if (s) e === ']' && (s = !1);
else {
if (e === '/') {
i = !0;
break;
}
e === '[' && (s = !0);
}
}
return i || this.throwUnexpectedToken(Messages.UnterminatedRegExp), t.substr(1, t.length - 2);
}
scanRegExpFlags() {
let e = '';
let t = '';
for (; !this.eof();) {
let s = this.source[this.index];
if (!Character.isIdentifierPart(s.charCodeAt(0))) break;
if (++this.index, s !== '\\' || this.eof()) t += s, e += s;
else if (s = this.source[this.index], s === 'u') {
++this.index;
let s = this.index;
const i = this.scanHexEscape('u');
if (i !== null) for (t += i, e += '\\u'; s < this.index; ++s) e += this.source[s];
else this.index = s, t += 'u', e += '\\u';
this.tolerateUnexpectedToken();
} else e += '\\', this.tolerateUnexpectedToken();
}
return t;
}
scanRegExp() {
const e = this.index;
const t = this.scanRegExpBody();
const s = this.scanRegExpFlags();
return {
type: 9,
value: '',
pattern: t,
flags: s,
regex: this.testRegExp(t, s),
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: e,
end: this.index
};
}
lex() {
if (this.eof()) {
return {
type: 2,
value: '',
lineNumber: this.lineNumber,
lineStart: this.lineStart,
start: this.index,
end: this.index
};
}
const e = this.source.charCodeAt(this.index);
return Character.isIdentifierStart(e) ? this.scanIdentifier() : e === 40 || e === 41 || e === 59 ? this.scanPunctuator() : e === 39 || e === 34 ? this.scanStringLiteral() : e === 46 ? Character.isDecimalDigit(this.source.charCodeAt(this.index + 1)) ? this.scanNumericLiteral() : this.scanPunctuator() : Character.isDecimalDigit(e) ? this.scanNumericLiteral() : e === 96 || e === 125 && this.curlyStack[this.curlyStack.length - 1] === '${' ? this.scanTemplate() : e >= 55296 && e < 57343 && Character.isIdentifierStart(this.codePointAt(this.index)) ? this.scanIdentifier() : this.scanPunctuator();
}
};
const ArrowParameterPlaceHolder = 'ArrowParameterPlaceHolder';
const Parser = class {
config;
delegate;
errorHandler;
scanner;
operatorPrecedence;
lookahead;
hasLineTerminator;
context;
tokens;
startMarker;
lastMarker;
constructor(e, t = {}, s) {
this.config = {
range: typeof t.range === 'boolean' && t.range,
loc: typeof t.loc === 'boolean' && t.loc,
source: null,
tokens: typeof t.tokens === 'boolean' && t.tokens,
comment: typeof t.comment === 'boolean' && t.comment,
tolerant: typeof t.tolerant === 'boolean' && t.tolerant
}, this.config.loc && t.source && t.source !== null && (this.config.source = String(t.source)), this.delegate = s, this.errorHandler = new ErrorHandler(), this.errorHandler.tolerant = this.config.tolerant == 1, this.scanner = new Scanner(e, this.errorHandler), this.scanner.trackComment = this.config.comment == 1, this.operatorPrecedence = {
')': 0,
';': 0,
',': 0,
'=': 0,
']': 0,
'??': 5,
'||': 6,
'&&': 7,
'|': 8,
'^': 9,
'&': 10,
'==': 11,
'!=': 11,
'===': 11,
'!==': 11,
'<': 12,
'>': 12,
'<=': 12,
'>=': 12,
'<<': 13,
'>>': 13,
'>>>': 13,
'+': 14,
'-': 14,
'*': 15,
'/': 15,
'%': 15
}, this.lookahead = {
type: 2,
value: '',
lineNumber: this.scanner.lineNumber,
lineStart: 0,
start: 0,
end: 0
}, this.hasLineTerminator = !1, this.context = {
isModule: !1,
isAsync: !1,
allowIn: !0,
allowStrictDirective: !0,
allowSuper: !1,
allowYield: !0,
firstCoverInitializedNameError: null,
isAssignmentTarget: !1,
isBindingElement: !1,
inConstructor: !1,
inFunctionBody: !1,
inIteration: !1,
inSwitch: !1,
inClassConstructor: !1,
labelSet: {},
strict: !1,
decorators: null
}, this.tokens = [], this.startMarker = {
index: 0,
line: this.scanner.lineNumber,
column: 0
}, this.lastMarker = {
index: 0,
line: this.scanner.lineNumber,
column: 0
}, this.nextToken(), this.lastMarker = {
index: this.scanner.index,
line: this.scanner.lineNumber,
column: this.scanner.index - this.scanner.lineStart
};
}
throwError(e, ...t) {
const s = t.slice();
const i = e.replace(/%(\d)/g, ((e, t) => (assert(t < s.length, 'Message reference must be in range'), s[t])));
const r = this.lastMarker.index;
const n = this.lastMarker.line;
const a = this.lastMarker.column + 1;
throw this.errorHandler.createError(r, n, a, i);
}
tolerateError(e, ...t) {
const s = t.slice();
const i = e.replace(/%(\d)/g, ((e, t) => (assert(t < s.length, 'Message reference must be in range'), s[t])));
const r = this.lastMarker.index;
const n = this.scanner.lineNumber;
const a = this.lastMarker.column + 1;
this.errorHandler.tolerateError(r, n, a, i);
}
unexpectedTokenError(e, t) {
let s; let
i = t || Messages.UnexpectedToken;
if (e ? (t || (i = e.type === 2 ? Messages.UnexpectedEOS : e.type === 3 ? Messages.UnexpectedIdentifier : e.type === 6 ? Messages.UnexpectedNumber : e.type === 8 ? Messages.UnexpectedString : e.type === 10 ? Messages.UnexpectedTemplate : Messages.UnexpectedToken, e.type === 4 && (this.scanner.isFutureReservedWord(e.value) ? i = Messages.UnexpectedReserved : this.context.strict && this.scanner.isStrictModeReservedWord(e.value) && (i = Messages.StrictReservedWord))), s = e.value) : s = 'ILLEGAL', i = i.replace('%0', s), e && typeof e.lineNumber === 'number') {
const t = e.start;
const s = e.lineNumber;
const r = this.lastMarker.index - this.lastMarker.column;
const n = e.start - r + 1;
return this.errorHandler.createError(t, s, n, i);
} {
const e = this.lastMarker.index;
const t = this.lastMarker.line;
const s = this.lastMarker.column + 1;
return this.errorHandler.createError(e, t, s, i);
}
}
throwUnexpectedToken(e, t) {
throw this.unexpectedTokenError(e, t);
}
tolerateUnexpectedToken(e, t) {
this.errorHandler.tolerate(this.unexpectedTokenError(e, t));
}
tolerateInvalidLoopStatement() {
(this.matchKeyword('class') || this.matchKeyword('function')) && this.tolerateError(Messages.UnexpectedToken, this.lookahead);
}
collectComments() {
if (this.config.comment) {
const e = this.scanner.scanComments();
if (e.length > 0 && this.delegate) {
for (let t = 0; t < e.length; ++t) {
const s = e[t];
const i = {
type: s.multiLine ? 'BlockComment' : 'LineComment',
value: this.scanner.source.slice(s.slice[0], s.slice[1])
};
this.config.range && (i.range = s.range), this.config.loc && (i.loc = s.loc);
const r = {
start: {
line: s.loc.start.line,
column: s.loc.start.column,
offset: s.range[0]
},
end: {
line: s.loc.end.line,
column: s.loc.end.column,
offset: s.range[1]
}
};
this.delegate(i, r);
}
}
} else this.scanner.scanComments();
}
getTokenRaw(e) {
return this.scanner.source.slice(e.start, e.end);
}
convertToken(e) {
const t = {
type: TokenName[e.type],
value: this.getTokenRaw(e)
};
if (this.config.range && (t.range = [e.start, e.end]), this.config.loc && (t.loc = {
start: {
line: this.startMarker.line,
column: this.startMarker.column
},
end: {
line: this.scanner.lineNumber,
column: this.scanner.index - this.scanner.lineStart
}
}), e.type === 9) {
const s = e.pattern;
const i = e.flags;
t.regex = {
pattern: s,
flags: i
};
}
return t;
}
nextToken() {
const e = this.lookahead;
this.lastMarker.index = this.scanner.index, this.lastMarker.line = this.scanner.lineNumber, this.lastMarker.column = this.scanner.index - this.scanner.lineStart, this.collectComments(), this.scanner.index !== this.startMarker.index && (this.startMarker.index = this.scanner.index, this.startMarker.line = this.scanner.lineNumber, this.startMarker.column = this.scanner.index - this.scanner.lineStart);
const t = this.scanner.lex();
return this.hasLineTerminator = e.lineNumber !== t.lineNumber, t && this.context.strict && t.type === 3 && this.scanner.isStrictModeReservedWord(t.value) && (t.type = 4), this.lookahead = t, this.config.tokens && t.type !== 2 && this.tokens.push(this.convertToken(t)), e;
}
nextRegexToken() {
this.collectComments();
const e = this.scanner.scanRegExp();
return this.config.tokens && (this.tokens.pop(), this.tokens.push(this.convertToken(e))), this.lookahead = e, this.nextToken(), e;
}
createNode() {
return {
index: this.startMarker.index,
line: this.startMarker.line,
column: this.startMarker.column
};
}
startNode(e, t = 0) {
let s = e.start - e.lineStart;
let i = e.lineNumber;
return s < 0 && (s += t, i--), {
index: e.start,
line: i,
column: s
};
}
finalize(e, t) {
if (this.config.range && (t.range = [e.index, this.lastMarker.index]), this.config.loc && (t.loc = {
start: {
line: e.line,
column: e.column
},
end: {
line: this.lastMarker.line,
column: this.lastMarker.column
}
}, this.config.source && (t.loc.source = this.config.source)), this.delegate) {
const s = {
start: {
line: e.line,
column: e.column,
offset: e.index
},
end: {
line: this.lastMarker.line,
column: this.lastMarker.column,
offset: this.lastMarker.index
}
};
this.delegate(t, s);
}
return t;
}
expect(e) {
const t = this.nextToken();
t.type === 7 && t.value === e || this.throwUnexpectedToken(t);
}
expectCommaSeparator() {
if (this.config.tolerant) {
const e = this.lookahead;
e.type === 7 && e.value === ',' ? this.nextToken() : e.type === 7 && e.value === ';' ? (this.nextToken(), this.tolerateUnexpectedToken(e)) : this.tolerateUnexpectedToken(e, Messages.UnexpectedToken);
} else this.expect(',');
}
expectKeyword(e) {
const t = this.nextToken();
t.type === 4 && t.value === e || this.throwUnexpectedToken(t);
}
match(e) {
return this.lookahead.type === 7 && this.lookahead.value === e;
}
matchKeyword(e) {
return this.lookahead.type === 4 && this.lookahead.value === e;
}
matchContextualKeyword(e) {
return this.lookahead.type === 3 && this.lookahead.value === e;
}
matchAssign() {
if (this.lookahead.type !== 7) return !1;
const e = this.lookahead.value;
return e === '=' || e === '*=' || e === '**=' || e === '/=' || e === '%=' || e === '+=' || e === '-=' || e === '<<=' || e === '>>=' || e === '>>>=' || e === '&=' || e === '^=' || e === '|=' || e === '&&=' || e === '||=' || e === '??=';
}
isolateCoverGrammar(e) {
const t = this.context.isBindingElement;
const s = this.context.isAssignmentTarget;
const i = this.context.firstCoverInitializedNameError;
this.context.isBindingElement = !0, this.context.isAssignmentTarget = !0, this.context.firstCoverInitializedNameError = null;
const r = e.call(this);
return this.context.firstCoverInitializedNameError !== null && this.throwUnexpectedToken(this.context.firstCoverInitializedNameError), this.context.isBindingElement = t, this.context.isAssignmentTarget = s, this.context.firstCoverInitializedNameError = i, r;
}
inheritCoverGrammar(e) {
const t = this.context.isBindingElement;
const s = this.context.isAssignmentTarget;
const i = this.context.firstCoverInitializedNameError;
this.context.isBindingElement = !0, this.context.isAssignmentTarget = !0, this.context.firstCoverInitializedNameError = null;
const r = e.call(this);
return this.context.isBindingElement = this.context.isBindingElement && t, this.context.isAssignmentTarget = this.context.isAssignmentTarget && s, this.context.firstCoverInitializedNameError = i || this.context.firstCoverInitializedNameError, r;
}
consumeSemicolon() {
this.match(';') ? this.nextToken() : this.hasLineTerminator || (this.lookahead.type === 2 || this.match('}') || this.throwUnexpectedToken(this.lookahead), this.lastMarker.index = this.startMarker.index, this.lastMarker.line = this.startMarker.line, this.lastMarker.column = this.startMarker.column);
}
parsePrimaryExpression() {
const e = this.createNode();
let t; let s; let
i;
switch (this.lookahead.type) {
case 3:
(this.context.isModule || this.context.isAsync) && this.lookahead.value === 'await' && this.tolerateUnexpectedToken(this.lookahead), t = this.matchAsyncFunction() ? this.parseFunctionExpression() : this.finalize(e, new Identifier(this.nextToken().value));
break;
case 6:
case 8:
this.context.strict && this.lookahead.octal && this.tolerateUnexpectedToken(this.lookahead, Messages.StrictOctalLiteral), this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1, s = this.nextToken(), i = this.getTokenRaw(s), t = typeof s.value === 'bigint' ? this.finalize(e, new BigIntLiteral(s.value, i, s.value.toString())) : this.finalize(e, new Literal(s.value, i));
break;
case 1:
this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1, s = this.nextToken(), i = this.getTokenRaw(s), t = this.finalize(e, new Literal(s.value === 'true', i));
break;
case 5:
this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1, s = this.nextToken(), i = this.getTokenRaw(s), t = this.finalize(e, new Literal(null, i));
break;
case 10:
t = this.parseTemplateLiteral({
isTagged: !1
});
break;
case 7:
switch (this.lookahead.value) {
case '(':
this.context.isBindingElement = !1, t = this.inheritCoverGrammar(this.parseGroupExpression);
break;
case '[':
t = this.inheritCoverGrammar(this.parseArrayInitializer);
break;
case '{':
t = this.inheritCoverGrammar(this.parseObjectInitializer);
break;
case '/':
case '/=':
this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1, this.scanner.index = this.startMarker.index, s = this.nextRegexToken(), i = this.getTokenRaw(s), t = this.finalize(e, new RegexLiteral(s.regex, i, s.pattern, s.flags));
break;
case '#':
this.nextToken(), t = this.finalize(e, new PrivateIdentifier(this.nextToken().value));
break;
case '@':
const r = this.parseDecorators();
this.context.decorators = r;
this.parsePrimaryExpression();
this.context.decorators = null, t = this.finalize(e, new PrivateIdentifier(this.nextToken().value));
break;
default:
t = this.throwUnexpectedToken(this.nextToken());
}
break;
case 4:
!this.context.strict && this.context.allowYield && this.matchKeyword('yield') ? t = this.parseIdentifierName() : !this.context.strict && this.matchKeyword('let') ? t = this.finalize(e, new Identifier(this.nextToken().value)) : (this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1, this.matchKeyword('function') ? t = this.parseFunctionExpression() : this.matchKeyword('this') ? (this.nextToken(), t = this.finalize(e, new ThisExpression())) : this.matchKeyword('class') ? t = this.parseClassExpression() : this.matchKeyword('new') ? t = this.parseNewExpression() : this.matchImportCall() ? t = this.parseImportCall() : this.matchImportMeta() ? (this.context.isModule || this.tolerateUnexpectedToken(this.lookahead, Messages.CannotUseImportMetaOutsideAModule), t = this.parseImportMeta()) : t = this.throwUnexpectedToken(this.nextToken()));
break;
default:
t = this.throwUnexpectedToken(this.nextToken());
}
return t;
}
parseSpreadElement() {
const e = this.createNode();
this.expect('...');
const t = this.inheritCoverGrammar(this.parseAssignmentExpression);
return this.finalize(e, new SpreadElement(t));
}
parseArrayInitializer() {
const e = this.createNode();
const t = [];
for (this.expect('['); !this.match(']');) {
if (this.match(',')) this.nextToken(), t.push(null);
else if (this.match('...')) {
const e = this.parseSpreadElement();
this.match(']') || (this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1, this.expect(',')), t.push(e);
} else t.push(this.inheritCoverGrammar(this.parseAssignmentExpression)), this.match(']') || this.expect(',');
}
return this.expect(']'), this.finalize(e, new ArrayExpression(t));
}
parsePropertyMethod(e) {
this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1;
const t = this.context.strict;
const s = this.context.allowStrictDirective;
this.context.allowStrictDirective = e.simple;
const i = this.isolateCoverGrammar(this.parseFunctionSourceElements);
return this.context.strict && e.firstRestricted && this.tolerateUnexpectedToken(e.firstRestricted, e.message), this.context.strict && e.stricted && this.tolerateUnexpectedToken(e.stricted, e.message), this.context.strict = t, this.context.allowStrictDirective = s, i;
}
parsePropertyMethodFunction(e) {
const t = this.createNode();
const s = this.context.allowYield;
this.context.allowYield = !0;
const i = this.parseFormalParameters();
const r = this.parsePropertyMethod(i);
return this.context.allowYield = s, this.finalize(t, new FunctionExpression(null, i.params, r, e, !1));
}
parsePropertyMethodAsyncFunction(e) {
const t = this.createNode();
const s = this.context.allowYield;
const i = this.context.isAsync;
this.context.allowYield = !1, this.context.isAsync = !0;
const r = this.parseFormalParameters();
const n = this.parsePropertyMethod(r);
return this.context.allowYield = s, this.context.isAsync = i, this.finalize(t, new FunctionExpression(null, r.params, n, e, !0));
}
parseObjectPropertyKey(e = !1) {
const t = this.createNode();
const s = this.nextToken();
let i;
switch (s.type) {
case 8:
case 6:
this.context.strict && s.octal && this.tolerateUnexpectedToken(s, Messages.StrictOctalLiteral);
const r = this.getTokenRaw(s);
i = typeof s.value === 'bigint' ? this.finalize(t, new BigIntLiteral(s.value, r, s.value.toString())) : this.finalize(t, new Literal(s.value, r));
break;
case 3:
case 1:
case 5:
case 4:
i = this.finalize(t, e ? new PrivateIdentifier(s.value) : new Identifier(s.value));
break;
case 7:
s.value === '[' ? (i = this.isolateCoverGrammar(this.parseAssignmentExpression), this.expect(']')) : i = this.throwUnexpectedToken(s);
break;
default:
i = this.throwUnexpectedToken(s);
}
return i;
}
isPropertyKey(e, t) {
return e.type === 'Identifier' && e.name === t || e.type === 'Literal' && e.value === t;
}
parseObjectProperty(e) {
const t = this.createNode();
const s = this.lookahead;
let i; let r = null;
let n = null;
let a = !1;
let o = !1;
let u = !1;
let h = !1;
let c = !1;
if (s.type === 3) {
const e = s.value;
this.nextToken(), a = this.match('['), h = !(this.hasLineTerminator || e !== 'async' || this.match(':') || this.match('(') || this.match(',')), c = this.match('*'), c && this.nextToken(), r = h ? this.parseObjectPropertyKey() : this.finalize(t, new Identifier(e));
} else this.match('*') ? this.nextToken() : (a = this.match('['), r = this.parseObjectPropertyKey());
const l = this.qualifiedPropertyName(this.lookahead);
if (s.type === 3 && !h && s.value === 'get' && l) i = 'get', a = this.match('['), r = this.parseObjectPropertyKey(), this.context.allowYield = !1, n = this.parseGetterMethod();
else if (s.type === 3 && !h && s.value === 'set' && l) i = 'set', a = this.match('['), r = this.parseObjectPropertyKey(), n = this.parseSetterMethod();
else if (s.type === 7 && s.value === '*' && l) i = 'init', a = this.match('['), r = this.parseObjectPropertyKey(), n = this.parseGeneratorMethod(!1), o = !0;
else if (r || this.throwUnexpectedToken(this.lookahead), i = 'init', this.match(':') && !h) !a && this.isPropertyKey(r, '__proto__') && (e.value && this.tolerateError(Messages.DuplicateProtoProperty), e.value = !0), this.nextToken(), n = this.inheritCoverGrammar(this.parseAssignmentExpression);
else if (this.match('(')) n = h ? this.parsePropertyMethodAsyncFunction(c) : this.parsePropertyMethodFunction(c), o = !0;
else if (s.type === 3) {
const e = this.finalize(t, new Identifier(s.value));
if (this.match('=')) {
this.context.firstCoverInitializedNameError = this.lookahead, this.nextToken(), u = !0;
const s = this.isolateCoverGrammar(this.parseAssignmentExpression);
n = this.finalize(t, new AssignmentPattern(e, s));
} else u = !0, n = e;
} else this.throwUnexpectedToken(this.nextToken());
return this.finalize(t, new Property(i, r, a, n, o, u));
}
parseObjectInitializer() {
const e = this.createNode();
this.expect('{');
const t = [];
const s = {
value: !1
};
for (; !this.match('}');) {
const e = this.match('...') ? this.parseSpreadElement() : this.parseObjectProperty(s);
t.push(e), this.match('}') || e.method && !this.match(',') || this.expectCommaSeparator();
}
return this.expect('}'), this.finalize(e, new ObjectExpression(t));
}
throwTemplateLiteralEarlyErrors(e) {
switch (e.notEscapeSequenceHead) {
case 'u':
return this.throwUnexpectedToken(e, Messages.InvalidUnicodeEscapeSequence);
case 'x':
return this.throwUnexpectedToken(e, Messages.InvalidHexEscapeSequence);
case '8':
case '9':
return this.throwUnexpectedToken(e, Messages.TemplateEscape89);
default:
return this.throwUnexpectedToken(e, Messages.TemplateOctalLiteral);
}
}
parseTemplateHead(e) {
assert(this.lookahead.head, 'Template literal must start with a template head');
const t = this.createNode();
const s = this.nextToken();
e.isTagged || s.notEscapeSequenceHead === null || this.throwTemplateLiteralEarlyErrors(s);
const i = s.value;
const r = s.cooked;
return this.finalize(t, new TemplateElement({
raw: i,
cooked: r
}, s.tail));
}
parseTemplateElement(e) {
this.lookahead.type !== 10 && this.throwUnexpectedToken();
const t = this.createNode();
const s = this.nextToken();
e.isTagged || s.notEscapeSequenceHead === null || this.throwTemplateLiteralEarlyErrors(s);
const i = s.value;
const r = s.cooked;
return this.finalize(t, new TemplateElement({
raw: i,
cooked: r
}, s.tail));
}
parseTemplateLiteral(e) {
const t = this.createNode();
const s = [];
const i = [];
let r = this.parseTemplateHead(e);
for (i.push(r); !r.tail;) s.push(this.parseExpression()), r = this.parseTemplateElement(e), i.push(r);
return this.finalize(t, new TemplateLiteral(i, s));
}
reinterpretExpressionAsPattern(e) {
switch (e.type) {
case 'Identifier':
case 'MemberExpression':
case 'RestElement':
case 'AssignmentPattern':
default:
break;
case 'SpreadElement':
e.type = 'RestElement', this.reinterpretExpressionAsPattern(e.argument);
break;
case 'ArrayExpression':
e.type = 'ArrayPattern';
for (let t = 0; t < e.elements.length; t++) e.elements[t] !== null && this.reinterpretExpressionAsPattern(e.elements[t]);
break;
case 'ObjectExpression':
e.type = 'ObjectPattern';
for (let t = 0; t < e.properties.length; t++) {
const s = e.properties[t];
this.reinterpretExpressionAsPattern(s.type === 'SpreadElement' ? s : s.value);
}
break;
case 'AssignmentExpression':
e.type = 'AssignmentPattern', delete e.operator, this.reinterpretExpressionAsPattern(e.left);
}
}
parseGroupExpression() {
let e;
if (this.expect('('), this.match(')')) {
this.nextToken(), this.match('=>') || this.expect('=>'), e = {
type: ArrowParameterPlaceHolder,
params: [],
async: !1
};
} else {
const t = this.lookahead;
const s = [];
if (this.match('...')) {
e = this.parseRestElement(s), this.expect(')'), this.match('=>') || this.expect('=>'), e = {
type: ArrowParameterPlaceHolder,
params: [e],
async: !1
};
} else {
let i = !1;
if (this.context.isBindingElement = !0, e = this.inheritCoverGrammar(this.parseAssignmentExpression), this.match(',')) {
const r = [];
for (this.context.isAssignmentTarget = !1, r.push(e); this.lookahead.type !== 2 && this.match(',');) {
if (this.nextToken(), this.match(')')) {
this.nextToken();
for (let e = 0; e < r.length; e++) this.reinterpretExpressionAsPattern(r[e]);
i = !0, e = {
type: ArrowParameterPlaceHolder,
params: r,
async: !1
};
} else if (this.match('...')) {
this.context.isBindingElement || this.throwUnexpectedToken(this.lookahead), r.push(this.parseRestElement(s)), this.expect(')'), this.match('=>') || this.expect('=>'), this.context.isBindingElement = !1;
for (let e = 0; e < r.length; e++) this.reinterpretExpressionAsPattern(r[e]);
i = !0, e = {
type: ArrowParameterPlaceHolder,
params: r,
async: !1
};
} else r.push(this.inheritCoverGrammar(this.parseAssignmentExpression));
if (i) break;
}
i || (e = this.finalize(this.startNode(t), new SequenceExpression(r)));
}
if (!i) {
if (this.expect(')'), this.match('=>') && (e.type === 'Identifier' && e.name === 'yield' && (i = !0, e = {
type: ArrowParameterPlaceHolder,
params: [e],
async: !1
}), !i)) {
if (this.context.isBindingElement || this.throwUnexpectedToken(this.lookahead), e.type === 'SequenceExpression') for (let t = 0; t < e.expressions.length; t++) this.reinterpretExpressionAsPattern(e.expressions[t]);
else this.reinterpretExpressionAsPattern(e);
const t = e.type === 'SequenceExpression' ? e.expressions : [e];
e = {
type: ArrowParameterPlaceHolder,
params: t,
async: !1
};
}
this.context.isBindingElement = !1;
}
}
}
return e;
}
parseArguments() {
this.expect('(');
const e = [];
if (!this.match(')')) {
for (;;) {
const t = this.match('...') ? this.parseSpreadElement() : this.isolateCoverGrammar(this.parseAssignmentExpression);
if (e.push(t), this.match(')')) break;
if (this.expectCommaSeparator(), this.match(')')) break;
}
}
return this.expect(')'), e;
}
isIdentifierName(e) {
return e.type === 3 || e.type === 4 || e.type === 1 || e.type === 5;
}
parseIdentifierName(e = !1) {
let t = !1;
const s = this.createNode();
let i = this.nextToken();
return i.value === '#' && e && (i = this.nextToken(), t = !0), this.isIdentifierName(i) || this.throwUnexpectedToken(i), this.finalize(s, t ? new PrivateIdentifier(i.value) : new Identifier(i.value));
}
parseNewExpression() {
const e = this.createNode();
const t = this.parseIdentifierName();
let s;
if (assert(t.name === 'new', 'New expression must start with `new`'), this.match('.')) {
if (this.nextToken(), this.lookahead.type === 3 && this.context.inFunctionBody && this.lookahead.value === 'target') {
const e = this.parseIdentifierName();
s = new MetaProperty(t, e);
} else this.throwUnexpectedToken(this.lookahead);
} else if (this.matchKeyword('import')) this.throwUnexpectedToken(this.lookahead);
else {
const e = this.isolateCoverGrammar(this.parseLeftHandSideExpression);
const t = this.match('(') ? this.parseArguments() : [];
s = new NewExpression(e, t), this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1;
}
return this.finalize(e, s);
}
parseAsyncArgument() {
const e = this.parseAssignmentExpression();
return this.context.firstCoverInitializedNameError = null, e;
}
parseAsyncArguments() {
this.expect('(');
const e = [];
if (!this.match(')')) {
for (;;) {
const t = this.match('...') ? this.parseSpreadElement() : this.isolateCoverGrammar(this.parseAsyncArgument);
if (e.push(t), this.match(')')) break;
if (this.expectCommaSeparator(), this.match(')')) break;
}
}
return this.expect(')'), e;
}
matchImportCall() {
let e = this.matchKeyword('import');
if (e) {
const t = this.scanner.saveState();
this.scanner.scanComments();
const s = this.scanner.lex();
this.scanner.restoreState(t), e = s.type === 7 && s.value === '(';
}
return e;
}
parseImportCall() {
const e = this.createNode();
this.expectKeyword('import'), this.expect('(');
const t = this.context.isAssignmentTarget;
this.context.isAssignmentTarget = !0;
const s = this.parseAssignmentExpression();
let i = null;
return this.match(',') && (this.nextToken(), this.match(')') || (i = this.parseAssignmentExpression())), this.context.isAssignmentTarget = t, this.match(')') ? this.nextToken() : (this.match(',') && this.nextToken(), this.expect(')')), this.finalize(e, new ImportExpression(s, i));
}
matchImportMeta() {
let e = this.matchKeyword('import');
if (e) {
const t = this.scanner.saveState();
this.scanner.scanComments();
const s = this.scanner.lex();
if (s.type === 7 && s.value === '.') {
this.scanner.scanComments();
const t = this.scanner.lex();
e = t.type === 3 && t.value === 'meta', e && t.end - t.start != 4 && this.tolerateUnexpectedToken(t, Messages.InvalidEscapedReservedWord);
} else e = !1;
this.scanner.restoreState(t);
}
return e;
}
parseImportMeta() {
const e = this.createNode();
const t = this.parseIdentifierName();
this.expect('.');
const s = this.parseIdentifierName();
return this.context.isAssignmentTarget = !1, this.finalize(e, new MetaProperty(t, s));
}
parseLeftHandSideExpressionAllowCall() {
const e = this.lookahead;
const t = this.matchContextualKeyword('async');
const s = this.context.allowIn;
let i;
this.context.allowIn = !0;
const r = this.matchKeyword('super');
r && this.context.inFunctionBody ? (i = this.createNode(), this.nextToken(), i = this.finalize(i, new Super()), this.match('(') || this.match('.') || this.match('[') || this.throwUnexpectedToken(this.lookahead)) : i = this.inheritCoverGrammar(this.matchKeyword('new') ? this.parseNewExpression : this.parsePrimaryExpression), !r || !this.match('(') || this.context.inClassConstructor && this.context.allowSuper || this.tolerateError(Messages.UnexpectedSuper);
let n = !1;
for (;;) {
let s = !1;
if (this.match('?.') && (s = !0, n = !0, this.expect('?.')), this.match('(')) {
const r = t && e.lineNumber === this.lookahead.lineNumber;
this.context.isBindingElement = !1, this.context.isAssignmentTarget = !1;
const n = r ? this.parseAsyncArguments() : this.parseArguments();
if (i.type === 'ImportExpression' && n.length !== 1 && this.tolerateError(Messages.BadImportCallArity), i = this.finalize(this.startNode(e), new CallExpression(i, n, s)), r && this.match('=>')) {
for (let e = 0; e < n.length; ++e) this.reinterpretExpressionAsPattern(n[e]);
i = {
type: ArrowParameterPlaceHolder,
params: n,
async: !0
};
}
} else if (this.match('[')) {
this.context.isBindingElement = !1, this.context.isAssignmentTarget = !s, this.expect('[');
const t = this.isolateCoverGrammar(this.parseExpression);
this.expect(']'), i = this.finalize(this.startNode(e), new MemberExpression(!0, i, t, s));
} else if (this.lookahead.type === 10 && this.lookahead.head) {
s && this.throwUnexpectedToken(this.lookahead), n && this.throwError(Messages.InvalidTaggedTemplateOnOptionalChain);
const t = this.parseTemplateLiteral({
isTagged: !0
});
i = this.finalize(this.startNode(e), new TaggedTemplateExpression(i, t));
} else {
if (!this.match('.') && !s) break;
{
this.context.isBindingElement = !1, this.context.isAssignmentTarget = !s, s || this.expect('.');
const t = this.parseIdentifierName(!0);
i = this.finalize(this.startNode(e), new MemberExpression(!1, i, t, s));
}
}
}
return this.context.allowIn = s, n && (i = this.finalize(this.startNode(e), new ChainExpression(i))), i;
}
parseSuper() {
const e = this.createNode();
return this.expectKeyword('super'), this.match('[') || this.match('.') || this.throwUnexpectedToken(this.lookahead), this.finalize(e, new Super());
}
parseLeftHandSideExpression() {
assert(this.context.allowIn, 'callee of new expression always allow in keyword.');
const e = this.startNode(this.lookahead);
let t = this.matchKeyword('super') && this.context.inFunctionBody ? this.parseSuper() : this.inheritCoverGrammar(this.matchKeyword('new') ? this.parseNewExpression : this.parsePrimaryExpression);
let s = !1;
for (;;) {
let i = !1;
if (this.match('?.') && (i = !0, s = !0, this.expect('?.')), this.match('[')) {
this.context.isBindingElement = !1, this.context.isAssignmentTarget = !i, this.expect('[');
const s = this.isolateCoverGrammar(this.parseExpression);
this.expect(']'), t = this.finalize(e, new MemberExpression(!0, t, s, i));
} else if (this.lookahead.type === 10 && this.lookahead.head) {
i && this.throwUnexpectedToken(this.lookahead), s && this.throwError(Messages.InvalidTaggedTemplateOnOptionalChain);
const r = this.parseTemplateLiteral({
isTagged: !0
});
t = this.finalize(e, new TaggedTemplateExpression(t, r));
} else {
if (!this.match('.') && !i) break;
{
this.context.isBindingElement = !1, this.context.isAssignmentTarget = !i, i || this.expect('.');
const s = this.parseIdentifierName();
t = this.finalize(e, new MemberExpression(!1, t, s, i));
}
}
}
return s && (t = this.finalize(e, new ChainExpression(t))), t;
}
parseUpdateExpression() {
let e;
const t = this.lookahead;
if (this.match('++') || this.match('--')) {
const s = this.startNode(t);
const i = this.nextToken();
e = this.inheritCoverGrammar(this.parseUnaryExpression), this.context.strict && e.type === 'Identifier' && this.scanner.isRestrictedWord(e.name) && this.tolerateError(Messages.StrictLHSPrefix), this.context.isAssignmentTarget || this.tolerateError(Messages.InvalidLHSInAssignment);
const r = !0;
e = this.finalize(s, new UpdateExpression(i.value, e, r)), this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1;
} else if (e = this.inheritCoverGrammar(this.parseLeftHandSideExpressionAllowCall), !this.hasLineTerminator && this.lookahead.type === 7 && (this.match('++') || this.match('--'))) {
this.context.strict && e.type === 'Identifier' && this.scanner.isRestrictedWord(e.name) && this.tolerateError(Messages.StrictLHSPostfix), this.context.isAssignmentTarget || this.tolerateError(Messages.InvalidLHSInAssignment), this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1;
const s = this.nextToken().value;
const i = !1;
e = this.finalize(this.startNode(t), new UpdateExpression(s, e, i));
}
return e;
}
parseAwaitExpression() {
const e = this.createNode();
this.nextToken();
const t = this.parseUnaryExpression();
return this.finalize(e, new AwaitExpression(t));
}
parseUnaryExpression() {
let e;
if (this.match('+') || this.match('-') || this.match('~') || this.match('!') || this.matchKeyword('delete') || this.matchKeyword('void') || this.matchKeyword('typeof')) {
const t = this.startNode(this.lookahead);
const s = this.nextToken();
e = this.inheritCoverGrammar(this.parseUnaryExpression), e = this.finalize(t, new UnaryExpression(s.value, e)), this.context.strict && e.operator === 'delete' && e.argument.type === 'Identifier' && this.tolerateError(Messages.StrictDelete), this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1;
} else e = (this.context.isModule && !this.context.inFunctionBody || this.context.isAsync) && this.matchContextualKeyword('await') ? this.parseAwaitExpression() : this.parseUpdateExpression();
return e;
}
parseExponentiationExpression() {
const e = this.lookahead;
const t = this.match('(');
let s = this.inheritCoverGrammar(this.parseUnaryExpression);
if ((s.type !== 'UnaryExpression' || t) && this.match('**')) {
this.nextToken(), this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1;
const t = s;
const i = this.isolateCoverGrammar(this.parseExponentiationExpression);
s = this.finalize(this.startNode(e), new BinaryExpression('**', t, i));
}
return s;
}
binaryPrecedence(e) {
const t = e.value;
let s;
return s = e.type === 7 ? this.operatorPrecedence[t] || 0 : e.type === 4 && (t === 'instanceof' || this.context.allowIn && t === 'in') ? 12 : 0, s;
}
parseBinaryExpression() {
const e = this.lookahead;
let t = this.inheritCoverGrammar(this.parseExponentiationExpression);
let s = !0;
let i = !0;
const r = e => {
e.value !== '&&' && e.value !== '||' || (i = !1), e.value === '??' && (s = !1);
};
const n = this.lookahead;
let a = this.binaryPrecedence(n);
if (a > 0) {
r(n), this.nextToken(), this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1;
const o = [e, this.lookahead];
let u = t;
let h = this.isolateCoverGrammar(this.parseExponentiationExpression);
const c = [u, n.value, h];
const l = [a];
for (; a = this.binaryPrecedence(this.lookahead), !(a <= 0);) {
for ((s || this.lookahead.value !== '&&' && this.lookahead.value !== '||') && (i || this.lookahead.value !== '??') || this.throwUnexpectedToken(this.lookahead), r(this.lookahead); c.length > 2 && a <= l[l.length - 1];) {
h = c.pop();
const e = c.pop();
l.pop(), u = c.pop(), o.pop();
const t = o[o.length - 1];
const s = this.startNode(t, t.lineStart);
const i = e === '||' || e === '&&' || e === '??';
c.push(this.finalize(s, i ? new LogicalExpression(e, u, h) : new BinaryExpression(e, u, h)));
}
c.push(this.nextToken().value), l.push(a), o.push(this.lookahead), c.push(this.isolateCoverGrammar(this.parseExponentiationExpression));
}
let p = c.length - 1;
t = c[p];
let m = o.pop();
for (; p > 1;) {
const e = o.pop();
const s = m && m.lineStart;
const i = this.startNode(e, s);
const r = c[p - 1];
const n = r === '||' || r === '&&' || r === '??';
t = this.finalize(i, n ? new LogicalExpression(r, c[p - 2], t) : new BinaryExpression(r, c[p - 2], t)), p -= 2, m = e;
}
}
return t;
}
parseConditionalExpression() {
const e = this.lookahead;
let t = this.inheritCoverGrammar(this.parseBinaryExpression);
if (this.match('?')) {
this.nextToken();
const s = this.context.allowIn;
this.context.allowIn = !0;
const i = this.isolateCoverGrammar(this.parseAssignmentExpression);
this.context.allowIn = s, this.expect(':');
const r = this.isolateCoverGrammar(this.parseAssignmentExpression);
t = this.finalize(this.startNode(e), new ConditionalExpression(t, i, r)), this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1;
}
return t;
}
checkPatternParam(e, t) {
switch (t.type) {
case 'Identifier':
this.validateParam(e, t, t.name);
break;
case 'RestElement':
this.checkPatternParam(e, t.argument);
break;
case 'AssignmentPattern':
this.checkPatternParam(e, t.left);
break;
case 'ArrayPattern':
for (let s = 0; s < t.elements.length; s++) t.elements[s] !== null && this.checkPatternParam(e, t.elements[s]);
break;
case 'ObjectPattern':
for (let s = 0; s < t.properties.length; s++) {
const i = t.properties[s];
this.checkPatternParam(e, i.type === 'RestElement' ? i : i.value);
}
}
e.simple = e.simple && t instanceof Identifier;
}
reinterpretAsCoverFormalsList(e) {
let t = [e];
const s = {
simple: !0,
paramSet: {}
};
let i = !1;
switch (e.type) {
case 'Identifier':
break;
case ArrowParameterPlaceHolder:
t = e.params, i = e.async;
break;
default:
return null;
}
for (let e = 0; e < t.length; ++e) {
const r = t[e];
r.type === 'AssignmentPattern' ? r.right.type === 'YieldExpression' && (r.right.argument && this.throwUnexpectedToken(this.lookahead), r.right.type = 'Identifier', r.right.name = 'yield', delete r.right.argument, delete r.right.delegate) : i && r.type === 'Identifier' && r.name === 'await' && this.throwUnexpectedToken(this.lookahead), this.checkPatternParam(s, r), t[e] = r;
}
if (this.context.strict || !this.context.allowYield) {
for (let e = 0; e < t.length; ++e) {
t[e].type === 'YieldExpression' && this.throwUnexpectedToken(this.lookahead);
}
}
if (s.hasDuplicateParameterNames) {
const e = this.context.strict ? s.stricted : s.firstRestricted;
this.throwUnexpectedToken(e, Messages.DuplicateParameter);
}
return {
simple: s.simple,
params: t,
stricted: s.stricted,
firstRestricted: s.firstRestricted,
message: s.message
};
}
parseAssignmentExpression() {
let e;
if (!this.context.allowYield && this.matchKeyword('yield')) e = this.parseYieldExpression();
else {
const t = this.lookahead;
let s = t;
if (e = this.parseConditionalExpression(), s.type === 3 && s.lineNumber === this.lookahead.lineNumber && s.value === 'async' && (this.lookahead.type === 3 || this.matchKeyword('yield'))) {
const t = this.parsePrimaryExpression();
this.reinterpretExpressionAsPattern(t), e = {
type: ArrowParameterPlaceHolder,
params: [t],
async: !0
};
}
if (e.type === ArrowParameterPlaceHolder || this.match('=>')) {
this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1;
const s = e.async;
const i = this.reinterpretAsCoverFormalsList(e);
if (i) {
this.hasLineTerminator && this.tolerateUnexpectedToken(this.lookahead), this.context.firstCoverInitializedNameError = null;
const r = this.context.strict;
const n = this.context.allowStrictDirective;
this.context.allowStrictDirective = i.simple;
const a = this.context.allowYield;
const o = this.context.isAsync;
this.context.allowYield = !0, this.context.isAsync = s;
const u = this.startNode(t);
let h;
if (this.expect('=>'), this.match('{')) {
const e = this.context.allowIn;
this.context.allowIn = !0, h = this.parseFunctionSourceElements(), this.context.allowIn = e;
} else h = this.isolateCoverGrammar(this.parseAssignmentExpression);
const c = h.type !== 'BlockStatement';
this.context.strict && i.firstRestricted && this.throwUnexpectedToken(i.firstRestricted, i.message), this.context.strict && i.stricted && this.tolerateUnexpectedToken(i.stricted, i.message), e = this.finalize(u, new ArrowFunctionExpression(i.params, h, c, s)), this.context.strict = r, this.context.allowStrictDirective = n, this.context.allowYield = a, this.context.isAsync = o;
}
} else if (this.matchAssign()) {
if (this.context.isAssignmentTarget || this.tolerateError(Messages.InvalidLHSInAssignment), this.context.strict && e.type === 'Identifier') {
const t = e;
this.scanner.isRestrictedWord(t.name) && this.tolerateUnexpectedToken(s, Messages.StrictLHSAssignment), this.scanner.isStrictModeReservedWord(t.name) && this.tolerateUnexpectedToken(s, Messages.StrictReservedWord);
}
this.match('=') ? this.reinterpretExpressionAsPattern(e) : (this.context.isAssignmentTarget = !1, this.context.isBindingElement = !1), s = this.nextToken();
const i = s.value;
const r = this.isolateCoverGrammar(this.parseAssignmentExpression);
e = this.finalize(this.startNode(t), new AssignmentExpression(i, e, r)), this.context.firstCoverInitializedNameError = null;
}
}
return e;
}
parseExpression() {
const e = this.lookahead;
let t = this.isolateCoverGrammar(this.parseAssignmentExpression);
if (this.match(',')) {
const s = [];
for (s.push(t); this.lookahead.type !== 2 && this.match(',');) this.nextToken(), s.push(this.isolateCoverGrammar(this.parseAssignmentExpression));
t = this.finalize(this.startNode(e), new SequenceExpression(s));
}
return t;
}
parseStatementListItem() {
let e;
if (this.context.isAssignmentTarget = !0, this.context.isBindingElement = !0, this.lookahead.type === 4) {
switch (this.lookahead.value) {
case 'export':
this.context.isModule || this.tolerateUnexpectedToken(this.lookahead, Messages.IllegalExportDeclaration), e = this.parseExportDeclaration();
break;
case 'import':
this.matchImportCall() ? e = this.parseExpressionStatement() : this.matchImportMeta() ? e = this.parseStatement() : (this.context.isModule || this.tolerateUnexpectedToken(this.lookahead, Messages.IllegalImportDeclaration), e = this.parseImportDeclaration());
break;
case 'const':
e = this.parseLexicalDeclaration({
inFor: !1
});
break;
case 'function':
e = this.parseFunctionDeclaration();
break;
case 'class':
e = this.parseClassDeclaration();
break;
case 'let':
e = this.isLexicalDeclaration() ? this.parseLexicalDeclaration({
inFor: !1
}) : this.parseStatement();
break;
default:
e = this.parseStatement();
}
} else e = this.parseStatement();
return e;
}
parseBlock() {
const e = this.createNode();
this.expect('{');
const t = [];
for (; !this.match('}');) t.push(this.parseStatementListItem());
return this.expect('}'), this.finalize(e, new BlockStatement(t));
}
parseLexicalBinding(e, t) {
const s = this.createNode();
const i = this.parsePattern([], e);
this.context.strict && i.type === 'Identifier' && this.scanner.isRestrictedWord(i.name) && this.tolerateError(Messages.StrictVarName);
let r = null;
return e === 'const' ? this.matchKeyword('in') || this.matchContextualKeyword('of') || (this.match('=') ? (this.nextToken(), r = this.isolateCoverGrammar(this.parseAssignmentExpression)) : this.throwError(Messages.DeclarationMissingInitializer, 'const')) : (!t.inFor && i.type !== 'Identifier' || this.match('=')) && (this.expect('='), r = this.isolateCoverGrammar(this.parseAssignmentExpression)), this.finalize(s, new VariableDeclarator(i, r));
}
parseBindingList(e, t) {
const s = [this.parseLexicalBinding(e, t)];
for (; this.match(',');) this.nextToken(), s.push(this.parseLexicalBinding(e, t));
return s;
}
isLexicalDeclaration() {
const e = this.scanner.saveState();
this.scanner.scanComments();
const t = this.scanner.lex();
return this.scanner.restoreState(e), t.type === 3 || t.type === 7 && t.value === '[' || t.type === 7 && t.value === '{' || t.type === 4 && t.value === 'let' || t.type === 4 && t.value === 'yield';
}
parseLexicalDeclaration(e) {
const t = this.createNode();
const s = this.nextToken().value;
assert(s === 'let' || s === 'const', 'Lexical declaration must be either let or const');
const i = this.parseBindingList(s, e);
return this.consumeSemicolon(), this.finalize(t, new VariableDeclaration(i, s));
}
isInitializedProperty() {
const e = this.scanner.saveState();
this.scanner.scanComments();
const t = this.scanner.lex();
return this.scanner.restoreState(e), this.lookahead.type === 3 && t.value === '=';
}
isDeclaredProperty() {
const e = this.scanner.saveState();
this.scanner.scanComments();
const t = this.scanner.lex();
return this.scanner.restoreState(e), this.lookahead.type === 3 && t.value === ';' || this.lookahead.type === 3 && t.lineNumber !== this.startMarker.line;
}
parseBindingRestElement(e, t) {
const s = this.createNode();
this.expect('...');
const i = this.parsePattern(e, t);
return this.finalize(s, new RestElement(i));
}
parseArrayPattern(e, t) {
const s = this.createNode();
this.expect('[');
const i = [];
for (; !this.match(']');) {
if (this.match(',')) this.nextToken(), i.push(null);
else {
if (this.match('...')) {
i.push(this.parseBindingRestElement(e, t));
break;
}
i.push(this.parsePatternWithDefault(e, t)), this.match(']') || this.expect(',');
}
} return this.expect(']'), this.finalize(s, new ArrayPattern(i));
}
parsePropertyPattern(e, t) {
const s = this.createNode();
let i = !1;
let r = !1;
let n; let
a;
if (this.lookahead.type === 3) {
const i = this.lookahead;
n = this.parseVariableIdentifier();
const o = this.finalize(s, new Identifier(i.value));
if (this.match('=')) {
e.push(i), r = !0, this.nextToken();
const t = this.parseAssignmentExpression();
a = this.finalize(this.startNode(i), new AssignmentPattern(o, t));
} else this.match(':') ? (this.expect(':'), a = this.parsePatternWithDefault(e, t)) : (e.push(i), r = !0, a = o);
} else i = this.match('['), n = this.parseObjectPropertyKey(), this.expect(':'), a = this.parsePatternWithDefault(e, t);
return this.finalize(s, new Property('init', n, i, a, !1, r));
}
parseRestProperty(e) {
const t = this.createNode();
this.expect('...');
const s = this.parsePattern(e);
return this.match('=') && this.throwError(Messages.DefaultRestProperty), this.match('}') || this.throwError(Messages.PropertyAfterRestProperty), this.finalize(t, new RestElement(s));
}
parseObjectPattern(e, t) {
const s = this.createNode();
const i = [];
for (this.expect('{'); !this.match('}');) i.push(this.match('...') ? this.parseRestProperty(e) : this.parsePropertyPattern(e, t)), this.match('}') || this.expect(',');
return this.expect('}'), this.finalize(s, new ObjectPattern(i));
}
parsePattern(e, t) {
let s;
return this.match('[') ? s = this.parseArrayPattern(e, t) : this.match('{') ? s = this.parseObjectPattern(e, t) : (!this.matchKeyword('let') || t !== 'const' && t !== 'let' || this.tolerateUnexpectedToken(this.lookahead, Messages.LetInLexicalBinding), e.push(this.lookahead), s = this.parseVariableIdentifier(t)), s;
}
parsePatternWithDefault(e, t) {
const s = this.lookahead;
let i = this.parsePattern(e, t);
if (this.match('=')) {
this.nextToken();
const e = this.context.allowYield;
this.context.allowYield = !0;
const t = this.isolateCoverGrammar(this.parseAssignmentExpression);
this.context.allowYield = e, i = this.finalize(this.startNode(s), new AssignmentPattern(i, t));
}
return i;
}
parseVariableIdentifier(e) {
const t = this.createNode();
const s = this.nextToken();
return s.type === 4 && s.value === 'yield' ? this.context.strict ? this.tolerateUnexpectedToken(s, Messages.StrictReservedWord) : this.context.allowYield || this.throwUnexpectedToken(s) : s.type !== 3 ? this.context.strict && s.type === 4 && this.scanner.isStrictModeReservedWord(s.value) ? this.tolerateUnexpectedToken(s, Messages.StrictReservedWord) : (this.context.strict || s.value !== 'let' || e !== 'var') && this.throwUnexpectedToken(s) : (this.context.isModule || this.context.isAsync) && s.type === 3 && s.value === 'await' && this.tolerateUnexpectedToken(s), this.finalize(t, new Identifier(s.value));
}
parseVariableDeclaration(e) {
const t = this.createNode();
const s = this.parsePattern([], 'var');
this.context.strict && s.type === 'Identifier' && this.scanner.isRestrictedWord(s.name) && this.tolerateError(Messages.StrictVarName);
let i = null;
return this.match('=') ? (this.nextToken(), i = this.isolateCoverGrammar(this.parseAssignmentExpression)) : s.type === 'Identifier' || e.inFor || this.expect('='), this.finalize(t, new VariableDeclarator(s, i));
}
parseVariableDeclarationList(e) {
const t = {
inFor: e.inFor
};
const s = [];
for (s.push(this.parseVariableDeclaration(t)); this.match(',');) this.nextToken(), s.push(this.parseVariableDeclaration(t));
return s;
}
parseVariableStatement() {
const e = this.createNode();
this.expectKeyword('var');
const t = this.parseVariableDeclarationList({
inFor: !1
});
return this.consumeSemicolon(), this.finalize(e, new VariableDeclaration(t, 'var'));
}
parseEmptyStatement() {
const e = this.createNode();
return this.expect(';'), this.finalize(e, new EmptyStatement());
}
parseExpressionStatement() {
const e = this.createNode();
const t = this.parseExpression();
return this.consumeSemicolon(), this.finalize(e, new ExpressionStatement(t));
}
parseIfClause() {
return this.context.strict && this.matchKeyword('function') && this.tolerateError(Messages.StrictFunction), this.parseStatement();
}
parseIfStatement() {
const e = this.createNode();
let t; let
s = null;
this.expectKeyword('if'), this.expect('(');
const i = this.parseExpression();
return !this.match(')') && this.config.tolerant ? (this.tolerateUnexpectedToken(this.nextToken()), t = this.finalize(this.createNode(), new EmptyStatement())) : (this.expect(')'), t = this.parseIfClause(), this.matchKeyword('else') && (this.nextToken(), s = this.parseIfClause())), this.finalize(e, new IfStatement(i, t, s));
}
parseDoWhileStatement() {
const e = this.createNode();
this.expectKeyword('do'), this.tolerateInvalidLoopStatement();
const t = this.context.inIteration;
this.context.inIteration = !0;
const s = this.parseStatement();
this.context.inIteration = t, this.expectKeyword('while'), this.expect('(');
const i = this.parseExpression();
return !this.match(')') && this.config.tolerant ? this.tolerateUnexpectedToken(this.nextToken()) : (this.expect(')'), this.match(';') && this.nextToken()), this.finalize(e, new DoWhileStatement(s, i));
}
parseWhileStatement() {
const e = this.createNode();
let t;
this.expectKeyword('while'), this.expect('(');
const s = this.parseExpression();
if (!this.match(')') && this.config.tolerant) this.tolerateUnexpectedToken(this.nextToken()), t = this.finalize(this.createNode(), new EmptyStatement());
else {
this.expect(')');
const e = this.context.inIteration;
this.context.inIteration = !0, t = this.parseStatement(), this.context.inIteration = e;
}
return this.finalize(e, new WhileStatement(s, t));
}
parseForStatement() {
let e; let t; let s = null;
let i = null;
let r = null;
let n = !0;
let a = !1;
const o = this.createNode();
if (this.expectKeyword('for'), this.matchContextualKeyword('await') && (this.context.isAsync || this.tolerateUnexpectedToken(this.lookahead), a = !0, this.nextToken()), this.expect('('), this.match(';')) this.nextToken();
else if (this.matchKeyword('var')) {
s = this.createNode(), this.nextToken();
const i = this.context.allowIn;
this.context.allowIn = !1;
const r = this.parseVariableDeclarationList({
inFor: !0
});
if (this.context.allowIn = i, !a && r.length === 1 && this.matchKeyword('in')) {
const i = r[0];
i.init && (i.id.type === 'ArrayPattern' || i.id.type === 'ObjectPattern' || this.context.strict) && this.tolerateError(Messages.ForInOfLoopInitializer, 'for-in'), s = this.finalize(s, new VariableDeclaration(r, 'var')), this.nextToken(), e = s, t = this.parseExpression(), s = null;
} else r.length === 1 && r[0].init === null && this.matchContextualKeyword('of') ? (s = this.finalize(s, new VariableDeclaration(r, 'var')), this.nextToken(), e = s, t = this.parseAssignmentExpression(), s = null, n = !1) : (s = this.finalize(s, new VariableDeclaration(r, 'var')), this.expect(';'));
} else if (this.matchKeyword('const') || this.matchKeyword('let')) {
s = this.createNode();
const i = this.nextToken().value;
if (this.context.strict || this.lookahead.value !== 'in') {
const r = this.context.allowIn;
this.context.allowIn = !1;
const a = this.parseBindingList(i, {
inFor: !0
});
this.context.allowIn = r, a.length === 1 && a[0].init === null && this.matchKeyword('in') ? (s = this.finalize(s, new VariableDeclaration(a, i)), this.nextToken(), e = s, t = this.parseExpression(), s = null) : a.length === 1 && a[0].init === null && this.matchContextualKeyword('of') ? (s = this.finalize(s, new VariableDeclaration(a, i)), this.nextToken(), e = s, t = this.parseAssignmentExpression(), s = null, n = !1) : (this.consumeSemicolon(), s = this.finalize(s, new VariableDeclaration(a, i)));
} else s = this.finalize(s, new Identifier(i)), this.nextToken(), e = s, t = this.parseExpression(), s = null;
} else {
const i = this.lookahead;
const r = this.context.isBindingElement;
const a = this.context.isAssignmentTarget;
const o = this.context.firstCoverInitializedNameError;
const u = this.context.allowIn;
if (this.context.allowIn = !1, s = this.inheritCoverGrammar(this.parseAssignmentExpression), this.context.allowIn = u, this.matchKeyword('in')) this.context.isAssignmentTarget && s.type !== 'AssignmentExpression' || this.tolerateError(Messages.InvalidLHSInForIn), this.nextToken(), this.reinterpretExpressionAsPattern(s), e = s, t = this.parseExpression(), s = null;
else if (this.matchContextualKeyword('of')) this.context.isAssignmentTarget && s.type !== 'AssignmentExpression' || this.tolerateError(Messages.InvalidLHSInForLoop), this.nextToken(), this.reinterpretExpressionAsPattern(s), e = s, t = this.parseAssignmentExpression(), s = null, n = !1;
else {
if (this.context.isBindingElement = r, this.context.isAssignmentTarget = a, this.context.firstCoverInitializedNameError = o, this.match(',')) {
const e = [s];
for (; this.match(',');) this.nextToken(), e.push(this.isolateCoverGrammar(this.parseAssignmentExpression));
s = this.finalize(this.startNode(i), new SequenceExpression(e));
}
this.expect(';');
}
}
let u;
if (void 0 === e && (this.match(';') || (i = this.isolateCoverGrammar(this.parseExpression)), this.expect(';'), this.match(')') || (r = this.isolateCoverGrammar(this.parseExpression))), !this.match(')') && this.config.tolerant) this.tolerateUnexpectedToken(this.nextToken()), u = this.finalize(this.createNode(), new EmptyStatement());
else {
this.expect(')'), this.tolerateInvalidLoopStatement();
const e = this.context.inIteration;
this.context.inIteration = !0, u = this.isolateCoverGrammar(this.parseStatement), this.context.inIteration = e;
}
return void 0 === e ? this.finalize(o, new ForStatement(s, i, r, u)) : n ? this.finalize(o, new ForInStatement(e, t, u)) : this.finalize(o, new ForOfStatement(e, t, u, a));
}
parseContinueStatement() {
const e = this.createNode();
this.expectKeyword('continue');
let t = null;
if (this.lookahead.type === 3 && !this.hasLineTerminator) {
const e = this.parseVariableIdentifier();
t = e;
const s = `$${e.name}`;
Object.prototype.hasOwnProperty.call(this.context.labelSet, s) || this.throwError(Messages.UnknownLabel, e.name);
}
return this.consumeSemicolon(), t !== null || this.context.inIteration || this.throwError(Messages.IllegalContinue), this.finalize(e, new ContinueStatement(t));
}
parseBreakStatement() {
const e = this.createNode();
this.expectKeyword('break');
let t = null;
if (this.lookahead.type === 3 && !this.hasLineTerminator) {
const e = this.parseVariableIdentifier();
const s = `$${e.name}`;
Object.prototype.hasOwnProperty.call(this.context.labelSet, s) || this.throwError(Messages.UnknownLabel, e.name), t = e;
}
return this.consumeSemicolon(), t !== null || this.context.inIteration || this.context.inSwitch || this.throwError(Messages.IllegalBreak), this.finalize(e, new BreakStatement(t));
}
parseReturnStatement() {
this.context.inFunctionBody || this.tolerateError(Messages.IllegalReturn);
const e = this.createNode();
this.expectKeyword('return');
const t = !this.match(';') && !this.match('}') && !this.hasLineTerminator && this.lookahead.type !== 2 || this.lookahead.type === 8 || this.lookahead.type === 10 ? this.parseExpression() : null;
return this.consumeSemicolon(), this.finalize(e, new ReturnStatement(t));
}
parseWithStatement() {
this.context.strict && this.tolerateError(Messages.StrictModeWith);
const e = this.createNode();
let t;
this.expectKeyword('with'), this.expect('(');
const s = this.parseExpression();
return !this.match(')') && this.config.tolerant ? (this.tolerateUnexpectedToken(this.nextToken()), t = this.finalize(this.createNode(), new EmptyStatement())) : (this.expect(')'), t = this.parseStatement()), this.finalize(e, new WithStatement(s, t));
}
parseSwitchCase() {
const e = this.createNode();
let t;
this.matchKeyword('default') ? (this.nextToken(), t = null) : (this.expectKeyword('case'), t = this.parseExpression()), this.expect(':');
const s = [];
for (; !(this.match('}') || this.matchKeyword('default') || this.matchKeyword('case'));) s.push(this.parseStatementListItem());
return this.finalize(e, new SwitchCase(t, s));
}
parseSwitchStatement() {
const e = this.createNode();
this.expectKeyword('switch'), this.expect('(');
const t = this.parseExpression();
this.expect(')');
const s = this.context.inSwitch;
this.context.inSwitch = !0;
const i = [];
let r = !1;
for (this.expect('{'); !this.match('}');) {
const e = this.parseSwitchCase();
e.test === null && (r && this.throwError(Messages.MultipleDefaultsInSwitch), r = !0), i.push(e);
}
return this.expect('}'), this.context.inSwitch = s, this.finalize(e, new SwitchStatement(t, i));
}
parseLabelledStatement() {
const e = this.createNode();
const t = this.parseExpression();
let s;
if (t.type === 'Identifier' && this.match(':')) {
this.nextToken();
const e = t;
const i = `$${e.name}`;
let r;
if (Object.prototype.hasOwnProperty.call(this.context.labelSet, i) && this.throwError(Messages.Redeclaration, 'Label', e.name), this.context.labelSet[i] = !0, this.matchKeyword('class')) this.tolerateUnexpectedToken(this.lookahead), r = this.parseClassDeclaration();
else if (this.matchKeyword('function')) {
const e = this.lookahead;
const t = this.parseFunctionDeclaration();
this.context.strict ? this.tolerateUnexpectedToken(e, Messages.StrictFunction) : t.generator && this.tolerateUnexpectedToken(e, Messages.GeneratorInLegacyContext), r = t;
} else r = this.parseStatement();
delete this.context.labelSet[i], s = new LabeledStatement(e, r);
} else this.consumeSemicolon(), s = new ExpressionStatement(t);
return this.finalize(e, s);
}
parseThrowStatement() {
const e = this.createNode();
this.expectKeyword('throw'), this.hasLineTerminator && this.throwError(Messages.NewlineAfterThrow);
const t = this.parseExpression();
return this.consumeSemicolon(), this.finalize(e, new ThrowStatement(t));
}
parseCatchClause() {
const e = this.createNode();
this.expectKeyword('catch');
let t = null;
if (this.match('(')) {
this.expect('('), this.match(')') && this.throwUnexpectedToken(this.lookahead);
const e = [];
t = this.parsePattern(e);
const s = {};
for (let t = 0; t < e.length; t++) {
const i = `$${e[t].value}`;
Object.prototype.hasOwnProperty.call(s, i) && this.tolerateError(Messages.DuplicateBinding, e[t].value), s[i] = !0;
}
this.context.strict && t.type === 'Identifier' && this.scanner.isRestrictedWord(t.name) && this.tolerateError(Messages.StrictCatchVariable), this.expect(')');
}
const s = this.parseBlock();
return this.finalize(e, new CatchClause(t, s));
}
parseFinallyClause() {
return this.expectKeyword('finally'), this.parseBlock();
}
parseTryStatement() {
const e = this.createNode();
this.expectKeyword('try');
const t = this.parseBlock();
const s = this.matchKeyword('catch') ? this.parseCatchClause() : null;
const i = this.matchKeyword('finally') ? this.parseFinallyClause() : null;
return s || i || this.throwError(Messages.NoCatchOrFinally), this.finalize(e, new TryStatement(t, s, i));
}
parseDebuggerStatement() {
const e = this.createNode();
return this.expectKeyword('debugger'), this.consumeSemicolon(), this.finalize(e, new DebuggerStatement());
}
parseStatement() {
let e;
switch (this.lookahead.type) {
case 1:
case 5:
case 6:
case 8:
case 10:
case 9:
e = this.parseExpressionStatement();
break;
case 7:
const t = this.lookahead.value;
e = t === '{' ? this.parseBlock() : t === '(' ? this.parseExpressionStatement() : t === ';' ? this.parseEmptyStatement() : this.parseExpressionStatement();
break;
case 3:
e = this.matchAsyncFunction() ? this.parseFunctionDeclaration() : this.parseLabelledStatement();
break;
case 4:
switch (this.lookahead.value) {
case 'break':
e = this.parseBreakStatement();
break;
case 'continue':
e = this.parseContinueStatement();
break;
case 'debugger':
e = this.parseDebuggerStatement();
break;
case 'do':
e = this.parseDoWhileStatement();
break;
case 'for':
e = this.parseForStatement();
break;
case 'function':
e = this.parseFunctionDeclaration();
break;
case 'if':
e = this.parseIfStatement();
break;
case 'return':
e = this.parseReturnStatement();
break;
case 'switch':
e = this.parseSwitchStatement();
break;
case 'throw':
e = this.parseThrowStatement();
break;
case 'try':
e = this.parseTryStatement();
break;
case 'var':
e = this.parseVariableStatement();
break;
case 'while':
e = this.parseWhileStatement();
break;
case 'with':
e = this.parseWithStatement();
break;
default:
e = this.parseExpressionStatement();
}
break;
default:
e = this.throwUnexpectedToken(this.lookahead);
}
return e;
}
parseFunctionSourceElements() {
const e = this.createNode();
this.expect('{');
const t = this.parseDirectivePrologues();
const s = this.context.labelSet;
const i = this.context.inIteration;
const r = this.context.inSwitch;
const n = this.context.inFunctionBody;
for (this.context.labelSet = {}, this.context.inIteration = !1, this.context.inSwitch = !1, this.context.inFunctionBody = !0; this.lookahead.type !== 2 && !this.match('}');) t.push(this.parseStatementListItem());
return this.expect('}'), this.context.labelSet = s, this.context.inIteration = i, this.context.inSwitch = r, this.context.inFunctionBody = n, this.finalize(e, new BlockStatement(t));
}
validateParam(e, t, s) {
const i = `$${s}`;
this.context.strict ? (this.scanner.isRestrictedWord(s) && (e.stricted = t, e.message = Messages.StrictParamName), Object.prototype.hasOwnProperty.call(e.paramSet, i) && (e.stricted = t, e.hasDuplicateParameterNames = !0)) : e.firstRestricted || (this.scanner.isRestrictedWord(s) ? (e.firstRestricted = t, e.message = Messages.StrictParamName) : this.scanner.isStrictModeReservedWord(s) ? (e.firstRestricted = t, e.message = Messages.StrictReservedWord) : Object.prototype.hasOwnProperty.call(e.paramSet, i) && (e.stricted = t, e.hasDuplicateParameterNames = !0)), typeof Object.defineProperty === 'function' ? Object.defineProperty(e.paramSet, i, {
value: !0,
enumerable: !0,
writable: !0,
configurable: !0
}) : e.paramSet[i] = !0;
}
parseRestElement(e) {
const t = this.createNode();
this.expect('...');
const s = this.parsePattern(e);
return this.match('=') && this.throwError(Messages.DefaultRestParameter), this.match(')') || this.throwError(Messages.ParameterAfterRestParameter), this.finalize(t, new RestElement(s));
}
parseFormalParameter(e) {
const t = [];
const s = this.match('...') ? this.parseRestElement(t) : this.parsePatternWithDefault(t);
for (let s = 0; s < t.length; s++) this.validateParam(e, t[s], t[s].value);
e.simple = e.simple && s instanceof Identifier, e.params.push(s);
}
parseFormalParameters(e) {
const t = {
simple: !0,
hasDuplicateParameterNames: !1,
params: [],
firstRestricted: e
};
if (this.expect('('), !this.match(')')) for (t.paramSet = {}; this.lookahead.type !== 2 && (this.parseFormalParameter(t), !this.match(')')) && (this.expect(','), !this.match(')')););
return this.expect(')'), t.hasDuplicateParameterNames && (this.context.strict || this.context.isAsync || !t.simple) && this.throwError(Messages.DuplicateParameter), {
simple: t.simple,
params: t.params,
stricted: t.stricted,
firstRestricted: t.firstRestricted,
message: t.message
};
}
matchAsyncFunction() {
let e = this.matchContextualKeyword('async');
if (e) {
const t = this.scanner.saveState();
this.scanner.scanComments();
const s = this.scanner.lex();
this.scanner.restoreState(t), e = t.lineNumber === s.lineNumber && s.type === 4 && s.value === 'function';
}
return e;
}
parseFunctionDeclaration(e) {
const t = this.createNode();
const s = this.matchContextualKeyword('async');
s && (this.context.inIteration && this.tolerateError(Messages.AsyncFunctionInSingleStatementContext), this.nextToken()), this.expectKeyword('function');
const i = this.match('*');
let r;
i && this.nextToken();
let n = null;
let a = null;
if (!e || !this.match('(')) {
const e = this.lookahead;
n = this.parseVariableIdentifier(), this.context.strict ? this.scanner.isRestrictedWord(e.value) && this.tolerateUnexpectedToken(e, Messages.StrictFunctionName) : this.scanner.isRestrictedWord(e.value) ? (a = e, r = Messages.StrictFunctionName) : this.scanner.isStrictModeReservedWord(e.value) && (a = e, r = Messages.StrictReservedWord);
}
const o = this.context.isAsync;
const u = this.context.allowYield;
this.context.isAsync = s, this.context.allowYield = !i;
const h = this.parseFormalParameters(a);
const c = h.params;
const l = h.stricted;
a = h.firstRestricted, h.message && (r = h.message);
const p = this.context.strict;
const m = this.context.allowStrictDirective;
this.context.allowStrictDirective = h.simple;
const d = this.parseFunctionSourceElements();
return this.context.strict && a && this.throwUnexpectedToken(a, r), this.context.strict && l && this.tolerateUnexpectedToken(l, r), this.context.strict = p, this.context.allowStrictDirective = m, this.context.isAsync = o, this.context.allowYield = u, s ? this.finalize(t, new AsyncFunctionDeclaration(n, c, d, i)) : this.finalize(t, new FunctionDeclaration(n, c, d, i));
}
parseFunctionExpression() {
const e = this.createNode();
const t = this.matchContextualKeyword('async');
t && this.nextToken(), this.expectKeyword('function');
const s = this.match('*');
let i;
s && this.nextToken();
let r; let
n = null;
const a = this.context.isAsync;
const o = this.context.allowYield;
if (this.context.isAsync = t, this.context.allowYield = !s, !this.match('(')) {
const e = this.lookahead;
n = this.context.strict || s || !this.matchKeyword('yield') ? this.parseVariableIdentifier() : this.parseIdentifierName(), this.context.strict ? this.scanner.isRestrictedWord(e.value) && this.tolerateUnexpectedToken(e, Messages.StrictFunctionName) : this.scanner.isRestrictedWord(e.value) ? (r = e, i = Messages.StrictFunctionName) : this.scanner.isStrictModeReservedWord(e.value) && (r = e, i = Messages.StrictReservedWord);
}
const u = this.parseFormalParameters(r);
const h = u.params;
const c = u.stricted;
r = u.firstRestricted, u.message && (i = u.message);
const l = this.context.strict;
const p = this.context.allowStrictDirective;
this.context.allowStrictDirective = u.simple;
const m = this.parseFunctionSourceElements();
return this.context.strict && r && this.throwUnexpectedToken(r, i), this.context.strict && c && this.tolerateUnexpectedToken(c, i), this.context.strict = l, this.context.allowStrictDirective = p, this.context.isAsync = a, this.context.allowYield = o, this.finalize(e, new FunctionExpression(n, h, m, s, t));
}
parseDirective() {
const e = this.lookahead;
const t = this.createNode();
const s = this.parseExpression();
const i = s.type === 'Literal' ? this.getTokenRaw(e).slice(1, -1) : null;
return this.consumeSemicolon(), this.finalize(t, i ? new Directive(s, i) : new ExpressionStatement(s));
}
parseDirectivePrologues() {
let e = null;
const t = [];
for (;;) {
const s = this.lookahead;
if (s.type !== 8) break;
const i = this.parseDirective();
t.push(i);
const r = i.directive;
if (typeof r !== 'string') break;
r === 'use strict' ? (this.context.strict = !0, e && this.tolerateUnexpectedToken(e, Messages.StrictOctalLiteral), this.context.allowStrictDirective || this.tolerateUnexpectedToken(s, Messages.IllegalLanguageModeDirective)) : !e && s.octal && (e = s);
}
return t;
}
qualifiedPropertyName(e) {
switch (e.type) {
case 3:
case 8:
case 1:
case 5:
case 6:
case 4:
return !0;
case 7:
return e.value === '[' || e.value === '#';
}
return !1;
}
parseGetterMethod() {
const e = this.createNode();
const t = this.context.allowYield;
this.context.allowYield = !0;
const s = this.parseFormalParameters();
s.params.length > 0 && this.tolerateError(Messages.BadGetterArity);
const i = this.parsePropertyMethod(s);
return this.context.allowYield = t, this.finalize(e, new FunctionExpression(null, s.params, i, false, !1));
}
parseSetterMethod() {
const e = this.createNode();
const t = this.context.allowYield;
this.context.allowYield = !0;
const s = this.parseFormalParameters();
s.params.length !== 1 ? this.tolerateError(Messages.BadSetterArity) : s.params[0] instanceof RestElement && this.tolerateError(Messages.BadSetterRestParameter);
const i = this.parsePropertyMethod(s);
return this.context.allowYield = t, this.finalize(e, new FunctionExpression(null, s.params, i, false, !1));
}
parseGeneratorMethod(e) {
const t = this.createNode();
const s = this.context.allowYield;
this.context.allowYield = !0;
const i = this.parseFormalParameters();
this.context.allowYield = !1;
const r = this.parsePropertyMethod(i);
return this.context.allowYield = s, this.finalize(t, new FunctionExpression(null, i.params, r, !0, e));
}
isStartOfExpression() {
let e = !0;
const t = this.lookahead.value;
switch (this.lookahead.type) {
case 7:
e = t === '[' || t === '(' || t === '{' || t === '+' || t === '-' || t === '!' || t === '~' || t === '++' || t === '--' || t === '/' || t === '/=';
break;
case 4:
e = t === 'class' || t === 'delete' || t === 'function' || t === 'let' || t === 'new' || t === 'super' || t === 'this' || t === 'typeof' || t === 'void' || t === 'yield';
}
return e;
}
parseYieldExpression() {
const e = this.createNode();
this.expectKeyword('yield');
let t = null;
let s = !1;
if (!this.hasLineTerminator) {
const e = this.context.allowYield;
this.context.allowYield = !1, s = this.match('*'), s ? (this.nextToken(), t = this.parseAssignmentExpression()) : this.isStartOfExpression() && (t = this.parseAssignmentExpression()), this.context.allowYield = e;
}
return this.finalize(e, new YieldExpression(t, s));
}
parseStaticBlock() {
const e = this.createNode();
this.expect('{');
const t = [];
for (; !this.match('}');) t.push(this.parseStatementListItem());
return this.expect('}'), this.finalize(e, new StaticBlock(t));
}
parseDecorator() {
const e = this.createNode();
this.expect('@');
const t = this.context.strict;
const s = this.context.allowYield;
const i = this.context.isAsync;
this.context.strict = !1, this.context.allowYield = !0, this.context.isAsync = !1;
const r = this.isolateCoverGrammar(this.parseLeftHandSideExpressionAllowCall);
return this.context.strict = t, this.context.allowYield = s, this.context.isAsync = i, this.match(';') && this.throwError(Messages.NoSemicolonAfterDecorator), this.finalize(e, new Decorator(r));
}
parseDecorators() {
let e = null;
for (; this.match('@');) e == null && (e = []), e.push(this.parseDecorator());
return e;
}
parseClassElement(e) {
let t = this.lookahead;
const s = this.createNode();
const i = this.context.inConstructor;
let r = '';
let n = null;
let a = null;
let o = !1;
let u = !1;
let h = !1;
let c = !1;
let l = !1;
let p = !1;
const m = this.parseDecorators();
if (m && (t = this.lookahead), this.match('*')) this.nextToken();
else {
o = this.match('['), this.match('#') && (p = !0, this.nextToken(), t = this.lookahead), n = this.parseObjectPropertyKey(p);
const e = n;
if (this.context.inConstructor = t.type === 3 && t.value === 'constructor', e.name === 'static' && (this.qualifiedPropertyName(this.lookahead) || this.match('*')) && (t = this.lookahead, h = !0, o = this.match('['), this.match('*') ? (this.nextToken(), this.match('#') && (p = !0, this.nextToken(), t = this.lookahead)) : (this.match('#') && (p = !0, this.nextToken(), t = this.lookahead), n = this.parseObjectPropertyKey(p))), e.name === 'static' && this.match('{')) return this.parseStaticBlock();
if (t.type === 3 && !this.hasLineTerminator && t.value === 'async') {
const e = this.lookahead.value;
e !== ':' && e !== '(' && (c = !0, l = this.match('*'), l && this.nextToken(), t = this.lookahead, o = this.match('['), this.match('*') ? (this.nextToken(), this.match('#') && (p = !0, this.nextToken())) : (this.match('#') && (p = !0, this.nextToken(), t = this.lookahead), n = this.parseObjectPropertyKey(p)), t.type !== 3 || t.value !== 'constructor' || h || this.tolerateUnexpectedToken(t, Messages.ConstructorIsAsync));
}
}
t.type === 3 && t.value === 'constructor' && p && this.tolerateUnexpectedToken(t, Messages.ConstructorIsPrivate);
const d = this.qualifiedPropertyName(this.lookahead);
if (t.type === 3 || t.type === 8 ? t.value === 'get' && d ? (r = 'get', this.match('#') && (p = !0, this.nextToken(), t = this.lookahead), o = this.match('['), n = this.parseObjectPropertyKey(p), this.context.allowYield = !1, a = this.parseGetterMethod()) : t.value === 'set' && d ? (r = 'set', this.match('#') && (p = !0, this.nextToken(), t = this.lookahead), o = this.match('['), n = this.parseObjectPropertyKey(p), a = this.parseSetterMethod()) : this.match('(') || (r = 'property', o = !1, this.match('=') && (this.nextToken(), a = this.isolateCoverGrammar(this.parseAssignmentExpression))) : t.type === 7 && t.value === '*' && d ? (r = 'init', o = this.match('['), n = this.parseObjectPropertyKey(p), a = this.parseGeneratorMethod(c), u = !0) : t.type !== 7 || t.value !== '[' || this.match('(') || (r = 'property', o = !0, this.match('=') && (this.nextToken(), a = this.isolateCoverGrammar(this.parseAssignmentExpression))), !r && n && this.match('(')) {
const e = this.context.inClassConstructor;
this.context.inClassConstructor = t.value === 'constructor', r = 'init', a = c ? this.parsePropertyMethodAsyncFunction(l) : this.parsePropertyMethodFunction(l), this.context.inClassConstructor = e, u = !0;
}
return r || this.throwUnexpectedToken(this.lookahead), r === 'init' && (r = 'method'), o || (h && this.isPropertyKey(n, 'prototype') && this.throwUnexpectedToken(t, Messages.StaticPrototype), !h && this.isPropertyKey(n, 'constructor') && ((r !== 'method' || !u || a && a.generator) && this.throwUnexpectedToken(t, Messages.ConstructorSpecialMethod), e.value ? this.throwUnexpectedToken(t, Messages.DuplicateConstructor) : e.value = !0, r = 'constructor')), this.context.inConstructor = i, r === 'property' ? (this.consumeSemicolon(), this.finalize(s, new PropertyDefinition(n, o, a, h, m))) : this.finalize(s, new MethodDefinition(n, o, a, r, h, m));
}
parseClassElementList() {
const e = [];
const t = {
value: !1
};
for (this.expect('{'); !this.match('}');) this.match(';') ? this.nextToken() : e.push(this.parseClassElement(t));
return this.expect('}'), e;
}
parseClassBody() {
const e = this.createNode();
const t = this.parseClassElementList();
return this.finalize(e, new ClassBody(t));
}
parseClassDeclaration(e) {
const t = this.createNode();
const s = this.context.strict;
const i = this.context.allowSuper;
this.context.strict = !0, this.expectKeyword('class');
const r = e && this.lookahead.type !== 3 ? null : this.parseVariableIdentifier();
let n = null;
this.matchKeyword('extends') && (this.nextToken(), n = this.isolateCoverGrammar(this.parseLeftHandSideExpressionAllowCall), this.context.allowSuper = !0);
const a = this.parseClassBody();
return this.context.allowSuper = i, this.context.strict = s, this.finalize(t, new ClassDeclaration(r, n, a, this.context.decorators));
}
parseClassExpression() {
const e = this.createNode();
const t = this.context.strict;
this.context.strict = !0, this.expectKeyword('class');
const s = this.lookahead.type === 3 ? this.parseVariableIdentifier() : null;
let i = null;
this.matchKeyword('extends') && (this.nextToken(), i = this.isolateCoverGrammar(this.parseLeftHandSideExpressionAllowCall), this.context.allowSuper = !0);
const r = this.parseClassBody();
return this.context.strict = t, this.finalize(e, new ClassExpression(s, i, r, this.context.decorators));
}
parseModule() {
this.context.strict = !0, this.context.isModule = !0, this.scanner.isModule = !0;
const e = this.createNode();
const t = this.parseDirectivePrologues();
for (; this.lookahead.type !== 2;) t.push(this.parseStatementListItem());
return this.finalize(e, new Module(t));
}
parseScript() {
const e = this.createNode();
const t = this.parseDirectivePrologues();
for (; this.lookahead.type !== 2;) t.push(this.parseStatementListItem());
return this.finalize(e, new Script(t));
}
parseImportAttributes() {
if (this.lookahead.value === 'assert') {
this.nextToken(), this.expect('{');
const e = [];
for (; !this.match('}');) e.push(this.parseImportAttribute()), this.match('}') || this.expectCommaSeparator();
return this.expect('}'), e;
}
return null;
}
parseImportAttribute() {
const e = this.createNode();
this.lookahead.type !== 3 && this.throwUnexpectedToken(this.nextToken());
const t = this.parseIdentifierName();
this.match(':') || this.throwUnexpectedToken(this.nextToken()), this.nextToken();
const s = this.nextToken();
const i = this.getTokenRaw(s);
const r = this.finalize(e, new Literal(s.value, i));
return this.finalize(e, new ImportAttribute(t, r));
}
parseModuleSpecifier() {
const e = this.createNode();
this.lookahead.type !== 8 && this.throwError(Messages.InvalidModuleSpecifier);
const t = this.nextToken();
const s = this.getTokenRaw(t);
return Character.isStringWellFormedUnicode(t.value) || this.throwError(Messages.InvalidModuleSpecifier), this.finalize(e, new Literal(t.value, s));
}
parseImportSpecifier() {
const e = this.createNode();
let t; let
s;
return this.lookahead.type === 3 ? (t = this.parseVariableIdentifier(), s = t, this.matchContextualKeyword('as') && (this.nextToken(), s = this.parseVariableIdentifier())) : (t = this.lookahead.type == 8 ? this.parseModuleSpecifier() : this.parseIdentifierName(), s = t, this.matchContextualKeyword('as') ? (this.nextToken(), s = this.parseVariableIdentifier()) : this.throwUnexpectedToken(this.nextToken())), this.finalize(e, new ImportSpecifier(s, t));
}
parseNamedImports() {
this.expect('{');
const e = [];
for (; !this.match('}');) e.push(this.parseImportSpecifier()), this.match('}') || this.expect(',');
return this.expect('}'), e;
}
parseImportDefaultSpecifier() {
const e = this.createNode();
const t = this.parseIdentifierName();
return this.finalize(e, new ImportDefaultSpecifier(t));
}
parseImportNamespaceSpecifier() {
const e = this.createNode();
this.expect('*'), this.matchContextualKeyword('as') || this.throwError(Messages.NoAsAfterImportNamespace), this.lookahead.escaped && this.throwError(Messages.NoAsAndFromEscapeSequences), this.nextToken();
const t = this.parseIdentifierName();
return this.finalize(e, new ImportNamespaceSpecifier(t));
}
parseImportDeclaration() {
this.context.inFunctionBody && this.throwError(Messages.IllegalImportDeclaration);
const e = this.createNode();
let t;
this.expectKeyword('import');
let s = [];
if (this.lookahead.type === 8) t = this.parseModuleSpecifier();
else {
if (this.match('{') ? s = s.concat(this.parseNamedImports()) : this.match('*') ? s.push(this.parseImportNamespaceSpecifier()) : this.isIdentifierName(this.lookahead) && !this.matchKeyword('default') ? (s.push(this.parseImportDefaultSpecifier()), this.match(',') && (this.nextToken(), this.match('*') ? s.push(this.parseImportNamespaceSpecifier()) : this.match('{') ? s = s.concat(this.parseNamedImports()) : this.throwUnexpectedToken(this.lookahead))) : this.throwUnexpectedToken(this.nextToken()), !this.matchContextualKeyword('from')) {
const e = this.lookahead.value ? Messages.UnexpectedToken : Messages.MissingFromClause;
this.throwError(e, this.lookahead.value);
}
this.nextToken(), t = this.parseModuleSpecifier();
}
const i = this.parseImportAttributes();
return this.consumeSemicolon(), this.finalize(e, new ImportDeclaration(s, t, i));
}
parseExportSpecifier() {
const e = this.createNode();
const t = this.lookahead.type == 8 ? this.parseModuleSpecifier() : this.parseIdentifierName();
let s = t;
return this.matchContextualKeyword('as') && (this.lookahead.escaped && this.throwError(Messages.NoAsAndFromEscapeSequences), this.nextToken(), s = this.lookahead.type == 8 ? this.parseModuleSpecifier() : this.parseIdentifierName()), this.finalize(e, new ExportSpecifier(t, s));
}
parseExportDeclaration() {
this.context.inFunctionBody && this.throwError(Messages.IllegalExportDeclaration);
const e = this.createNode();
let t;
if (this.expectKeyword('export'), this.matchKeyword('default')) {
if (this.nextToken(), this.matchKeyword('function')) {
const s = this.parseFunctionDeclaration(!0);
t = this.finalize(e, new ExportDefaultDeclaration(s));
} else if (this.matchKeyword('class')) {
const s = this.parseClassDeclaration(!0);
t = this.finalize(e, new ExportDefaultDeclaration(s));
} else if (this.matchContextualKeyword('async')) {
const s = this.matchAsyncFunction() ? this.parseFunctionDeclaration(!0) : this.parseAssignmentExpression();
t = this.finalize(e, new ExportDefaultDeclaration(s));
} else {
this.matchContextualKeyword('from') && this.throwError(Messages.UnexpectedToken, this.lookahead.value);
const s = this.match('{') ? this.parseObjectInitializer() : this.match('[') ? this.parseArrayInitializer() : this.parseAssignmentExpression();
this.consumeSemicolon(), t = this.finalize(e, new ExportDefaultDeclaration(s));
}
} else if (this.match('*')) {
this.nextToken();
let s = null;
if (this.matchContextualKeyword('as') && (this.lookahead.escaped && this.throwError(Messages.NoAsAndFromEscapeSequences), this.nextToken(), s = this.lookahead.type == 8 ? this.parseModuleSpecifier() : this.parseIdentifierName()), !this.matchContextualKeyword('from')) {
const e = this.lookahead.value ? Messages.UnexpectedToken : Messages.MissingFromClause;
this.throwError(e, this.lookahead.value);
}
this.lookahead.escaped && this.throwError(Messages.NoAsAndFromEscapeSequences), this.nextToken();
const i = this.parseModuleSpecifier();
const r = this.parseImportAttributes();
this.consumeSemicolon(), t = this.finalize(e, new ExportAllDeclaration(i, s, r));
} else if (this.lookahead.type === 4) {
let s;
switch (this.lookahead.value) {
case 'let':
case 'const':
s = this.parseLexicalDeclaration({
inFor: !1
});
break;
case 'var':
case 'class':
case 'function':
s = this.parseStatementListItem();
break;
default:
this.throwUnexpectedToken(this.lookahead);
}
t = this.finalize(e, new ExportNamedDeclaration(s, [], null, null));
} else if (this.matchAsyncFunction()) {
const s = this.parseFunctionDeclaration();
t = this.finalize(e, new ExportNamedDeclaration(s, [], null, null));
} else {
const s = [];
let i = null;
let r = !1;
let n = null;
for (this.expect('{'); !this.match('}');) r = r || this.matchKeyword('default'), s.push(this.parseExportSpecifier()), this.match('}') || this.expect(',');
if (this.expect('}'), this.matchContextualKeyword('from')) this.lookahead.escaped && this.throwError(Messages.NoAsAndFromEscapeSequences), this.nextToken(), i = this.parseModuleSpecifier(), n = this.parseImportAttributes(), this.consumeSemicolon();
else if (r) {
const e = this.lookahead.value ? Messages.UnexpectedToken : Messages.MissingFromClause;
this.throwError(e, this.lookahead.value);
} else n = this.parseImportAttributes(), this.consumeSemicolon();
t = this.finalize(e, new ExportNamedDeclaration(null, s, i, n));
}
return t;
}
};
const XHTMLEntities = {
quot: '"',
amp: '&',
apos: "'",
gt: '>',
nbsp: ' ',
iexcl: '¡',
cent: '¢',
pound: '£',
curren: '¤',
yen: '¥',
brvbar: '¦',
sect: '§',
uml: '¨',
copy: '©',
ordf: 'ª',
laquo: '«',
not: '¬',
shy: '',
reg: '®',
macr: '¯',
deg: '°',
plusmn: '±',
sup2: '²',
sup3: '³',
acute: '´',
micro: 'µ',
para: '¶',
middot: '·',
cedil: '¸',
sup1: '¹',
ordm: 'º',
raquo: '»',
frac14: '¼',
frac12: '½',
frac34: '¾',
iquest: '¿',
Agrave: 'À',
Aacute: 'Á',
Acirc: 'Â',
Atilde: 'Ã',
Auml: 'Ä',
Aring: 'Å',
AElig: 'Æ',
Ccedil: 'Ç',
Egrave: 'È',
Eacute: 'É',
Ecirc: 'Ê',
Euml: 'Ë',
Igrave: 'Ì',
Iacute: 'Í',
Icirc: 'Î',
Iuml: 'Ï',
ETH: 'Ð',
Ntilde: 'Ñ',
Ograve: 'Ò',
Oacute: 'Ó',
Ocirc: 'Ô',
Otilde: 'Õ',
Ouml: 'Ö',
times: '×',
Oslash: 'Ø',
Ugrave: 'Ù',
Uacute: 'Ú',
Ucirc: 'Û',
Uuml: 'Ü',
Yacute: 'Ý',
THORN: 'Þ',
szlig: 'ß',
agrave: 'à',
aacute: 'á',
acirc: 'â',
atilde: 'ã',
auml: 'ä',
aring: 'å',
aelig: 'æ',
ccedil: 'ç',
egrave: 'è',
eacute: 'é',
ecirc: 'ê',
euml: 'ë',
igrave: 'ì',
iacute: 'í',
icirc: 'î',
iuml: 'ï',
eth: 'ð',
ntilde: 'ñ',
ograve: 'ò',
oacute: 'ó',
ocirc: 'ô',
otilde: 'õ',
ouml: 'ö',
divide: '÷',
oslash: 'ø',
ugrave: 'ù',
uacute: 'ú',
ucirc: 'û',
uuml: 'ü',
yacute: 'ý',
thorn: 'þ',
yuml: 'ÿ',
OElig: 'Œ',
oelig: 'œ',
Scaron: 'Š',
scaron: 'š',
Yuml: 'Ÿ',
fnof: 'ƒ',
circ: 'ˆ',
tilde: '˜',
Alpha: 'Α',
Beta: 'Β',
Gamma: 'Γ',
Delta: 'Δ',
Epsilon: 'Ε',
Zeta: 'Ζ',
Eta: 'Η',
Theta: 'Θ',
Iota: 'Ι',
Kappa: 'Κ',
Lambda: 'Λ',
Mu: 'Μ',
Nu: 'Ν',
Xi: 'Ξ',
Omicron: 'Ο',
Pi: 'Π',
Rho: 'Ρ',
Sigma: 'Σ',
Tau: 'Τ',
Upsilon: 'Υ',
Phi: 'Φ',
Chi: 'Χ',
Psi: 'Ψ',
Omega: 'Ω',
alpha: 'α',
beta: 'β',
gamma: 'γ',
delta: 'δ',
epsilon: 'ε',
zeta: 'ζ',
eta: 'η',
theta: 'θ',
iota: 'ι',
kappa: 'κ',
lambda: 'λ',
mu: 'μ',
nu: 'ν',
xi: 'ξ',
omicron: 'ο',
pi: 'π',
rho: 'ρ',
sigmaf: 'ς',
sigma: 'σ',
tau: 'τ',
upsilon: 'υ',
phi: 'φ',
chi: 'χ',
psi: 'ψ',
omega: 'ω',
thetasym: 'ϑ',
upsih: 'ϒ',
piv: 'ϖ',
ensp: ' ',
emsp: ' ',
thinsp: ' ',
zwnj: '',
zwj: '',
lrm: '',
rlm: '',
ndash: '–',
mdash: '—',
lsquo: '‘',
rsquo: '’',
sbquo: '‚',
ldquo: '“',
rdquo: '”',
bdquo: '„',
dagger: '†',
Dagger: '‡',
bull: '•',
hellip: '…',
permil: '‰',
prime: '′',
Prime: '″',
lsaquo: '‹',
rsaquo: '›',
oline: '‾',
frasl: '⁄',
euro: '€',
image: 'ℑ',
weierp: '℘',
real: 'ℜ',
trade: '™',
alefsym: 'ℵ',
larr: '←',
uarr: '↑',
rarr: '→',
darr: '↓',
harr: '↔',
crarr: '↵',
lArr: '⇐',
uArr: '⇑',
rArr: '⇒',
dArr: '⇓',
hArr: '⇔',
forall: '∀',
part: '∂',
exist: '∃',
empty: '∅',
nabla: '∇',
isin: '∈',
notin: '∉',
ni: '∋',
prod: '∏',
sum: '∑',
minus: '−',
lowast: '∗',
radic: '√',
prop: '∝',
infin: '∞',
ang: '∠',
and: '∧',
or: '∨',
cap: '∩',
cup: '∪',
int: '∫',
there4: '∴',
sim: '∼',
cong: '≅',
asymp: '≈',
ne: '≠',
equiv: '≡',
le: '≤',
ge: '≥',
sub: '⊂',
sup: '⊃',
nsub: '⊄',
sube: '⊆',
supe: '⊇',
oplus: '⊕',
otimes: '⊗',
perp: '⊥',
sdot: '⋅',
lceil: '⌈',
rceil: '⌉',
lfloor: '⌊',
rfloor: '⌋',
loz: '◊',
spades: '♠',
clubs: '♣',
hearts: '♥',
diams: '♦',
lang: '⟨',
rang: '⟩'
};
function getQualifiedElementName(e) {
let t;
switch (e.type) {
case 'JSXIdentifier':
t = e.name;
break;
case 'JSXNamespacedName':
const s = e;
t = `${getQualifiedElementName(s.namespace)}:${getQualifiedElementName(s.name)}`;
break;
case 'JSXMemberExpression':
const i = e;
t = `${getQualifiedElementName(i.object)}.${getQualifiedElementName(i.property)}`;
}
return t;
}
TokenName[100] = 'JSXIdentifier', TokenName[101] = 'JSXText';
const JSXParser = class extends Parser {
constructor(e, t, s) {
super(e, t, s);
}
parsePrimaryExpression() {
return this.match('<') ? this.parseJSXRoot() : super.parsePrimaryExpression();
}
startJSX() {
this.scanner.index = this.startMarker.index, this.scanner.lineNumber = this.startMarker.line, this.scanner.lineStart = this.startMarker.index - this.startMarker.column;
}
finishJSX() {
this.nextToken();
}
reenterJSX() {
this.startJSX(), this.expectJSX('}'), this.config.tokens && this.tokens.pop();
}
createJSXNode() {
return this.collectComments(), {
index: this.scanner.index,
line: this.scanner.lineNumber,
column: this.scanner.index - this.scanner.lineStart
};
}
createJSXChildNode() {
return {
index: this.scanner.index,
line: this.scanner.lineNumber,
column: this.scanner.index - this.scanner.lineStart
};
}
scanXHTMLEntity(e) {
let t = '&';
let s = !0;
let i = !1;
let r = !1;
let n = !1;
for (; !this.scanner.eof() && s && !i;) {
const a = this.scanner.source[this.scanner.index];
if (a === e) break;
if (i = a === ';', t += a, ++this.scanner.index, !i) {
switch (t.length) {
case 2:
r = a === '#';
break;
case 3:
r && (n = a === 'x', s = n || Character.isDecimalDigit(a.charCodeAt(0)), r = r && !n);
break;
default:
s = s && !(r && !Character.isDecimalDigit(a.charCodeAt(0))), s = s && !(n && !Character.isHexDigit(a.charCodeAt(0)));
}
}
}
if (s && i && t.length > 2) {
const e = t.substr(1, t.length - 2);
r && e.length > 1 ? t = String.fromCharCode(parseInt(e.substr(1), 10)) : n && e.length > 2 ? t = String.fromCharCode(parseInt(`0${e.substr(1)}`, 16)) : r || n || !XHTMLEntities[e] || (t = XHTMLEntities[e]);
}
return t;
}
lexJSX() {
const e = this.scanner.source.charCodeAt(this.scanner.index);
if (e === 60 || e === 62 || e === 47 || e === 58 || e === 61 || e === 123 || e === 125) {
return {
type: 7,
value: this.scanner.source[this.scanner.index++],
lineNumber: this.scanner.lineNumber,
lineStart: this.scanner.lineStart,
start: this.scanner.index - 1,
end: this.scanner.index
};
}
if (e === 34 || e === 39) {
const e = this.scanner.index;
const t = this.scanner.source[this.scanner.index++];
let s = '';
for (; !this.scanner.eof();) {
const e = this.scanner.source[this.scanner.index++];
if (e === t) break;
s += e === '&' ? this.scanXHTMLEntity(t) : e;
}
return {
type: 8,
value: s,
lineNumber: this.scanner.lineNumber,
lineStart: this.scanner.lineStart,
start: e,
end: this.scanner.index
};
}
if (e === 46) {
const e = this.scanner.source.charCodeAt(this.scanner.index + 1);
const t = this.scanner.source.charCodeAt(this.scanner.index + 2);
const s = e === 46 && t === 46 ? '...' : '.';
const i = this.scanner.index;
return this.scanner.index += s.length, {
type: 7,
value: s,
lineNumber: this.scanner.lineNumber,
lineStart: this.scanner.lineStart,
start: i,
end: this.scanner.index
};
}
if (e === 96) {
return {
type: 10,
value: '',
lineNumber: this.scanner.lineNumber,
lineStart: this.scanner.lineStart,
start: this.scanner.index,
end: this.scanner.index
};
}
if (Character.isIdentifierStart(e) && e !== 92) {
const e = this.scanner.index;
for (++this.scanner.index; !this.scanner.eof();) {
const e = this.scanner.source.charCodeAt(this.scanner.index);
if (Character.isIdentifierPart(e) && e !== 92) ++this.scanner.index;
else {
if (e !== 45) break;
++this.scanner.index;
}
}
return {
type: 100,
value: this.scanner.source.slice(e, this.scanner.index),
lineNumber: this.scanner.lineNumber,
lineStart: this.scanner.lineStart,
start: e,
end: this.scanner.index
};
}
return this.scanner.lex();
}
nextJSXToken() {
this.collectComments(), this.startMarker.index = this.scanner.index, this.startMarker.line = this.scanner.lineNumber, this.startMarker.column = this.scanner.index - this.scanner.lineStart;
const e = this.lexJSX();
return this.lastMarker.index = this.scanner.index, this.lastMarker.line = this.scanner.lineNumber, this.lastMarker.column = this.scanner.index - this.scanner.lineStart, this.config.tokens && this.tokens.push(this.convertToken(e)), e;
}
nextJSXText() {
this.startMarker.index = this.scanner.index, this.startMarker.line = this.scanner.lineNumber, this.startMarker.column = this.scanner.index - this.scanner.lineStart;
const e = this.scanner.index;
let t = '';
for (; !this.scanner.eof();) {
const e = this.scanner.source[this.scanner.index];
if (e === '{' || e === '<') break;
++this.scanner.index, t += e, Character.isLineTerminator(e.charCodeAt(0)) && (++this.scanner.lineNumber, e === '\r' && this.scanner.source[this.scanner.index] === '\n' && ++this.scanner.index, this.scanner.lineStart = this.scanner.index);
}
this.lastMarker.index = this.scanner.index, this.lastMarker.line = this.scanner.lineNumber, this.lastMarker.column = this.scanner.index - this.scanner.lineStart;
const s = {
type: 101,
value: t,
lineNumber: this.scanner.lineNumber,
lineStart: this.scanner.lineStart,
start: e,
end: this.scanner.index
};
return t.length > 0 && this.config.tokens && this.tokens.push(this.convertToken(s)), s;
}
peekJSXToken() {
const e = this.scanner.saveState();
this.scanner.scanComments();
const t = this.lexJSX();
return this.scanner.restoreState(e), t;
}
expectJSX(e) {
const t = this.nextJSXToken();
t.type === 7 && t.value === e || this.throwUnexpectedToken(t);
}
matchJSX(e) {
const t = this.peekJSXToken();
return t.type === 7 && t.value === e;
}
parseJSXIdentifier() {
const e = this.createJSXNode();
const t = this.nextJSXToken();
return t.type !== 100 && this.throwUnexpectedToken(t), this.finalize(e, new JSXIdentifier(t.value));
}
parseJSXElementName() {
const e = this.createJSXNode();
let t = this.parseJSXIdentifier();
if (this.matchJSX(':')) {
const s = t;
this.expectJSX(':');
const i = this.parseJSXIdentifier();
t = this.finalize(e, new JSXNamespacedName(s, i));
} else if (this.matchJSX('.')) {
for (; this.matchJSX('.');) {
const s = t;
this.expectJSX('.');
const i = this.parseJSXIdentifier();
t = this.finalize(e, new JSXMemberExpression(s, i));
}
}
return t;
}
parseJSXAttributeName() {
const e = this.createJSXNode();
let t;
const s = this.parseJSXIdentifier();
if (this.matchJSX(':')) {
const i = s;
this.expectJSX(':');
const r = this.parseJSXIdentifier();
t = this.finalize(e, new JSXNamespacedName(i, r));
} else t = s;
return t;
}
parseJSXStringLiteralAttribute() {
const e = this.createJSXNode();
const t = this.nextJSXToken();
t.type !== 8 && this.throwUnexpectedToken(t);
const s = this.getTokenRaw(t);
return this.finalize(e, new Literal(t.value, s));
}
parseJSXExpressionAttribute() {
const e = this.createJSXNode();
this.expectJSX('{'), this.finishJSX(), this.match('}') && this.tolerateError('JSX attributes must only be assigned a non-empty expression');
const t = this.parseAssignmentExpression();
return this.reenterJSX(), this.finalize(e, new JSXExpressionContainer(t));
}
parseJSXAttributeValue() {
return this.matchJSX('{') ? this.parseJSXExpressionAttribute() : this.matchJSX('<') ? this.parseJSXElement() : this.parseJSXStringLiteralAttribute();
}
parseJSXNameValueAttribute() {
const e = this.createJSXNode();
const t = this.parseJSXAttributeName();
let s = null;
return this.matchJSX('=') && (this.expectJSX('='), s = this.parseJSXAttributeValue()), this.finalize(e, new JSXAttribute(t, s));
}
parseJSXSpreadAttribute() {
const e = this.createJSXNode();
this.expectJSX('{'), this.expectJSX('...'), this.finishJSX();
const t = this.parseAssignmentExpression();
return this.reenterJSX(), this.finalize(e, new JSXSpreadAttribute(t));
}
parseJSXAttributes() {
const e = [];
for (; !this.matchJSX('/') && !this.matchJSX('>');) {
const t = this.matchJSX('{') ? this.parseJSXSpreadAttribute() : this.parseJSXNameValueAttribute();
e.push(t);
}
return e;
}
parseJSXOpeningElement() {
const e = this.createJSXNode();
if (this.expectJSX('<'), this.matchJSX('>')) return this.expectJSX('>'), this.finalize(e, new JSXOpeningFragment(!1));
const t = this.parseJSXElementName();
const s = this.parseJSXAttributes();
const i = this.matchJSX('/');
return i && this.expectJSX('/'), this.expectJSX('>'), this.finalize(e, new JSXOpeningElement(t, i, s));
}
parseJSXBoundaryElement() {
const e = this.createJSXNode();
if (this.expectJSX('<'), this.matchJSX('/')) {
if (this.expectJSX('/'), this.matchJSX('>')) return this.expectJSX('>'), this.finalize(e, new JSXClosingFragment());
const t = this.parseJSXElementName();
return this.expectJSX('>'), this.finalize(e, new JSXClosingElement(t));
}
const t = this.parseJSXElementName();
const s = this.parseJSXAttributes();
const i = this.matchJSX('/');
return i && this.expectJSX('/'), this.expectJSX('>'), this.finalize(e, new JSXOpeningElement(t, i, s));
}
parseJSXEmptyExpression() {
const e = this.createJSXChildNode();
return this.collectComments(), this.lastMarker.index = this.scanner.index, this.lastMarker.line = this.scanner.lineNumber, this.lastMarker.column = this.scanner.index - this.scanner.lineStart, this.finalize(e, new JSXEmptyExpression());
}
parseJSXExpressionContainer() {
const e = this.createJSXNode();
let t;
return this.expectJSX('{'), this.matchJSX('}') ? (t = this.parseJSXEmptyExpression(), this.expectJSX('}')) : (this.finishJSX(), t = this.parseAssignmentExpression(), this.reenterJSX()), this.finalize(e, new JSXExpressionContainer(t));
}
parseJSXChildren() {
const e = [];
for (; !this.scanner.eof();) {
const t = this.createJSXChildNode();
const s = this.nextJSXText();
if (s.start < s.end) {
const i = this.getTokenRaw(s);
const r = this.finalize(t, new JSXText(s.value, i));
e.push(r);
}
if (this.scanner.source[this.scanner.index] !== '{') break;
{
const t = this.parseJSXExpressionContainer();
e.push(t);
}
}
return e;
}
parseComplexJSXElement(e) {
const t = [];
for (; !this.scanner.eof();) {
e.children = e.children.concat(this.parseJSXChildren());
const s = this.createJSXChildNode();
const i = this.parseJSXBoundaryElement();
if (i.type === 'JSXOpeningElement') {
const r = i;
if (r.selfClosing) {
const t = this.finalize(s, new JSXElement(r, [], null));
e.children.push(t);
} else {
t.push(e), e = {
node: s,
opening: r,
closing: null,
children: []
};
}
}
if (i.type === 'JSXClosingElement') {
e.closing = i;
const s = getQualifiedElementName(e.opening.name);
if (s !== getQualifiedElementName(e.closing.name) && this.tolerateError('Expected corresponding JSX closing tag for %0', s), !(t.length > 0)) break;
{
const s = this.finalize(e.node, new JSXElement(e.opening, e.children, e.closing));
(e = t[t.length - 1]).children.push(s), t.pop();
}
}
if (i.type === 'JSXClosingFragment') {
if (e.closing = i, e.opening.type === 'JSXOpeningFragment') break;
this.tolerateError('Expected corresponding JSX closing tag for jsx fragment');
}
}
return e;
}
parseJSXElement() {
const e = this.createJSXNode();
const t = this.parseJSXOpeningElement();
let s = [];
let i = null;
if (!t.selfClosing) {
const r = this.parseComplexJSXElement({
node: e,
opening: t,
closing: i,
children: s
});
s = r.children, i = r.closing;
}
return this.finalize(e, new JSXElement(t, s, i));
}
parseJSXRoot() {
this.config.tokens && this.tokens.pop(), this.startJSX();
const e = this.parseJSXElement();
return this.finishJSX(), e;
}
isStartOfExpression() {
return super.isStartOfExpression() || this.match('<');
}
};
const beforeFunctionExpressionTokens = ['(', '{', '[', 'in', 'typeof', 'instanceof', 'new', 'return', 'case', 'delete', 'throw', 'void', '=', '+=', '-=', '*=', '**=', '/=', '%=', '<<=', '>>=', '>>>=', '&=', '|=', '^=', ',', '+', '-', '*', '**', '/', '%', '++', '--', '<<', '>>', '>>>', '&', '|', '^', '!', '~', '&&', '||', '??', '?', ':', '===', '==', '>=', '<=', '<', '>', '!=', '!=='];
const Reader = class {
values;
curly;
paren;
constructor() {
this.values = [], this.curly = this.paren = -1;
}
beforeFunctionExpression(e) {
return beforeFunctionExpressionTokens.includes(e);
}
isRegexStart() {
const e = this.values[this.values.length - 1];
let t = e !== null;
switch (e) {
case 'this':
case ']':
t = !1;
break;
case ')':
const e = this.values[this.paren - 1];
t = e === 'if' || e === 'while' || e === 'for' || e === 'with';
break;
case '}':
if (t = !0, this.values[this.curly - 3] === 'function') {
const e = this.values[this.curly - 4];
t = !!e && !this.beforeFunctionExpression(e);
} else if (this.values[this.curly - 4] === 'function') {
const e = this.values[this.curly - 5];
t = !e || !this.beforeFunctionExpression(e);
}
}
return t;
}
push(e) {
e.type === 7 || e.type === 4 ? (e.value === '{' ? this.curly = this.values.length : e.value === '(' && (this.paren = this.values.length), this.values.push(e.value)) : this.values.push(null);
}
};
const Tokenizer = class {
errorHandler;
scanner;
trackRange;
trackLoc;
buffer;
reader;
constructor(e, t) {
this.errorHandler = new ErrorHandler(), this.errorHandler.tolerant = !!t && (typeof t.tolerant === 'boolean' && t.tolerant), this.scanner = new Scanner(e, this.errorHandler), this.scanner.trackComment = !!t && (typeof t.comment === 'boolean' && t.comment), this.trackRange = !!t && (typeof t.range === 'boolean' && t.range), this.trackLoc = !!t && (typeof t.loc === 'boolean' && t.loc), this.buffer = [], this.reader = new Reader();
}
errors() {
return this.errorHandler.errors;
}
getNextToken() {
if (this.buffer.length === 0) {
const e = this.scanner.scanComments();
if (this.scanner.trackComment) {
for (let t = 0; t < e.length; ++t) {
const s = e[t];
const i = this.scanner.source.slice(s.slice[0], s.slice[1]);
const r = {
type: s.multiLine ? 'BlockComment' : 'LineComment',
value: i
};
this.trackRange && (r.range = s.range), this.trackLoc && (r.loc = s.loc), this.buffer.push(r);
}
}
if (!this.scanner.eof()) {
let e;
this.trackLoc && (e = {
start: {
line: this.scanner.lineNumber,
column: this.scanner.index - this.scanner.lineStart
},
end: {}
});
let t;
if (this.scanner.source[this.scanner.index] === '/' && this.reader.isRegexStart()) {
const e = this.scanner.saveState();
try {
t = this.scanner.scanRegExp();
} catch (s) {
this.scanner.restoreState(e), t = this.scanner.lex();
}
} else t = this.scanner.lex();
this.reader.push(t);
const s = {
type: TokenName[t.type],
value: this.scanner.source.slice(t.start, t.end)
};
if (this.trackRange && (s.range = [t.start, t.end]), this.trackLoc && (e.end = {
line: this.scanner.lineNumber,
column: this.scanner.index - this.scanner.lineStart
}, s.loc = e), t.type === 9) {
const e = t.pattern;
const i = t.flags;
s.regex = {
pattern: e,
flags: i
};
}
this.buffer.push(s);
}
}
return this.buffer.shift();
}
};
const Visitor = class {
visit(e) {
if (e == null) return e;
switch (e.type) {
case 'AssignmentExpression':
return this.visitAssignmentExpression(e);
case 'AssignmentPattern':
return this.visitAssignmentPattern(e);
case 'ArrayExpression':
return this.visitArrayExpression(e);
case 'ArrayPattern':
return this.visitArrayPattern(e);
case 'ArrowFunctionExpression':
return this.visitArrowFunctionExpression(e);
case 'AwaitExpression':
return this.visitAwaitExpression(e);
case 'BlockStatement':
return this.visitBlockStatement(e);
case 'BinaryExpression':
return this.visitBinaryExpression(e);
case 'BreakStatement':
return this.visitBreakStatement(e);
case 'CallExpression':
return this.visitCallExpression(e);
case 'CatchClause':
return this.visitCatchClause(e);
case 'ChainExpression':
return this.visitChainExpression(e);
case 'ClassBody':
return this.visitClassBody(e);
case 'ClassDeclaration':
return this.visitClassDeclaration(e);
case 'ClassExpression':
return this.visitClassExpression(e);
case 'ConditionalExpression':
return this.visitConditionalExpression(e);
case 'ContinueStatement':
return this.visitContinueStatement(e);
case 'Decorator':
return this.visitDecorator(e);
case 'DoWhileStatement':
return this.visitDoWhileStatement(e);
case 'DebuggerStatement':
return this.visitDebuggerStatement(e);
case 'EmptyStatement':
return this.visitEmptyStatement(e);
case 'ExportAllDeclaration':
return this.visitExportAllDeclaration(e);
case 'ExportDefaultDeclaration':
return this.visitExportDefaultDeclaration(e);
case 'ExportNamedDeclaration':
return this.visitExportNamedDeclaration(e);
case 'ExportSpecifier':
return this.visitExportSpecifier(e);
case 'ExpressionStatement':
return this.visitExpressionStatement(e);
case 'ForStatement':
return this.visitForStatement(e);
case 'ForOfStatement':
return this.visitForOfStatement(e);
case 'ForInStatement':
return this.visitForInStatement(e);
case 'FunctionDeclaration':
return this.visitFunctionDeclaration(e);
case 'FunctionExpression':
return this.visitFunctionExpression(e);
case 'Identifier':
return this.visitIdentifier(e);
case 'IfStatement':
return this.visitIfStatement(e);
case 'ImportAttribute':
return this.visitImportAttribute(e);
case 'ImportExpression':
return this.visitImportExpression(e);
case 'ImportDeclaration':
return this.visitImportDeclaration(e);
case 'ImportDefaultSpecifier':
return this.visitImportDefaultSpecifier(e);
case 'ImportNamespaceSpecifier':
return this.visitImportNamespaceSpecifier(e);
case 'ImportSpecifier':
return this.visitImportSpecifier(e);
case 'Literal':
return this.visitLiteral(e);
case 'LabeledStatement':
return this.visitLabeledStatement(e);
case 'LogicalExpression':
return this.visitLogicalExpression(e);
case 'MemberExpression':
return this.visitMemberExpression(e);
case 'MetaProperty':
return this.visitMetaProperty(e);
case 'MethodDefinition':
return this.visitMethodDefinition(e);
case 'NewExpression':
return this.visitNewExpression(e);
case 'ObjectExpression':
return this.visitObjectExpression(e);
case 'ObjectPattern':
return this.visitObjectPattern(e);
case 'Program':
return this.visitProgram(e);
case 'Property':
return this.visitProperty(e);
case 'PrivateIdentifier':
return this.visitPrivateIdentifier(e);
case 'RestElement':
return this.visitRestElement(e);
case 'ReturnStatement':
return this.visitReturnStatement(e);
case 'SequenceExpression':
return this.visitSequenceExpression(e);
case 'SpreadElement':
return this.visitSpreadElement(e);
case 'StaticBlock':
return this.visitStaticBlock(e);
case 'Super':
return this.visitSuper(e);
case 'SwitchCase':
return this.visitSwitchCase(e);
case 'SwitchStatement':
return this.visitSwitchStatement(e);
case 'TaggedTemplateExpression':
return this.visitTaggedTemplateExpression(e);
case 'TemplateElement':
return this.visitTemplateElement(e);
case 'TemplateLiteral':
return this.visitTemplateLiteral(e);
case 'ThisExpression':
return this.visitThisExpression(e);
case 'ThrowStatement':
return this.visitThrowStatement(e);
case 'TryStatement':
return this.visitTryStatement(e);
case 'UnaryExpression':
return this.visitUnaryExpression(e);
case 'UpdateExpression':
return this.visitUpdateExpression(e);
case 'VariableDeclaration':
return this.visitVariableDeclaration(e);
case 'VariableDeclarator':
return this.visitVariableDeclarator(e);
case 'WhileStatement':
return this.visitWhileStatement(e);
case 'WithStatement':
return this.visitWithStatement(e);
case 'YieldExpression':
return this.visitYieldExpression(e);
}
}
visitNodeList(e) {
if (e == null) return e;
let t = null;
for (let s = 0, i = e.length; s < i; s++) {
const i = this.visit(e[s]);
if (t != null) t.push(i);
else if (i != e[s]) {
t = [];
for (let i = 0; i < s; i++) t.push(e[i]);
t.push(i);
}
}
return t != null ? t : e;
}
visitAssignmentExpression(e) {
const t = this.visit(e.left);
const s = this.visit(e.right);
return t !== e.left || s !== e.right ? new AssignmentExpression(e.operator, t, s) : e;
}
visitAssignmentPattern(e) {
const t = this.visit(e.left);
const s = this.visit(e.right);
return t !== e.left || s !== e.right ? new AssignmentPattern(t, s) : e;
}
visitArrayExpression(e) {
const t = this.visitNodeList(e.elements);
return t !== e.elements ? new ArrayExpression(t) : e;
}
visitArrayPattern(e) {
const t = this.visitNodeList(e.elements);
return t !== e.elements ? new ArrayPattern(t) : e;
}
visitArrowFunctionExpression(e) {
const t = this.visit(e.id);
const s = this.visitNodeList(e.params);
const i = this.visit(e.body);
if (t !== e.id || s !== e.params || i !== e.body) {
const r = new ArrowFunctionExpression(s, i, e.expression, e.async);
return r.id = t, r;
}
return e;
}
visitAwaitExpression(e) {
const t = this.visit(e.argument);
return t !== e.argument ? new AwaitExpression(t) : e;
}
visitBlockStatement(e) {
const t = this.visitNodeList(e.body);
return t !== e.body ? new BlockStatement(t) : e;
}
visitBinaryExpression(e) {
const t = this.visit(e.left);
const s = this.visit(e.right);
return t !== e.left || s !== e.right ? new BinaryExpression(e.operator, t, s) : e;
}
visitBreakStatement(e) {
const t = this.visit(e.label);
return t !== e.label ? new BreakStatement(t) : e;
}
visitCallExpression(e) {
const t = this.visit(e.callee);
const s = this.visitNodeList(e.arguments);
return t !== e.callee || s !== e.arguments ? new CallExpression(t, s, e.optional) : e;
}
visitCatchClause(e) {
const t = this.visit(e.param);
const s = this.visit(e.body);
return t !== e.param || s !== e.body ? new CatchClause(t, s) : e;
}
visitChainExpression(e) {
const t = this.visit(e.expression);
return t !== e.expression ? new ChainExpression(t) : e;
}
visitClassBody(e) {
const t = this.visitNodeList(e.body);
return t !== e.body ? new ClassBody(t) : e;
}
visitClassDeclaration(e) {
const t = this.visit(e.id);
const s = this.visit(e.superClass);
const i = this.visit(e.body);
const r = this.visitNodeList(e.decorators);
return t !== e.id || s !== e.superClass || i !== e.body || r !== e.decorators ? new ClassDeclaration(t, s, i, r) : e;
}
visitClassExpression(e) {
const t = this.visit(e.id);
const s = this.visit(e.superClass);
const i = this.visit(e.body);
const r = this.visitNodeList(e.decorators);
return t !== e.id || s !== e.superClass || i !== e.body || r !== e.decorators ? new ClassExpression(t, s, i, r) : e;
}
visitConditionalExpression(e) {
const t = this.visit(e.test);
const s = this.visit(e.consequent);
const i = this.visit(e.alternate);
return t !== e.test || s !== e.consequent || i !== e.alternate ? new ConditionalExpression(t, s, i) : e;
}
visitContinueStatement(e) {
const t = this.visit(e.label);
return t !== e.label ? new ContinueStatement(t) : e;
}
visitDecorator(e) {
const t = this.visit(e.expression);
return t !== e.expression ? new Decorator(t) : e;
}
visitDoWhileStatement(e) {
const t = this.visit(e.body);
const s = this.visit(e.test);
return t !== e.body || s !== e.test ? new DoWhileStatement(t, s) : e;
}
visitDebuggerStatement(e) {
return e;
}
visitEmptyStatement(e) {
return e;
}
visitExportAllDeclaration(e) {
const t = this.visit(e.source);
const s = this.visit(e.exported);
const i = this.visitNodeList(e.assertions);
return t !== e.source || s !== e.exported || i !== e.assertions ? new ExportAllDeclaration(t, s, i) : e;
}
visitExportDefaultDeclaration(e) {
const t = this.visit(e.declaration);
return t !== e.declaration ? new ExportDefaultDeclaration(t) : e;
}
visitExportNamedDeclaration(e) {
const t = this.visit(e.declaration);
const s = this.visitNodeList(e.specifiers);
const i = this.visit(e.source);
const r = this.visitNodeList(e.assertions);
return t !== e.declaration || s !== e.specifiers || i !== e.source || r !== e.assertions ? new ExportNamedDeclaration(t, s, i, r) : e;
}
visitExportSpecifier(e) {
const t = this.visit(e.exported);
const s = this.visit(e.local);
return t !== e.exported || s !== e.local ? new ExportSpecifier(t, s) : e;
}
visitExpressionStatement(e) {
const t = this.visit(e.expression);
return t !== e.expression ? new ExpressionStatement(t) : e;
}
visitForStatement(e) {
const t = this.visit(e.init);
const s = this.visit(e.test);
const i = this.visit(e.update);
const r = this.visit(e.body);
return t !== e.init || s !== e.test || i !== e.update || r !== e.body ? new ForStatement(t, s, i, r) : e;
}
visitForOfStatement(e) {
const t = this.visit(e.left);
const s = this.visit(e.right);
const i = this.visit(e.body);
return t !== e.left || s !== e.right || i !== e.body ? new ForOfStatement(t, s, i, e.await) : e;
}
visitForInStatement(e) {
const t = this.visit(e.left);
const s = this.visit(e.right);
const i = this.visit(e.body);
return t !== e.left || s !== e.right || i !== e.body ? new ForInStatement(t, s, i) : e;
}
visitFunctionDeclaration(e) {
const t = this.visit(e.id);
const s = this.visitNodeList(e.params);
const i = this.visit(e.body);
return t !== e.id || s !== e.params || i !== e.body ? new FunctionDeclaration(t, s, i, e.generator) : e;
}
visitFunctionExpression(e) {
const t = this.visit(e.id);
const s = this.visitNodeList(e.params);
const i = this.visit(e.body);
return t !== e.id || s !== e.params || i !== e.body ? new FunctionExpression(t, s, i, e.generator, e.async) : e;
}
visitIdentifier(e) {
return e;
}
visitIfStatement(e) {
const t = this.visit(e.test);
const s = this.visit(e.consequent);
const i = this.visit(e.alternate);
return t !== e.test || s !== e.consequent || i !== e.alternate ? new IfStatement(t, s, i) : e;
}
visitImportAttribute(e) {
const t = this.visit(e.key);
const s = this.visit(e.value);
return t !== e.key || s !== e.value ? new ImportAttribute(t, s) : e;
}
visitImportExpression(e) {
const t = this.visit(e.source);
const s = this.visit(e.attributes);
return t !== e.source || s !== e.attributes ? new ImportExpression(t, s) : e;
}
visitImportDeclaration(e) {
const t = this.visitNodeList(e.specifiers);
const s = this.visit(e.source);
const i = this.visitNodeList(e.assertions);
return t !== e.specifiers || s !== e.source || i !== e.assertions ? new ImportDeclaration(t, s, i) : e;
}
visitImportDefaultSpecifier(e) {
const t = this.visit(e.local);
return t !== e.local ? new ImportDefaultSpecifier(t) : e;
}
visitImportNamespaceSpecifier(e) {
const t = this.visit(e.local);
return t !== e.local ? new ImportNamespaceSpecifier(t) : e;
}
visitImportSpecifier(e) {
const t = this.visit(e.local);
const s = this.visit(e.imported);
return t !== e.local || s !== e.imported ? new ImportSpecifier(t, s) : e;
}
visitLiteral(e) {
return e;
}
visitLabeledStatement(e) {
const t = this.visit(e.label);
const s = this.visit(e.body);
return t !== e.label || s !== e.body ? new LabeledStatement(t, s) : e;
}
visitLogicalExpression(e) {
const t = this.visit(e.left);
const s = this.visit(e.right);
return t !== e.left || s !== e.right ? new LogicalExpression(e.operator, t, s) : e;
}
visitMemberExpression(e) {
const t = this.visit(e.object);
const s = this.visit(e.property);
return t !== e.object || s !== e.property ? new MemberExpression(e.computed, t, s, e.optional) : e;
}
visitMetaProperty(e) {
const t = this.visit(e.meta);
const s = this.visit(e.property);
return t !== e.meta || s !== e.property ? new MetaProperty(t, s) : e;
}
visitMethodDefinition(e) {
const t = this.visit(e.key);
const s = this.visit(e.value);
const i = this.visitNodeList(e.decorators);
return t !== e.key || s !== e.value || i !== e.decorators ? new MethodDefinition(t, e.computed, s, e.kind, e.static, i) : e;
}
visitNewExpression(e) {
const t = this.visit(e.callee);
const s = this.visitNodeList(e.arguments);
return t !== e.callee || s !== e.arguments ? new NewExpression(t, s) : e;
}
visitObjectExpression(e) {
const t = this.visitNodeList(e.properties);
return t !== e.properties ? new ObjectExpression(t) : e;
}
visitObjectPattern(e) {
const t = this.visitNodeList(e.properties);
return t !== e.properties ? new ObjectPattern(t) : e;
}
visitProgram(e) {
const t = this.visitNodeList(e.body);
return t !== e.body ? new Program(e.sourceType, t) : e;
}
visitProperty(e) {
const t = this.visit(e.key);
const s = this.visit(e.value);
const i = this.visitNodeList(e.decorators);
return t !== e.key || s !== e.value || i != i ? 'kind' in e ? new Property(e.kind, t, e.computed, s, e.method, e.shorthand) : new PropertyDefinition(t, e.computed, s, e.static, i) : e;
}
visitPrivateIdentifier(e) {
return e;
}
visitRestElement(e) {
const t = this.visit(e.argument);
return t !== e.argument ? new RestElement(t) : e;
}
visitReturnStatement(e) {
const t = this.visit(e.argument);
return t !== e.argument ? new ReturnStatement(t) : e;
}
visitSequenceExpression(e) {
const t = this.visitNodeList(e.expressions);
return t !== e.expressions ? new SequenceExpression(t) : e;
}
visitSpreadElement(e) {
const t = this.visit(e.argument);
return t !== e.argument ? new SpreadElement(t) : e;
}
visitStaticBlock(e) {
const t = this.visitNodeList(e.body);
return t !== e.body ? new StaticBlock(t) : e;
}
visitSuper(e) {
return e;
}
visitSwitchCase(e) {
const t = this.visit(e.test);
const s = this.visitNodeList(e.consequent);
return t !== e.test || s !== e.consequent ? new SwitchCase(t, s) : e;
}
visitSwitchStatement(e) {
const t = this.visit(e.discriminant);
const s = this.visitNodeList(e.cases);
return t !== e.discriminant || s !== e.cases ? new SwitchStatement(t, s) : e;
}
visitTaggedTemplateExpression(e) {
const t = this.visit(e.tag);
const s = this.visit(e.quasi);
return t !== e.tag || s !== e.quasi ? new TaggedTemplateExpression(t, s) : e;
}
visitTemplateElement(e) {
return e;
}
visitTemplateLiteral(e) {
const t = this.visitNodeList(e.quasis);
const s = this.visitNodeList(e.expressions);
return t !== e.quasis || s !== e.expressions ? new TemplateLiteral(t, s) : e;
}
visitThisExpression(e) {
return e;
}
visitThrowStatement(e) {
const t = this.visit(e.argument);
return t !== e.argument ? new ThrowStatement(t) : e;
}
visitTryStatement(e) {
const t = this.visit(e.block);
const s = this.visit(e.handler);
const i = this.visit(e.finalizer);
return t !== e.block || s !== e.handler || i !== e.finalizer ? new TryStatement(t, s, i) : e;
}
visitUnaryExpression(e) {
const t = this.visit(e.argument);
return t !== e.argument ? new UnaryExpression(e.operator, t) : e;
}
visitUpdateExpression(e) {
const t = this.visit(e.argument);
return t !== e.argument ? new UpdateExpression(e.operator, t, e.prefix) : e;
}
visitVariableDeclaration(e) {
const t = this.visitNodeList(e.declarations);
return t !== e.declarations ? new VariableDeclaration(t, e.kind) : e;
}
visitVariableDeclarator(e) {
const t = this.visit(e.id);
const s = this.visit(e.init);
return t !== e.id || s !== e.init ? new VariableDeclarator(t, s) : e;
}
visitWhileStatement(e) {
const t = this.visit(e.test);
const s = this.visit(e.body);
return t !== e.test || s !== e.body ? new WhileStatement(t, s) : e;
}
visitWithStatement(e) {
const t = this.visit(e.object);
const s = this.visit(e.body);
return t !== e.object || s !== e.body ? new WithStatement(t, s) : e;
}
visitYieldExpression(e) {
const t = this.visit(e.argument);
return t !== e.argument ? new YieldExpression(t, e.delegate) : e;
}
};
function parse(e, t, s) {
let i = null;
const r = (e, t) => {
s && s(e, t), i && i.visit(e, t);
};
let n = typeof s === 'function' ? r : null;
let a = !1;
if (t) {
a = typeof t.comment === 'boolean' && t.comment;
const e = typeof t.attachComment === 'boolean' && t.attachComment;
(a || e) && (i = new CommentHandler(), i.attach = e, t.comment = !0, n = r);
}
let o; let
u = !1;
t && typeof t.sourceType === 'string' && (u = t.sourceType === 'module'), o = t && typeof t.jsx === 'boolean' && t.jsx ? new JSXParser(e, t, n) : new Parser(e, t, n);
const h = u ? o.parseModule() : o.parseScript();
return a && i && (h.comments = i.comments), o.config.tokens && (h.tokens = o.tokens), o.config.tolerant && (h.errors = o.errorHandler.errors), h;
}
function parseModule(e, t, s) {
const i = t || {};
return i.sourceType = 'module', parse(e, i, s);
}
function parseScript(e, t, s) {
const i = t || {};
return i.sourceType = 'script', parse(e, i, s);
}
function tokenize(e, t, s) {
const i = new Tokenizer(e, t);
const r = [];
try {
for (;;) {
let e = i.getNextToken();
if (!e) break;
s && (e = s(e)), r.push(e);
}
} catch (e) {
i.errorHandler.tolerate(e);
}
return i.errorHandler.tolerant && (r.errors = i.errors()), r;
}
const version = '6.0.3';
// eslint-disable-next-line camelcase
return {
parse,
parseModule,
parseScript,
tokenize,
Syntax,
version
};
})();
/* eslint-enable */
/* eslint-disable no-bitwise */
/* eslint-disable eqeqeq */
/* eslint-disable max-classes-per-file */
/* eslint-disable no-multi-assign */
const ScopeType = {
Global: 'Global',
Function: 'Function',
Block: 'Block'
};
const VariableType = {
Let: 'Let',
Const: 'Const',
Var: 'Var'
};
class Scope {
/** @type {Scope} */
parent;
variables = {};
/** @type {string} */
type;
constructor(type, parent) {
this.type = type;
this.parent = parent;
this.variables = {};
}
declare(type, name, value = undefined) {
this.checkAlreadyDeclared(name, type);
switch (type) {
case VariableType.Let:
this.variables[name] = { type, value };
break;
case VariableType.Const:
this.variables[name] = { type, value };
break;
case VariableType.Var: {
let scope = this;
while (scope) {
if (scope.type === ScopeType.Function || scope.type === ScopeType.Global) {
scope.variables[name] = { type, value };
scope = undefined;
} else {
scope = scope.parent;
}
}
break;
}
default:
throw new SyntaxError(`Unexpected variable declaration type: ${type}`);
}
}
checkAlreadyDeclared(name, type) {
let scope = this;
while (scope) {
if (scope.variables.hasOwnProperty(name)) {
if (type === VariableType.Const || type === VariableType.Let
|| scope.variables[name].type !== VariableType.Var) {
throw new SyntaxError(`Identifier '${name}' has already been declared`);
}
}
if (scope.type === ScopeType.Function || scope.type === ScopeType.Global) {
scope = undefined;
} else {
scope = scope.parent;
}
}
}
setValue(name, value) {
const reference = this.getReference(name, true);
if (!reference) {
throw new ReferenceError(`${name} is not defined.`);
}
if (reference.type === VariableType.Const) {
throw new TypeError(`Assignment to constant variable: ${name}`);
}
return (reference.value = value);
}
getValue(name) {
const reference = this.getReference(name);
return reference?.value;
}
getReference(name) {
let scope = this;
while (scope) {
if (scope.variables.hasOwnProperty(name)) {
return scope.variables[name];
}
if (scope.type === ScopeType.Global) {
scope = undefined;
} else {
scope = scope.parent;
}
}
return undefined;
}
createChildScope(type) {
return new Scope(type, this);
}
}
class FlowStopper {}
class Break extends FlowStopper {}
class Continue extends FlowStopper {}
class Return extends FlowStopper {
value;
constructor(value) {
super();
this.value = value;
}
}
class Debugger {}
class ChainIsNullish {}
// eslint-disable-next-line no-shadow
class Interpreter {
static execute(esTree, globalVariables) {
const scope = new Scope(ScopeType.Global);
// Add global variables
Object.keys(globalVariables).forEach(key => {
scope.declare(VariableType.Let, key, globalVariables[key]);
});
return { output: this.processNode(esTree, scope), variables: scope };
}
static processorMap = {
[esprima.Syntax.Program]: Interpreter.processProgram.bind(Interpreter),
[esprima.Syntax.ExpressionStatement]: (n, s) => Interpreter.processNode(n.expression, s),
[esprima.Syntax.Literal]: Interpreter.processLiteral.bind(Interpreter),
[esprima.Syntax.MemberExpression]: Interpreter.processMemberExpression.bind(Interpreter),
[esprima.Syntax.BinaryExpression]: Interpreter.processBinaryExpression.bind(Interpreter),
[esprima.Syntax.VariableDeclaration]: Interpreter.processVariableDeclaration.bind(Interpreter),
[esprima.Syntax.VariableDeclarator]: Interpreter.processVariableDeclarator.bind(Interpreter),
[esprima.Syntax.CallExpression]: Interpreter.processCallExpression.bind(Interpreter),
[esprima.Syntax.AssignmentExpression]: Interpreter.processAssigmentExpression.bind(Interpreter),
[esprima.Syntax.Identifier]: Interpreter.processIdentifier.bind(Interpreter),
[esprima.Syntax.IfStatement]: Interpreter.processIfStatement.bind(Interpreter),
[esprima.Syntax.BlockStatement]: Interpreter.processBlockStatement.bind(Interpreter),
[esprima.Syntax.EmptyStatement]: () => {}, // do nothing
[esprima.Syntax.TemplateLiteral]: Interpreter.processTemplateLiteral.bind(Interpreter),
[esprima.Syntax.NewExpression]: Interpreter.processNewExpression.bind(Interpreter),
[esprima.Syntax.FunctionDeclaration]: Interpreter.processFunctionDeclaration.bind(Interpreter),
[esprima.Syntax.ReturnStatement]: Interpreter.processReturnStatement.bind(Interpreter),
[esprima.Syntax.LogicalExpression]: Interpreter.processLogicalExpression.bind(Interpreter),
[esprima.Syntax.UnaryExpression]: Interpreter.processUnaryExpression.bind(Interpreter),
[esprima.Syntax.ArrayExpression]: Interpreter.processArrayExpression.bind(Interpreter),
[esprima.Syntax.ConditionalExpression]: Interpreter.processConditionalExpression.bind(Interpreter),
[esprima.Syntax.ObjectExpression]: Interpreter.processObjectExpression.bind(Interpreter),
[esprima.Syntax.FunctionExpression]: Interpreter.processFunctionExpression.bind(Interpreter),
[esprima.Syntax.ArrowFunctionExpression]: Interpreter.processArrowFunctionExpression.bind(Interpreter),
[esprima.Syntax.ChainExpression]: Interpreter.processChainExpression.bind(Interpreter),
[esprima.Syntax.UpdateExpression]: Interpreter.processUpdateExpression.bind(Interpreter),
[esprima.Syntax.ForStatement]: Interpreter.processForStatement.bind(Interpreter),
[esprima.Syntax.TryStatement]: Interpreter.processTryStatement.bind(Interpreter),
[esprima.Syntax.BreakStatement]: Interpreter.processBreakStatement.bind(Interpreter),
[esprima.Syntax.ContinueStatement]: Interpreter.processContinueStatement.bind(Interpreter),
[esprima.Syntax.DebuggerStatement]: Interpreter.processDebuggerStatement.bind(Interpreter),
[esprima.Syntax.SwitchStatement]: Interpreter.processSwitchStatement.bind(Interpreter)
};
static processNode(node, scope) {
const processor = this.processorMap[node.type];
if (!processor) {
throw new SyntaxError(`Unexpected node type: ${node.type}`);
}
return processor(node, scope);
}
static processSwitchStatement(node, scope) {
const discriminant = this.processNode(node.discriminant, scope);
let matchIndex = -1;
let defaultIndex = -1;
for (let i = 0; i < node.cases.length && matchIndex === -1; i++) {
const switchCase = node.cases[i];
if (!switchCase.test) {
defaultIndex = i;
} else if (this.processNode(switchCase.test, scope) === discriminant) {
matchIndex = i;
}
}
if (matchIndex === -1) matchIndex = defaultIndex;
let returnValue;
if (matchIndex > -1) {
const switchScope = scope.createChildScope(ScopeType.Block);
for (let i = matchIndex; i < node.cases.length && !(returnValue instanceof FlowStopper); i++) {
let result;
const switchCase = node.cases[i];
for (let j = 0; j < switchCase.consequent.length && !(result instanceof FlowStopper); j++) {
result = this.processNode(switchCase.consequent[j], switchScope);
if (!(result instanceof Break || result instanceof Continue)) {
returnValue = result;
}
}
}
}
return returnValue;
}
static processDebuggerStatement() {
// eslint-disable-next-line no-debugger
debugger;
return new Debugger();
}
static processTryStatement(node, scope) {
let returnValue;
try {
returnValue = this.processNode(node.block, scope);
} catch (e) {
// Based on research, I think a Function scope is appropriate here but not certain.
const catchScope = scope.createChildScope(ScopeType.Function);
node.handler.param.returnName = true;
catchScope.declare(VariableType.Var, this.processNode(node.handler.param, catchScope), e);
this.processNode(node.handler.body, catchScope);
} finally {
if (node.finalizer) {
this.processNode(node.finalizer, scope);
}
}
return returnValue;
}
static processObjectExpression(node, scope) {
const returnValue = {};
node.properties.forEach(property => {
property.key.returnName = !node.computed;
const key = this.processNode(property.key, scope);
returnValue[key] = this.processNode(property.value, scope);
});
return returnValue;
}
static processConditionalExpression(node, scope) {
const returnValue = this.processNode(node.test, scope) ? this.processNode(node.consequent, scope) : this.processNode(node.alternate, scope);
return returnValue;
}
static processArrayExpression(node, scope) {
const returnValue = node.elements.map(element => this.processNode(element, scope));
return returnValue;
}
static setScopeValue(targetNode, value, scope) {
switch (targetNode.type) {
case esprima.Syntax.MemberExpression: {
const object = this.processNode(targetNode.object, scope);
targetNode.property.returnName = true;
const propertyName = this.processNode(targetNode.property, scope);
object[propertyName] = value;
break;
}
case esprima.Syntax.Identifier:
scope.setValue(targetNode.name, value);
break;
default:
throw new SyntaxError(`Unexpected target node type in setValue(): ${targetNode.type}`);
}
return value;
}
static processUpdateExpression(node, scope) {
const oldValue = this.processNode(node.argument, scope);
let newValue;
switch (node.operator) {
case '++':
newValue = this.setScopeValue(node.argument, oldValue + 1, scope);
break;
case '--':
newValue = this.setScopeValue(node.argument, oldValue - 1, scope);
break;
default:
throw new SyntaxError(`Unexpected update expression operator: ${node.operator}`);
}
return node.prefix ? newValue : oldValue;
}
static processForStatement(node, scope) {
let returnValue;
this.processNode(node.init, scope);
while (this.processNode(node.test, scope)) {
returnValue = this.processNode(node.body, scope);
if (returnValue instanceof FlowStopper) {
if (returnValue instanceof Return) {
returnValue = returnValue.value;
}
break;
}
this.processNode(node.update, scope);
}
return returnValue;
}
static processUnaryExpression(node, scope) {
let returnValue;
switch (node.operator) {
case '!':
returnValue = !this.processNode(node.argument, scope);
break;
case '~':
returnValue = ~this.processNode(node.argument, scope);
break;
case '-':
returnValue = -this.processNode(node.argument, scope);
break;
case 'typeof':
returnValue = typeof this.processNode(node.argument, scope);
break;
default:
throw new SyntaxError(`Unexpected unary expression operator: ${node.operator}`);
}
return returnValue;
}
static processLogicalExpression(node, scope) {
let returnValue;
switch (node.operator) {
case '&&':
returnValue = this.processNode(node.left, scope) && this.processNode(node.right, scope);
break;
case '||':
returnValue = this.processNode(node.left, scope) || this.processNode(node.right, scope);
break;
case '??':
returnValue = this.processNode(node.left, scope) ?? this.processNode(node.right, scope);
break;
default:
throw new SyntaxError(`Unexpected logical expression operator: ${node.operator}`);
}
return returnValue;
}
static processReturnStatement(node, scope) {
const returnValue = node.argument && this.processNode(node.argument, scope);
return new Return(returnValue);
}
static processContinueStatement() {
return new Continue();
}
static processBreakStatement() {
return new Break();
}
/**
*
* @param {*} node
* @param {Scope} scope
* @returns
*/
static processArrowFunctionExpression(node, scope) {
const func = (...args) => {
const esTreeArgs = args.map(arg => {
const argNode = {
type: esprima.Syntax.Literal,
value: arg
};
return argNode;
});
const funcScope = scope.createChildScope(ScopeType.Function);
for (let i = 0; i < Math.min(esTreeArgs.length, node.params.length); i++) {
const param = node.params[i];
param.returnName = true;
funcScope.declare(
VariableType.Var,
this.processNode(param, funcScope),
this.processNode(esTreeArgs[i], funcScope)
);
}
let returnValue = this.processNode(node.body, funcScope);
if (returnValue instanceof Return) {
returnValue = returnValue.value;
}
return returnValue;
};
return func;
}
static processChainExpression(node, scope) {
let returnValue;
switch (node.expression.type) {
case esprima.Syntax.CallExpression:
case esprima.Syntax.MemberExpression: {
returnValue = this.processNode(node.expression, scope);
break;
}
default:
throw new SyntaxError(`Unexpected chain expression type: ${node.expression.type}`);
}
if (returnValue instanceof ChainIsNullish) returnValue = undefined;
return returnValue;
}
static processFunctionDeclaration(node, scope) {
const func = (...args) => {
const esTreeArgs = args.map(arg => {
const argNode = {
type: esprima.Syntax.Literal,
value: arg
};
return argNode;
});
const funcScope = scope.createChildScope(ScopeType.Function);
for (let i = 0; i < Math.min(esTreeArgs.length, node.params.length); i++) {
const param = node.params[i];
param.returnName = true;
funcScope.declare(
VariableType.Var,
this.processNode(param, funcScope),
this.processNode(esTreeArgs[i], funcScope)
);
}
let returnValue = this.processNode(node.body, funcScope);
if (returnValue instanceof Return) {
returnValue = returnValue.value;
}
return returnValue;
};
if (node.id) {
node.id.returnName = true;
const funcName = this.processNode(node.id, scope);
scope.declare(VariableType.Var, funcName, func);
}
return func;
}
static processFunctionExpression(node, scope) {
const func = (...args) => {
const esTreeArgs = args.map(arg => {
const argNode = {
type: esprima.Syntax.Literal,
value: arg
};
return argNode;
});
const funcScope = scope.createChildScope(ScopeType.Function);
for (let i = 0; i < Math.min(esTreeArgs.length, node.params.length); i++) {
const param = node.params[i];
param.returnName = true;
funcScope.declare(
VariableType.Var,
this.processNode(param, funcScope),
this.processNode(esTreeArgs[i], funcScope)
);
}
let returnValue = this.processNode(node.body, funcScope);
if (returnValue instanceof Return) {
returnValue = returnValue.value;
}
return returnValue;
};
return func;
}
static processProgram(node, scope) {
let returnValue;
node.body.forEach(childNode => {
returnValue = this.processNode(childNode, scope);
});
return returnValue;
}
static processNewExpression(node, scope) {
const args = node.arguments.map(argument => this.processNode(argument, scope));
return Reflect.construct(this.processNode(node.callee, scope), args);
}
static processTemplateLiteral(node, scope) {
let returnValue = '';
for (let i = 0; i < node.quasis.length; i++) {
returnValue += node.quasis[i].value.cooked;
if (!node.quasis[i].tail) {
returnValue += this.processNode(node.expressions[i], scope);
}
}
return returnValue;
}
static processBlockStatement(node, scope) {
let returnValue;
// TODO: I don't think we need to ignore the block scope in a function declaration. Test it.
// switch (context.type) {
// case esprima.Syntax.FunctionDeclaration:
// break;
// default:
const blockScope = scope.createChildScope(ScopeType.Block);
// }
for (let i = 0; i < node.body.length; i++) {
const childNode = node.body[i];
const result = this.processNode(childNode, blockScope);
if (result instanceof FlowStopper) {
if (result instanceof Return) {
returnValue = result;
}
break;
} else if (result instanceof Debugger) {
// do nothing
} else {
returnValue = result;
}
}
return returnValue;
}
static processIfStatement(node, scope) {
let returnValue;
const test = this.processNode(node.test, scope);
if (test) {
returnValue = this.processNode(node.consequent, scope);
} else if (node.alternate) {
returnValue = this.processNode(node.alternate, scope);
}
return returnValue;
}
static processLiteral(node) {
return node.value;
}
static processIdentifier(node, scope) {
let returnValue;
if (node.returnName) {
returnValue = node.name;
} else {
returnValue = scope.getValue(node.name);
}
return returnValue;
}
/**
*
* @param {*} expression
* @param {Scope} scope
* @returns
*/
static getMemberExpressionObject(expression, scope) {
let returnValue;
switch (expression.object.type) {
case esprima.Syntax.Identifier: {
returnValue = scope.getValue(expression.object.name);
break;
}
case esprima.Syntax.CallExpression:
case esprima.Syntax.MemberExpression: {
const object = this.processNode(expression.object, scope);
returnValue = object;
break;
}
default:
throw new SyntaxError(`Unexpected member expression object type: ${expression.object.type}`);
}
return returnValue;
}
static processMemberExpression(node, scope) {
let returnValue;
const object = this.getMemberExpressionObject(node, scope);
if (object == null && node.optional) {
returnValue = new ChainIsNullish();
} else if (object != null || (object == null && !node.optional)) {
node.property.returnName = !node.computed;
const propertyName = this.processNode(node.property, scope);
// if (object[propertyName] == null) {
// console.warn(`Object does not contain this property: ${propertyName}`);
// }
returnValue = object[propertyName];
}
return returnValue;
}
static doBinaryExpression(node, func, scope) {
return func(this.processNode(node.left, scope), this.processNode(node.right, scope));
}
static add(left, right) {
return left + right;
}
static subtract(left, right) {
return left - right;
}
static multiply(left, right) {
return left * right;
}
static divide(left, right) {
return left / right;
}
static mod(left, right) {
return left % right;
}
static power(left, right) {
return left ** right;
}
static processBinaryExpression(node, scope) {
let returnValue;
const process = operation => this.doBinaryExpression(node, operation, scope);
switch (node.operator) {
case '+':
returnValue = process(this.add);
break;
case '-':
returnValue = process(this.subtract);
break;
case '*':
returnValue = process(this.multiply);
break;
case '/':
returnValue = process(this.divide);
break;
case '%':
returnValue = process(this.mod);
break;
case '**':
returnValue = process(this.power);
break;
case '>':
returnValue = process((left, right) => left > right);
break;
case '<':
returnValue = process((left, right) => left < right);
break;
case '==':
returnValue = process((left, right) => left == right);
break;
case '===':
returnValue = process((left, right) => left === right);
break;
case '>=':
returnValue = process((left, right) => left >= right);
break;
case '<=':
returnValue = process((left, right) => left <= right);
break;
case '!=':
returnValue = process((left, right) => left != right);
break;
case '!==':
returnValue = process((left, right) => left !== right);
break;
case '^':
returnValue = process(this.bitwiseXOR);
break;
case '|':
returnValue = process(this.bitwiseOR);
break;
case '&':
returnValue = process(this.bitwiseAND);
break;
case '>>':
returnValue = process(this.bitwiseRightShift);
break;
case '<<':
returnValue = process(this.bitwiseLeftShift);
break;
case '>>>':
returnValue = process(this.bitwiseUnsignedRightShift);
break;
default:
throw new SyntaxError(`Unexpected binary expression operator: ${node.operator}`);
}
return returnValue;
}
static processVariableDeclaration(node, scope) {
switch (node.kind) {
case 'let':
case 'const':
case 'var':
node.declarations.forEach(declaration => {
declaration.kind = node.kind;
this.processNode(declaration, scope);
});
break;
default:
throw new SyntaxError(`Unexpected variable declaration kind: ${node.type}`);
}
// I believe declarations always return undefined
}
/**
*
* @param {*} node
* @param {Scope} scope
*/
static processVariableDeclarator(node, scope) {
switch (node.id.type) {
case esprima.Syntax.Identifier: {
node.id.returnName = true;
const name = this.processNode(node.id, scope);
const value = node.init ? this.processNode(node.init, scope) : undefined;
let declarationType;
switch (node.kind) {
case 'let':
declarationType = VariableType.Let;
break;
case 'const':
declarationType = VariableType.Const;
break;
case 'var':
declarationType = VariableType.Var;
break;
default:
throw new TypeError(`Unexpected variable declaration kind: ${node.kind}`);
}
scope.declare(declarationType, name, value);
break;
}
case esprima.Syntax.ObjectPattern: {
const object = this.processNode(node.init, scope);
node.id.properties.forEach(property => {
property.key.returnName = true;
const name = this.processNode(property.key, scope);
property.value.returnName = true;
const valueName = this.processNode(property.value, scope);
const value = object[valueName];
let declarationType;
switch (node.kind) {
case 'let':
declarationType = VariableType.Let;
break;
case 'const':
declarationType = VariableType.Const;
break;
case 'var':
declarationType = VariableType.Var;
break;
default:
throw new TypeError(`Unexpected variable declaration kind: ${node.kind}`);
}
scope.declare(declarationType, name, value);
});
break;
}
default:
throw new SyntaxError(`Unexpected variable declarator id type: ${node.id.type}`);
}
}
/**
*
* @param {*} node
* @param {Scope} scope
* @returns
*/
static processCallExpression(node, scope) {
// TODO: This code doesn't pass the sniff test. Need to work on it.
const { callee } = node;
let methodToCall;
let calleeObject;
let returnValue;
switch (callee.type) {
case esprima.Syntax.MemberExpression: {
calleeObject = this.processNode(callee.object, scope);
if (calleeObject == null) {
if (callee.optional) {
returnValue = new ChainIsNullish();
} else {
throw new SyntaxError('Callee object not found in call expression.');
}
} else if (calleeObject instanceof ChainIsNullish) {
returnValue = new ChainIsNullish();
} else {
methodToCall = calleeObject[callee.property.name];
}
break;
}
case esprima.Syntax.Identifier:
methodToCall = scope.getValue(callee.name);
break;
default:
throw new SyntaxError(`Unexpected callee type in call expression: ${callee.type}`);
}
if (!(returnValue instanceof ChainIsNullish)) {
if (methodToCall == null) {
if (node.optional) {
returnValue = new ChainIsNullish();
} else {
let methodName;
switch (callee.type) {
case esprima.Syntax.Identifier:
methodName = callee.name;
break;
case esprima.Syntax.MemberExpression:
callee.property.returnName = true;
methodName = this.processNode(callee.property);
break;
default:
}
throw new SyntaxError(`Method not found: ${methodName}`);
}
} else {
const args = node.arguments.map(arg => this.processNode(arg, scope));
// if (!methodToCall) debugger;
returnValue = methodToCall.call(calleeObject, ...args);
}
}
return returnValue;
}
static doAssignmentExpression(node, func, scope) {
let returnValue;
let leftValue;
switch (node.left.type) {
case esprima.Syntax.Identifier: {
leftValue = scope.getValue(node.left.name);
returnValue = this.setScopeValue(node.left, func(leftValue, this.processNode(node.right, scope)), scope);
break;
}
case esprima.Syntax.MemberExpression: {
const object = this.getMemberExpressionObject(node.left, scope);
const propertyName = this.processNode(node.left.property, scope);
leftValue = object[propertyName];
returnValue = (object[propertyName] = func(leftValue, this.processNode(node.right, scope)));
break;
}
default:
throw new SyntaxError(`Unexpected type on left side of assignment expression: ${node.left.type}`);
}
return returnValue;
}
static nullishCoalesce(left, right) {
return left ?? right;
}
static or(left, right) {
return left || right;
}
static and(left, right) {
return left && right;
}
static bitwiseAND(left, right) {
return left & right;
}
static bitwiseOR(left, right) {
return left | right;
}
static bitwiseXOR(left, right) {
return left ^ right;
}
static bitwiseLeftShift(left, right) {
return left << right;
}
static bitwiseRightShift(left, right) {
return left >> right;
}
static bitwiseUnsignedRightShift(left, right) {
return left >>> right;
}
static processAssigmentExpression(node, scope) {
let returnValue;
const assign = operation => this.doAssignmentExpression(node, operation, scope);
switch (node.operator) {
case '=':
returnValue = this.setScopeValue(node.left, this.processNode(node.right, scope), scope);
break;
case '+=':
returnValue = assign(this.add);
break;
case '-=':
returnValue = assign(this.subtract);
break;
case '*=':
returnValue = assign(this.multiply);
break;
case '/=':
returnValue = assign(this.divide);
break;
case '%=':
returnValue = assign(this.mod);
break;
case '**=':
returnValue = assign(this.power);
break;
case '??=':
returnValue = assign(this.nullishCoalesce);
break;
case '||=':
returnValue = assign(this.or);
break;
case '&&=':
returnValue = assign(this.and);
break;
case '<<=':
returnValue = assign(this.bitwiseLeftShift);
break;
case '>>=':
returnValue = assign(this.bitwiseRightShift);
break;
case '>>>=':
returnValue = assign(this.bitwiseUnsignedRightShift);
break;
case '&=':
returnValue = assign(this.bitwiseAND);
break;
case '|=':
returnValue = assign(this.bitwiseOR);
break;
case '^=':
returnValue = assign(this.bitwiseXOR);
break;
default:
throw new SyntaxError(`Unexpected assigment expression operator: ${node.operator}`);
}
return returnValue;
}
}
return { compile: esprima.parseScript, execute: Interpreter.execute.bind(Interpreter) };
})();