You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
5908 lines
203 KiB
5908 lines
203 KiB
2 years ago
|
/* MIT License
|
||
|
|
||
|
Copyright (c) 2021-Present Anthony Fu <https://github.com/antfu>
|
||
|
Copyright (c) 2021-Present Matias Capeletto <https://github.com/patak-dev>
|
||
|
|
||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||
|
of this software and associated documentation files (the "Software"), to deal
|
||
|
in the Software without restriction, including without limitation the rights
|
||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||
|
copies of the Software, and to permit persons to whom the Software is
|
||
|
furnished to do so, subject to the following conditions:
|
||
|
|
||
|
The above copyright notice and this permission notice shall be included in all
|
||
|
copies or substantial portions of the Software.
|
||
|
|
||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||
|
SOFTWARE.
|
||
|
*/
|
||
|
import { builtinModules, createRequire } from "module";
|
||
|
import { pathToFileURL, fileURLToPath } from "url";
|
||
|
import vm from "vm";
|
||
|
import path from "path";
|
||
|
import "fs";
|
||
|
import assert from "assert";
|
||
|
import { format as format$1, inspect } from "util";
|
||
|
function normalizeWindowsPath(input = "") {
|
||
|
if (!input.includes("\\")) {
|
||
|
return input;
|
||
|
}
|
||
|
return input.replace(/\\/g, "/");
|
||
|
}
|
||
|
const _UNC_REGEX = /^[/][/]/;
|
||
|
const _UNC_DRIVE_REGEX = /^[/][/]([.]{1,2}[/])?([a-zA-Z]):[/]/;
|
||
|
const _IS_ABSOLUTE_RE = /^\/|^\\|^[a-zA-Z]:[/\\]/;
|
||
|
const sep = "/";
|
||
|
const delimiter = ":";
|
||
|
const normalize = function(path2) {
|
||
|
if (path2.length === 0) {
|
||
|
return ".";
|
||
|
}
|
||
|
path2 = normalizeWindowsPath(path2);
|
||
|
const isUNCPath = path2.match(_UNC_REGEX);
|
||
|
const hasUNCDrive = isUNCPath && path2.match(_UNC_DRIVE_REGEX);
|
||
|
const isPathAbsolute = isAbsolute(path2);
|
||
|
const trailingSeparator = path2[path2.length - 1] === "/";
|
||
|
path2 = normalizeString(path2, !isPathAbsolute);
|
||
|
if (path2.length === 0) {
|
||
|
if (isPathAbsolute) {
|
||
|
return "/";
|
||
|
}
|
||
|
return trailingSeparator ? "./" : ".";
|
||
|
}
|
||
|
if (trailingSeparator) {
|
||
|
path2 += "/";
|
||
|
}
|
||
|
if (isUNCPath) {
|
||
|
if (hasUNCDrive) {
|
||
|
return `//./${path2}`;
|
||
|
}
|
||
|
return `//${path2}`;
|
||
|
}
|
||
|
return isPathAbsolute && !isAbsolute(path2) ? `/${path2}` : path2;
|
||
|
};
|
||
|
const join = function(...args) {
|
||
|
if (args.length === 0) {
|
||
|
return ".";
|
||
|
}
|
||
|
let joined;
|
||
|
for (let i = 0; i < args.length; ++i) {
|
||
|
const arg = args[i];
|
||
|
if (arg.length > 0) {
|
||
|
if (joined === void 0) {
|
||
|
joined = arg;
|
||
|
} else {
|
||
|
joined += `/${arg}`;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if (joined === void 0) {
|
||
|
return ".";
|
||
|
}
|
||
|
return normalize(joined);
|
||
|
};
|
||
|
const resolve = function(...args) {
|
||
|
args = args.map((arg) => normalizeWindowsPath(arg));
|
||
|
let resolvedPath = "";
|
||
|
let resolvedAbsolute = false;
|
||
|
for (let i = args.length - 1; i >= -1 && !resolvedAbsolute; i--) {
|
||
|
const path2 = i >= 0 ? args[i] : process.cwd();
|
||
|
if (path2.length === 0) {
|
||
|
continue;
|
||
|
}
|
||
|
resolvedPath = `${path2}/${resolvedPath}`;
|
||
|
resolvedAbsolute = isAbsolute(path2);
|
||
|
}
|
||
|
resolvedPath = normalizeString(resolvedPath, !resolvedAbsolute);
|
||
|
if (resolvedAbsolute && !isAbsolute(resolvedPath)) {
|
||
|
return `/${resolvedPath}`;
|
||
|
}
|
||
|
return resolvedPath.length > 0 ? resolvedPath : ".";
|
||
|
};
|
||
|
function normalizeString(path2, allowAboveRoot) {
|
||
|
let res = "";
|
||
|
let lastSegmentLength = 0;
|
||
|
let lastSlash = -1;
|
||
|
let dots = 0;
|
||
|
let char = null;
|
||
|
for (let i = 0; i <= path2.length; ++i) {
|
||
|
if (i < path2.length) {
|
||
|
char = path2[i];
|
||
|
} else if (char === "/") {
|
||
|
break;
|
||
|
} else {
|
||
|
char = "/";
|
||
|
}
|
||
|
if (char === "/") {
|
||
|
if (lastSlash === i - 1 || dots === 1)
|
||
|
;
|
||
|
else if (dots === 2) {
|
||
|
if (res.length < 2 || lastSegmentLength !== 2 || res[res.length - 1] !== "." || res[res.length - 2] !== ".") {
|
||
|
if (res.length > 2) {
|
||
|
const lastSlashIndex = res.lastIndexOf("/");
|
||
|
if (lastSlashIndex === -1) {
|
||
|
res = "";
|
||
|
lastSegmentLength = 0;
|
||
|
} else {
|
||
|
res = res.slice(0, lastSlashIndex);
|
||
|
lastSegmentLength = res.length - 1 - res.lastIndexOf("/");
|
||
|
}
|
||
|
lastSlash = i;
|
||
|
dots = 0;
|
||
|
continue;
|
||
|
} else if (res.length !== 0) {
|
||
|
res = "";
|
||
|
lastSegmentLength = 0;
|
||
|
lastSlash = i;
|
||
|
dots = 0;
|
||
|
continue;
|
||
|
}
|
||
|
}
|
||
|
if (allowAboveRoot) {
|
||
|
res += res.length > 0 ? "/.." : "..";
|
||
|
lastSegmentLength = 2;
|
||
|
}
|
||
|
} else {
|
||
|
if (res.length > 0) {
|
||
|
res += `/${path2.slice(lastSlash + 1, i)}`;
|
||
|
} else {
|
||
|
res = path2.slice(lastSlash + 1, i);
|
||
|
}
|
||
|
lastSegmentLength = i - lastSlash - 1;
|
||
|
}
|
||
|
lastSlash = i;
|
||
|
dots = 0;
|
||
|
} else if (char === "." && dots !== -1) {
|
||
|
++dots;
|
||
|
} else {
|
||
|
dots = -1;
|
||
|
}
|
||
|
}
|
||
|
return res;
|
||
|
}
|
||
|
const isAbsolute = function(p) {
|
||
|
return _IS_ABSOLUTE_RE.test(p);
|
||
|
};
|
||
|
const toNamespacedPath = function(p) {
|
||
|
return normalizeWindowsPath(p);
|
||
|
};
|
||
|
const extname = function(p) {
|
||
|
return path.posix.extname(normalizeWindowsPath(p));
|
||
|
};
|
||
|
const relative = function(from, to) {
|
||
|
return path.posix.relative(normalizeWindowsPath(from), normalizeWindowsPath(to));
|
||
|
};
|
||
|
const dirname = function(p) {
|
||
|
return path.posix.dirname(normalizeWindowsPath(p));
|
||
|
};
|
||
|
const format = function(p) {
|
||
|
return normalizeWindowsPath(path.posix.format(p));
|
||
|
};
|
||
|
const basename = function(p, ext) {
|
||
|
return path.posix.basename(normalizeWindowsPath(p), ext);
|
||
|
};
|
||
|
const parse = function(p) {
|
||
|
return path.posix.parse(normalizeWindowsPath(p));
|
||
|
};
|
||
|
const _path = /* @__PURE__ */ Object.freeze({
|
||
|
__proto__: null,
|
||
|
sep,
|
||
|
delimiter,
|
||
|
normalize,
|
||
|
join,
|
||
|
resolve,
|
||
|
normalizeString,
|
||
|
isAbsolute,
|
||
|
toNamespacedPath,
|
||
|
extname,
|
||
|
relative,
|
||
|
dirname,
|
||
|
format,
|
||
|
basename,
|
||
|
parse
|
||
|
});
|
||
|
({
|
||
|
..._path
|
||
|
});
|
||
|
var astralIdentifierCodes = [509, 0, 227, 0, 150, 4, 294, 9, 1368, 2, 2, 1, 6, 3, 41, 2, 5, 0, 166, 1, 574, 3, 9, 9, 370, 1, 154, 10, 50, 3, 123, 2, 54, 14, 32, 10, 3, 1, 11, 3, 46, 10, 8, 0, 46, 9, 7, 2, 37, 13, 2, 9, 6, 1, 45, 0, 13, 2, 49, 13, 9, 3, 2, 11, 83, 11, 7, 0, 161, 11, 6, 9, 7, 3, 56, 1, 2, 6, 3, 1, 3, 2, 10, 0, 11, 1, 3, 6, 4, 4, 193, 17, 10, 9, 5, 0, 82, 19, 13, 9, 214, 6, 3, 8, 28, 1, 83, 16, 16, 9, 82, 12, 9, 9, 84, 14, 5, 9, 243, 14, 166, 9, 71, 5, 2, 1, 3, 3, 2, 0, 2, 1, 13, 9, 120, 6, 3, 6, 4, 0, 29, 9, 41, 6, 2, 3, 9, 0, 10, 10, 47, 15, 406, 7, 2, 7, 17, 9, 57, 21, 2, 13, 123, 5, 4, 0, 2, 1, 2, 6, 2, 0, 9, 9, 49, 4, 2, 1, 2, 4, 9, 9, 330, 3, 19306, 9, 87, 9, 39, 4, 60, 6, 26, 9, 1014, 0, 2, 54, 8, 3, 82, 0, 12, 1, 19628, 1, 4706, 45, 3, 22, 543, 4, 4, 5, 9, 7, 3, 6, 31, 3, 149, 2, 1418, 49, 513, 54, 5, 49, 9, 0, 15, 0, 23, 4, 2, 14, 1361, 6, 2, 16, 3, 6, 2, 1, 2, 4, 262, 6, 10, 9, 357, 0, 62, 13, 1495, 6, 110, 6, 6, 9, 4759, 9, 787719, 239];
|
||
|
var astralIdentifierStartCodes = [0, 11, 2, 25, 2, 18, 2, 1, 2, 14, 3, 13, 35, 122, 70, 52, 268, 28, 4, 48, 48, 31, 14, 29, 6, 37, 11, 29, 3, 35, 5, 7, 2, 4, 43, 157, 19, 35, 5, 35, 5, 39, 9, 51, 13, 10, 2, 14, 2, 6, 2, 1, 2, 10, 2, 14, 2, 6, 2, 1, 68, 310, 10, 21, 11, 7, 25, 5, 2, 41, 2, 8, 70, 5, 3, 0, 2, 43, 2, 1, 4, 0, 3, 22, 11, 22, 10, 30, 66, 18, 2, 1, 11, 21, 11, 25, 71, 55, 7, 1, 65, 0, 16, 3, 2, 2, 2, 28, 43, 28, 4, 28, 36, 7, 2, 27, 28, 53, 11, 21, 11, 18, 14, 17, 111, 72, 56, 50, 14, 50, 14, 35, 349, 41, 7, 1, 79, 28, 11, 0, 9, 21, 43, 17, 47, 20, 28, 22, 13, 52, 58, 1, 3, 0, 14, 44, 33, 24, 27, 35, 30, 0, 3, 0, 9, 34, 4, 0, 13, 47, 15, 3, 22, 0, 2, 0, 36, 17, 2, 24, 85, 6, 2, 0, 2, 3, 2, 14, 2, 9, 8, 46, 39, 7, 3, 1, 3, 21, 2, 6, 2, 1, 2, 4, 4, 0, 19, 0, 13, 4, 159, 52, 19, 3, 21, 2, 31, 47, 21, 1, 2, 0, 185, 46, 42, 3, 37, 47, 21, 0, 60, 42, 14, 0, 72, 26, 38, 6, 186, 43, 117, 63, 32, 7, 3, 0, 3, 7, 2, 1, 2, 23, 16, 0, 2, 0, 95, 7, 3, 38, 17, 0, 2, 0, 29, 0, 11, 39, 8, 0, 22, 0, 12, 45, 20, 0, 19, 72, 264, 8, 2, 36, 18, 0, 50, 29, 113, 6, 2, 1, 2, 37, 22, 0, 26, 5, 2, 1, 2, 31, 15, 0, 328, 18, 190, 0, 80, 921, 103, 110, 18, 195, 2637, 96, 16, 1070, 4050, 582, 8634, 568, 8, 30, 18, 78, 18, 29, 19, 47, 17, 3, 32, 20, 6, 18, 689, 63, 129, 74, 6, 0, 67, 12, 65, 1, 2, 0, 29, 6135, 9, 1237, 43, 8, 8936, 3, 2, 6, 2, 1, 2, 290, 46, 2, 18, 3, 9, 395, 2309, 106, 6, 12, 4, 8, 8, 9, 5991, 84, 2, 70, 2, 1, 3, 0, 3, 1, 3, 3, 2, 11, 2, 0, 2, 6, 2, 64, 2, 3, 3, 7, 2, 6, 2, 27, 2, 3, 2, 4, 2, 0, 4, 6, 2, 339, 3, 24, 2, 24, 2, 30, 2, 24, 2, 30, 2, 24, 2, 30, 2, 24, 2, 30, 2, 24, 2, 7, 1845, 30, 482, 44, 11, 6, 17, 0, 322, 29, 19, 43, 1269, 6, 2, 3, 2, 1, 2, 14, 2, 196, 60, 67, 8, 0, 1205, 3, 2, 26, 2, 1, 2, 0, 3, 0, 2, 9, 2, 3, 2, 0, 2, 0, 7, 0, 5, 0, 2, 0, 2, 0, 2, 2, 2, 1, 2, 0, 3, 0, 2, 0, 2, 0, 2, 0, 2, 0, 2, 1, 2, 0, 3, 3, 2, 6, 2, 3, 2, 3, 2, 0, 2, 9, 2, 16, 6, 2, 2, 4, 2, 16, 4421, 42719, 33, 4152, 8, 221, 3, 5761, 15, 7472, 3104, 541, 1507, 4938];
|
||
|
var nonASCIIidentifierChars = "\u200C\u200D\xB7\u0300-\u036F\u0387\u0483-\u0487\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u0610-\u061A\u064B-\u0669\u0670\u06D6-\u06DC\u06DF-\u06E4\u06E7\u06E8\u06EA-\u06ED\u06F0-\u06F9\u0711\u0730-\u074A\u07A6-\u07B0\u07C0-\u07C9\u07EB-\u07F3\u07FD\u0816-\u0819\u081B-\u0823\u0825-\u0827\u0829-\u082D\u0859-\u085B\u0898-\u089F\u08CA-\u08E1\u08E3-\u0903\u093A-\u093C\u093E-\u094F\u0951-\u0957\u0962\u0963\u0966-\u096F\u0981-\u0983\u09BC\u09BE-\u09C4\u09C7\u09C8\u09CB-\u09CD\u09D7\u09E2\u09E3\u09E6-\u09EF\u09FE\u0A01-\u0A03\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A66-\u0A71\u0A75\u0A81-\u0A83\u0ABC\u0ABE-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AE2\u0AE3\u0AE6-\u0AEF\u0AFA-\u0AFF\u0B01-\u0B03\u0B3C\u0B3E-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B55-\u0B57\u0B62\u0B63\u0B66-\u0B6F\u0B82\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD7\u0BE6-\u0BEF\u0C00-\u0C04\u0C3C\u0C3E-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C62\u0C63\u0C66-\u0C6F\u0C81-\u0C83\u0CBC\u0CBE-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CE2\u0CE3\u0CE6-\u0CEF\u0D00-\u0D03\u0D3B\u0D3C\u0D3E-\u0D44\u0D46-\u0D48\u0D4A-\u0D4D\u0D57\u0D62\u0D63\u0D66-\u0D6F\u0D81-\u0D83\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E31\u0E34-\u0E3A\u0E47-\u0E4E\u0E50-\u0E59\u0EB1\u0EB4-\u0EBC\u0EC8-\u0ECD\u0ED0-\u0ED9\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E\u0F3F\u0F71-\u0F84\u0F86\u0F87\u0F8D-\u0F97\u0F99-\u0FBC\u0FC6\u102B-\u103E\u1040-\u1049\u1056-\u1059\u105E-\u1060\u1062-\u1064\u1067-\u106D\u1071-\u1074\u1082-\u108D\u108F-\u109D\u135D-\u135F\u1369-\u1371\u1712-\u1715\u1732-\u1734\u1752\u1753\u1772\u1773\u17B4-\u17D3\u17DD\u17E0-\u17E9\u180B-\u180D\u180F-\u1819\u18A9\u1920-\u192B\u1930-\u193B\u1946-\u194F\u19D0-\u19DA\u1A17-\u1A1B\u1A55-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AB0-\u1ABD\u1ABF-\u1ACE\u1B00-\u1B04\u1B34-\u1B44\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1B82\u1BA1-\u1BAD\u1BB0-\u1BB9\u1BE6-\u1BF3\u1C24-\u1C37\u1C40-\u1C49\u1C50-\u1C59\u1CD0-\u1CD2\u1CD4-\u1CE8\u1CED\u1CF4\u1CF7-\u1CF9\u1DC0-\u1DFF\u203F\u2040\u2054\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2CEF-\u2CF1\u2D7F\u2DE0-\u2DFF\u302A-\u302F\u3099\u309A\uA620-\uA629\uA66F\uA674-\uA67D\uA69E\uA69F\uA6F0\uA6F1\uA802\uA806\uA80B\uA823-\uA827\uA82C\uA880\uA881\uA8B4-\uA8C5\uA8D0-\uA8D9\uA8E0-\uA8F1\uA8FF-\uA909\uA926-\uA92D\uA947-\uA953\uA980-\uA983\uA9B3-\uA9C0\uA9D0-\uA9D9\uA9E5\uA9F0-\uA9F9\uAA29-\uAA36\uAA43\uAA4C\uAA4D\uAA50-\uAA59\uAA7B-\uAA7D\uAAB0\uAAB2-\uAAB4\uAAB7\uAAB8\uAABE\uAABF\uAAC1\uAAEB-\uAAEF\uAAF5\uAAF6\uABE3-\uABEA\uABEC\uABED\uABF0-\uABF9\uFB1E\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFF10-\uFF19\uFF3F";
|
||
|
var nonASCIIidentifierStartChars = "\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\u0870-\u0887\u0889-\u088E\u08A0-\u08C9\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\u0C5D\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D04-\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-\u1711\u171F-\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-\u1B4C\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-\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-\u31BF\u31F0-\u31FF\u3400-\u4DBF\u4E00-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7CA\uA7D0\uA7D1\uA7D3\uA7D5-\uA7D9\uA7F2-\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-\uAB69\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uF
|
||
|
var reservedWords = {
|
||
|
3: "abstract boolean byte char class double enum export extends final float goto implements import int interface long native package private protected public short static super synchronized throws transient volatile",
|
||
|
5: "class enum extends super const export import",
|
||
|
6: "enum",
|
||
|
strict: "implements interface let package private protected public static yield",
|
||
|
strictBind: "eval arguments"
|
||
|
};
|
||
|
var ecma5AndLessKeywords = "break case catch continue debugger default do else finally for function if return switch throw try var while with null true false instanceof typeof void delete new in this";
|
||
|
var keywords$1 = {
|
||
|
5: ecma5AndLessKeywords,
|
||
|
"5module": ecma5AndLessKeywords + " export import",
|
||
|
6: ecma5AndLessKeywords + " const class extends export import super"
|
||
|
};
|
||
|
var keywordRelationalOperator = /^in(stanceof)?$/;
|
||
|
var nonASCIIidentifierStart = new RegExp("[" + nonASCIIidentifierStartChars + "]");
|
||
|
var nonASCIIidentifier = new RegExp("[" + nonASCIIidentifierStartChars + nonASCIIidentifierChars + "]");
|
||
|
function isInAstralSet(code, set) {
|
||
|
var pos = 65536;
|
||
|
for (var i = 0; i < set.length; i += 2) {
|
||
|
pos += set[i];
|
||
|
if (pos > code) {
|
||
|
return false;
|
||
|
}
|
||
|
pos += set[i + 1];
|
||
|
if (pos >= code) {
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
function isIdentifierStart(code, astral) {
|
||
|
if (code < 65) {
|
||
|
return code === 36;
|
||
|
}
|
||
|
if (code < 91) {
|
||
|
return true;
|
||
|
}
|
||
|
if (code < 97) {
|
||
|
return code === 95;
|
||
|
}
|
||
|
if (code < 123) {
|
||
|
return true;
|
||
|
}
|
||
|
if (code <= 65535) {
|
||
|
return code >= 170 && nonASCIIidentifierStart.test(String.fromCharCode(code));
|
||
|
}
|
||
|
if (astral === false) {
|
||
|
return false;
|
||
|
}
|
||
|
return isInAstralSet(code, astralIdentifierStartCodes);
|
||
|
}
|
||
|
function isIdentifierChar(code, astral) {
|
||
|
if (code < 48) {
|
||
|
return code === 36;
|
||
|
}
|
||
|
if (code < 58) {
|
||
|
return true;
|
||
|
}
|
||
|
if (code < 65) {
|
||
|
return false;
|
||
|
}
|
||
|
if (code < 91) {
|
||
|
return true;
|
||
|
}
|
||
|
if (code < 97) {
|
||
|
return code === 95;
|
||
|
}
|
||
|
if (code < 123) {
|
||
|
return true;
|
||
|
}
|
||
|
if (code <= 65535) {
|
||
|
return code >= 170 && nonASCIIidentifier.test(String.fromCharCode(code));
|
||
|
}
|
||
|
if (astral === false) {
|
||
|
return false;
|
||
|
}
|
||
|
return isInAstralSet(code, astralIdentifierStartCodes) || isInAstralSet(code, astralIdentifierCodes);
|
||
|
}
|
||
|
var TokenType = function TokenType2(label, conf) {
|
||
|
if (conf === void 0)
|
||
|
conf = {};
|
||
|
this.label = label;
|
||
|
this.keyword = conf.keyword;
|
||
|
this.beforeExpr = !!conf.beforeExpr;
|
||
|
this.startsExpr = !!conf.startsExpr;
|
||
|
this.isLoop = !!conf.isLoop;
|
||
|
this.isAssign = !!conf.isAssign;
|
||
|
this.prefix = !!conf.prefix;
|
||
|
this.postfix = !!conf.postfix;
|
||
|
this.binop = conf.binop || null;
|
||
|
this.updateContext = null;
|
||
|
};
|
||
|
function binop(name, prec) {
|
||
|
return new TokenType(name, { beforeExpr: true, binop: prec });
|
||
|
}
|
||
|
var beforeExpr = { beforeExpr: true }, startsExpr = { startsExpr: true };
|
||
|
var keywords = {};
|
||
|
function kw(name, options) {
|
||
|
if (options === void 0)
|
||
|
options = {};
|
||
|
options.keyword = name;
|
||
|
return keywords[name] = new TokenType(name, options);
|
||
|
}
|
||
|
var types$1 = {
|
||
|
num: new TokenType("num", startsExpr),
|
||
|
regexp: new TokenType("regexp", startsExpr),
|
||
|
string: new TokenType("string", startsExpr),
|
||
|
name: new TokenType("name", startsExpr),
|
||
|
privateId: new TokenType("privateId", startsExpr),
|
||
|
eof: new TokenType("eof"),
|
||
|
bracketL: new TokenType("[", { beforeExpr: true, startsExpr: true }),
|
||
|
bracketR: new TokenType("]"),
|
||
|
braceL: new TokenType("{", { beforeExpr: true, startsExpr: true }),
|
||
|
braceR: new TokenType("}"),
|
||
|
parenL: new TokenType("(", { beforeExpr: true, startsExpr: true }),
|
||
|
parenR: new TokenType(")"),
|
||
|
comma: new TokenType(",", beforeExpr),
|
||
|
semi: new TokenType(";", beforeExpr),
|
||
|
colon: new TokenType(":", beforeExpr),
|
||
|
dot: new TokenType("."),
|
||
|
question: new TokenType("?", beforeExpr),
|
||
|
questionDot: new TokenType("?."),
|
||
|
arrow: new TokenType("=>", beforeExpr),
|
||
|
template: new TokenType("template"),
|
||
|
invalidTemplate: new TokenType("invalidTemplate"),
|
||
|
ellipsis: new TokenType("...", beforeExpr),
|
||
|
backQuote: new TokenType("`", startsExpr),
|
||
|
dollarBraceL: new TokenType("${", { beforeExpr: true, startsExpr: true }),
|
||
|
eq: new TokenType("=", { beforeExpr: true, isAssign: true }),
|
||
|
assign: new TokenType("_=", { beforeExpr: true, isAssign: true }),
|
||
|
incDec: new TokenType("++/--", { prefix: true, postfix: true, startsExpr: true }),
|
||
|
prefix: new TokenType("!/~", { beforeExpr: true, prefix: true, startsExpr: true }),
|
||
|
logicalOR: binop("||", 1),
|
||
|
logicalAND: binop("&&", 2),
|
||
|
bitwiseOR: binop("|", 3),
|
||
|
bitwiseXOR: binop("^", 4),
|
||
|
bitwiseAND: binop("&", 5),
|
||
|
equality: binop("==/!=/===/!==", 6),
|
||
|
relational: binop("</>/<=/>=", 7),
|
||
|
bitShift: binop("<</>>/>>>", 8),
|
||
|
plusMin: new TokenType("+/-", { beforeExpr: true, binop: 9, prefix: true, startsExpr: true }),
|
||
|
modulo: binop("%", 10),
|
||
|
star: binop("*", 10),
|
||
|
slash: binop("/", 10),
|
||
|
starstar: new TokenType("**", { beforeExpr: true }),
|
||
|
coalesce: binop("??", 1),
|
||
|
_break: kw("break"),
|
||
|
_case: kw("case", beforeExpr),
|
||
|
_catch: kw("catch"),
|
||
|
_continue: kw("continue"),
|
||
|
_debugger: kw("debugger"),
|
||
|
_default: kw("default", beforeExpr),
|
||
|
_do: kw("do", { isLoop: true, beforeExpr: true }),
|
||
|
_else: kw("else", beforeExpr),
|
||
|
_finally: kw("finally"),
|
||
|
_for: kw("for", { isLoop: true }),
|
||
|
_function: kw("function", startsExpr),
|
||
|
_if: kw("if"),
|
||
|
_return: kw("return", beforeExpr),
|
||
|
_switch: kw("switch"),
|
||
|
_throw: kw("throw", beforeExpr),
|
||
|
_try: kw("try"),
|
||
|
_var: kw("var"),
|
||
|
_const: kw("const"),
|
||
|
_while: kw("while", { isLoop: true }),
|
||
|
_with: kw("with"),
|
||
|
_new: kw("new", { beforeExpr: true, startsExpr: true }),
|
||
|
_this: kw("this", startsExpr),
|
||
|
_super: kw("super", startsExpr),
|
||
|
_class: kw("class", startsExpr),
|
||
|
_extends: kw("extends", beforeExpr),
|
||
|
_export: kw("export"),
|
||
|
_import: kw("import", startsExpr),
|
||
|
_null: kw("null", startsExpr),
|
||
|
_true: kw("true", startsExpr),
|
||
|
_false: kw("false", startsExpr),
|
||
|
_in: kw("in", { beforeExpr: true, binop: 7 }),
|
||
|
_instanceof: kw("instanceof", { beforeExpr: true, binop: 7 }),
|
||
|
_typeof: kw("typeof", { beforeExpr: true, prefix: true, startsExpr: true }),
|
||
|
_void: kw("void", { beforeExpr: true, prefix: true, startsExpr: true }),
|
||
|
_delete: kw("delete", { beforeExpr: true, prefix: true, startsExpr: true })
|
||
|
};
|
||
|
var lineBreak = /\r\n?|\n|\u2028|\u2029/;
|
||
|
var lineBreakG = new RegExp(lineBreak.source, "g");
|
||
|
function isNewLine(code) {
|
||
|
return code === 10 || code === 13 || code === 8232 || code === 8233;
|
||
|
}
|
||
|
function nextLineBreak(code, from, end) {
|
||
|
if (end === void 0)
|
||
|
end = code.length;
|
||
|
for (var i = from; i < end; i++) {
|
||
|
var next = code.charCodeAt(i);
|
||
|
if (isNewLine(next)) {
|
||
|
return i < end - 1 && next === 13 && code.charCodeAt(i + 1) === 10 ? i + 2 : i + 1;
|
||
|
}
|
||
|
}
|
||
|
return -1;
|
||
|
}
|
||
|
var nonASCIIwhitespace = /[\u1680\u2000-\u200a\u202f\u205f\u3000\ufeff]/;
|
||
|
var skipWhiteSpace = /(?:\s|\/\/.*|\/\*[^]*?\*\/)*/g;
|
||
|
var ref = Object.prototype;
|
||
|
var hasOwnProperty = ref.hasOwnProperty;
|
||
|
var toString = ref.toString;
|
||
|
var hasOwn = Object.hasOwn || function(obj, propName) {
|
||
|
return hasOwnProperty.call(obj, propName);
|
||
|
};
|
||
|
var isArray = Array.isArray || function(obj) {
|
||
|
return toString.call(obj) === "[object Array]";
|
||
|
};
|
||
|
function wordsRegexp(words) {
|
||
|
return new RegExp("^(?:" + words.replace(/ /g, "|") + ")$");
|
||
|
}
|
||
|
function codePointToString(code) {
|
||
|
if (code <= 65535) {
|
||
|
return String.fromCharCode(code);
|
||
|
}
|
||
|
code -= 65536;
|
||
|
return String.fromCharCode((code >> 10) + 55296, (code & 1023) + 56320);
|
||
|
}
|
||
|
var loneSurrogate = /(?:[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])/;
|
||
|
var Position = function Position2(line, col) {
|
||
|
this.line = line;
|
||
|
this.column = col;
|
||
|
};
|
||
|
Position.prototype.offset = function offset(n) {
|
||
|
return new Position(this.line, this.column + n);
|
||
|
};
|
||
|
var SourceLocation = function SourceLocation2(p, start, end) {
|
||
|
this.start = start;
|
||
|
this.end = end;
|
||
|
if (p.sourceFile !== null) {
|
||
|
this.source = p.sourceFile;
|
||
|
}
|
||
|
};
|
||
|
function getLineInfo(input, offset2) {
|
||
|
for (var line = 1, cur = 0; ; ) {
|
||
|
var nextBreak = nextLineBreak(input, cur, offset2);
|
||
|
if (nextBreak < 0) {
|
||
|
return new Position(line, offset2 - cur);
|
||
|
}
|
||
|
++line;
|
||
|
cur = nextBreak;
|
||
|
}
|
||
|
}
|
||
|
var defaultOptions = {
|
||
|
ecmaVersion: null,
|
||
|
sourceType: "script",
|
||
|
onInsertedSemicolon: null,
|
||
|
onTrailingComma: null,
|
||
|
allowReserved: null,
|
||
|
allowReturnOutsideFunction: false,
|
||
|
allowImportExportEverywhere: false,
|
||
|
allowAwaitOutsideFunction: null,
|
||
|
allowSuperOutsideMethod: null,
|
||
|
allowHashBang: false,
|
||
|
locations: false,
|
||
|
onToken: null,
|
||
|
onComment: null,
|
||
|
ranges: false,
|
||
|
program: null,
|
||
|
sourceFile: null,
|
||
|
directSourceFile: null,
|
||
|
preserveParens: false
|
||
|
};
|
||
|
var warnedAboutEcmaVersion = false;
|
||
|
function getOptions(opts) {
|
||
|
var options = {};
|
||
|
for (var opt in defaultOptions) {
|
||
|
options[opt] = opts && hasOwn(opts, opt) ? opts[opt] : defaultOptions[opt];
|
||
|
}
|
||
|
if (options.ecmaVersion === "latest") {
|
||
|
options.ecmaVersion = 1e8;
|
||
|
} else if (options.ecmaVersion == null) {
|
||
|
if (!warnedAboutEcmaVersion && typeof console === "object" && console.warn) {
|
||
|
warnedAboutEcmaVersion = true;
|
||
|
console.warn("Since Acorn 8.0.0, options.ecmaVersion is required.\nDefaulting to 2020, but this will stop working in the future.");
|
||
|
}
|
||
|
options.ecmaVersion = 11;
|
||
|
} else if (options.ecmaVersion >= 2015) {
|
||
|
options.ecmaVersion -= 2009;
|
||
|
}
|
||
|
if (options.allowReserved == null) {
|
||
|
options.allowReserved = options.ecmaVersion < 5;
|
||
|
}
|
||
|
if (opts.allowHashBang == null) {
|
||
|
options.allowHashBang = options.ecmaVersion >= 14;
|
||
|
}
|
||
|
if (isArray(options.onToken)) {
|
||
|
var tokens = options.onToken;
|
||
|
options.onToken = function(token) {
|
||
|
return tokens.push(token);
|
||
|
};
|
||
|
}
|
||
|
if (isArray(options.onComment)) {
|
||
|
options.onComment = pushComment(options, options.onComment);
|
||
|
}
|
||
|
return options;
|
||
|
}
|
||
|
function pushComment(options, array) {
|
||
|
return function(block, text, start, end, startLoc, endLoc) {
|
||
|
var comment = {
|
||
|
type: block ? "Block" : "Line",
|
||
|
value: text,
|
||
|
start,
|
||
|
end
|
||
|
};
|
||
|
if (options.locations) {
|
||
|
comment.loc = new SourceLocation(this, startLoc, endLoc);
|
||
|
}
|
||
|
if (options.ranges) {
|
||
|
comment.range = [start, end];
|
||
|
}
|
||
|
array.push(comment);
|
||
|
};
|
||
|
}
|
||
|
var SCOPE_TOP = 1, SCOPE_FUNCTION = 2, SCOPE_ASYNC = 4, SCOPE_GENERATOR = 8, SCOPE_ARROW = 16, SCOPE_SIMPLE_CATCH = 32, SCOPE_SUPER = 64, SCOPE_DIRECT_SUPER = 128, SCOPE_CLASS_STATIC_BLOCK = 256, SCOPE_VAR = SCOPE_TOP | SCOPE_FUNCTION | SCOPE_CLASS_STATIC_BLOCK;
|
||
|
function functionFlags(async, generator) {
|
||
|
return SCOPE_FUNCTION | (async ? SCOPE_ASYNC : 0) | (generator ? SCOPE_GENERATOR : 0);
|
||
|
}
|
||
|
var BIND_NONE = 0, BIND_VAR = 1, BIND_LEXICAL = 2, BIND_FUNCTION = 3, BIND_SIMPLE_CATCH = 4, BIND_OUTSIDE = 5;
|
||
|
var Parser = function Parser2(options, input, startPos) {
|
||
|
this.options = options = getOptions(options);
|
||
|
this.sourceFile = options.sourceFile;
|
||
|
this.keywords = wordsRegexp(keywords$1[options.ecmaVersion >= 6 ? 6 : options.sourceType === "module" ? "5module" : 5]);
|
||
|
var reserved = "";
|
||
|
if (options.allowReserved !== true) {
|
||
|
reserved = reservedWords[options.ecmaVersion >= 6 ? 6 : options.ecmaVersion === 5 ? 5 : 3];
|
||
|
if (options.sourceType === "module") {
|
||
|
reserved += " await";
|
||
|
}
|
||
|
}
|
||
|
this.reservedWords = wordsRegexp(reserved);
|
||
|
var reservedStrict = (reserved ? reserved + " " : "") + reservedWords.strict;
|
||
|
this.reservedWordsStrict = wordsRegexp(reservedStrict);
|
||
|
this.reservedWordsStrictBind = wordsRegexp(reservedStrict + " " + reservedWords.strictBind);
|
||
|
this.input = String(input);
|
||
|
this.containsEsc = false;
|
||
|
if (startPos) {
|
||
|
this.pos = startPos;
|
||
|
this.lineStart = this.input.lastIndexOf("\n", startPos - 1) + 1;
|
||
|
this.curLine = this.input.slice(0, this.lineStart).split(lineBreak).length;
|
||
|
} else {
|
||
|
this.pos = this.lineStart = 0;
|
||
|
this.curLine = 1;
|
||
|
}
|
||
|
this.type = types$1.eof;
|
||
|
this.value = null;
|
||
|
this.start = this.end = this.pos;
|
||
|
this.startLoc = this.endLoc = this.curPosition();
|
||
|
this.lastTokEndLoc = this.lastTokStartLoc = null;
|
||
|
this.lastTokStart = this.lastTokEnd = this.pos;
|
||
|
this.context = this.initialContext();
|
||
|
this.exprAllowed = true;
|
||
|
this.inModule = options.sourceType === "module";
|
||
|
this.strict = this.inModule || this.strictDirective(this.pos);
|
||
|
this.potentialArrowAt = -1;
|
||
|
this.potentialArrowInForAwait = false;
|
||
|
this.yieldPos = this.awaitPos = this.awaitIdentPos = 0;
|
||
|
this.labels = [];
|
||
|
this.undefinedExports = /* @__PURE__ */ Object.create(null);
|
||
|
if (this.pos === 0 && options.allowHashBang && this.input.slice(0, 2) === "#!") {
|
||
|
this.skipLineComment(2);
|
||
|
}
|
||
|
this.scopeStack = [];
|
||
|
this.enterScope(SCOPE_TOP);
|
||
|
this.regexpState = null;
|
||
|
this.privateNameStack = [];
|
||
|
};
|
||
|
var prototypeAccessors = { inFunction: { configurable: true }, inGenerator: { configurable: true }, inAsync: { configurable: true }, canAwait: { configurable: true }, allowSuper: { configurable: true }, allowDirectSuper: { configurable: true }, treatFunctionsAsVar: { configurable: true }, allowNewDotTarget: { configurable: true }, inClassStaticBlock: { configurable: true } };
|
||
|
Parser.prototype.parse = function parse2() {
|
||
|
var node = this.options.program || this.startNode();
|
||
|
this.nextToken();
|
||
|
return this.parseTopLevel(node);
|
||
|
};
|
||
|
prototypeAccessors.inFunction.get = function() {
|
||
|
return (this.currentVarScope().flags & SCOPE_FUNCTION) > 0;
|
||
|
};
|
||
|
prototypeAccessors.inGenerator.get = function() {
|
||
|
return (this.currentVarScope().flags & SCOPE_GENERATOR) > 0 && !this.currentVarScope().inClassFieldInit;
|
||
|
};
|
||
|
prototypeAccessors.inAsync.get = function() {
|
||
|
return (this.currentVarScope().flags & SCOPE_ASYNC) > 0 && !this.currentVarScope().inClassFieldInit;
|
||
|
};
|
||
|
prototypeAccessors.canAwait.get = function() {
|
||
|
for (var i = this.scopeStack.length - 1; i >= 0; i--) {
|
||
|
var scope = this.scopeStack[i];
|
||
|
if (scope.inClassFieldInit || scope.flags & SCOPE_CLASS_STATIC_BLOCK) {
|
||
|
return false;
|
||
|
}
|
||
|
if (scope.flags & SCOPE_FUNCTION) {
|
||
|
return (scope.flags & SCOPE_ASYNC) > 0;
|
||
|
}
|
||
|
}
|
||
|
return this.inModule && this.options.ecmaVersion >= 13 || this.options.allowAwaitOutsideFunction;
|
||
|
};
|
||
|
prototypeAccessors.allowSuper.get = function() {
|
||
|
var ref2 = this.currentThisScope();
|
||
|
var flags = ref2.flags;
|
||
|
var inClassFieldInit = ref2.inClassFieldInit;
|
||
|
return (flags & SCOPE_SUPER) > 0 || inClassFieldInit || this.options.allowSuperOutsideMethod;
|
||
|
};
|
||
|
prototypeAccessors.allowDirectSuper.get = function() {
|
||
|
return (this.currentThisScope().flags & SCOPE_DIRECT_SUPER) > 0;
|
||
|
};
|
||
|
prototypeAccessors.treatFunctionsAsVar.get = function() {
|
||
|
return this.treatFunctionsAsVarInScope(this.currentScope());
|
||
|
};
|
||
|
prototypeAccessors.allowNewDotTarget.get = function() {
|
||
|
var ref2 = this.currentThisScope();
|
||
|
var flags = ref2.flags;
|
||
|
var inClassFieldInit = ref2.inClassFieldInit;
|
||
|
return (flags & (SCOPE_FUNCTION | SCOPE_CLASS_STATIC_BLOCK)) > 0 || inClassFieldInit;
|
||
|
};
|
||
|
prototypeAccessors.inClassStaticBlock.get = function() {
|
||
|
return (this.currentVarScope().flags & SCOPE_CLASS_STATIC_BLOCK) > 0;
|
||
|
};
|
||
|
Parser.extend = function extend() {
|
||
|
var plugins = [], len = arguments.length;
|
||
|
while (len--)
|
||
|
plugins[len] = arguments[len];
|
||
|
var cls = this;
|
||
|
for (var i = 0; i < plugins.length; i++) {
|
||
|
cls = plugins[i](cls);
|
||
|
}
|
||
|
return cls;
|
||
|
};
|
||
|
Parser.parse = function parse3(input, options) {
|
||
|
return new this(options, input).parse();
|
||
|
};
|
||
|
Parser.parseExpressionAt = function parseExpressionAt(input, pos, options) {
|
||
|
var parser = new this(options, input, pos);
|
||
|
parser.nextToken();
|
||
|
return parser.parseExpression();
|
||
|
};
|
||
|
Parser.tokenizer = function tokenizer(input, options) {
|
||
|
return new this(options, input);
|
||
|
};
|
||
|
Object.defineProperties(Parser.prototype, prototypeAccessors);
|
||
|
var pp$9 = Parser.prototype;
|
||
|
var literal = /^(?:'((?:\\.|[^'\\])*?)'|"((?:\\.|[^"\\])*?)")/;
|
||
|
pp$9.strictDirective = function(start) {
|
||
|
if (this.options.ecmaVersion < 5) {
|
||
|
return false;
|
||
|
}
|
||
|
for (; ; ) {
|
||
|
skipWhiteSpace.lastIndex = start;
|
||
|
start += skipWhiteSpace.exec(this.input)[0].length;
|
||
|
var match = literal.exec(this.input.slice(start));
|
||
|
if (!match) {
|
||
|
return false;
|
||
|
}
|
||
|
if ((match[1] || match[2]) === "use strict") {
|
||
|
skipWhiteSpace.lastIndex = start + match[0].length;
|
||
|
var spaceAfter = skipWhiteSpace.exec(this.input), end = spaceAfter.index + spaceAfter[0].length;
|
||
|
var next = this.input.charAt(end);
|
||
|
return next === ";" || next === "}" || lineBreak.test(spaceAfter[0]) && !(/[(`.[+\-/*%<>=,?^&]/.test(next) || next === "!" && this.input.charAt(end + 1) === "=");
|
||
|
}
|
||
|
start += match[0].length;
|
||
|
skipWhiteSpace.lastIndex = start;
|
||
|
start += skipWhiteSpace.exec(this.input)[0].length;
|
||
|
if (this.input[start] === ";") {
|
||
|
start++;
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
pp$9.eat = function(type) {
|
||
|
if (this.type === type) {
|
||
|
this.next();
|
||
|
return true;
|
||
|
} else {
|
||
|
return false;
|
||
|
}
|
||
|
};
|
||
|
pp$9.isContextual = function(name) {
|
||
|
return this.type === types$1.name && this.value === name && !this.containsEsc;
|
||
|
};
|
||
|
pp$9.eatContextual = function(name) {
|
||
|
if (!this.isContextual(name)) {
|
||
|
return false;
|
||
|
}
|
||
|
this.next();
|
||
|
return true;
|
||
|
};
|
||
|
pp$9.expectContextual = function(name) {
|
||
|
if (!this.eatContextual(name)) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
};
|
||
|
pp$9.canInsertSemicolon = function() {
|
||
|
return this.type === types$1.eof || this.type === types$1.braceR || lineBreak.test(this.input.slice(this.lastTokEnd, this.start));
|
||
|
};
|
||
|
pp$9.insertSemicolon = function() {
|
||
|
if (this.canInsertSemicolon()) {
|
||
|
if (this.options.onInsertedSemicolon) {
|
||
|
this.options.onInsertedSemicolon(this.lastTokEnd, this.lastTokEndLoc);
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
};
|
||
|
pp$9.semicolon = function() {
|
||
|
if (!this.eat(types$1.semi) && !this.insertSemicolon()) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
};
|
||
|
pp$9.afterTrailingComma = function(tokType, notNext) {
|
||
|
if (this.type === tokType) {
|
||
|
if (this.options.onTrailingComma) {
|
||
|
this.options.onTrailingComma(this.lastTokStart, this.lastTokStartLoc);
|
||
|
}
|
||
|
if (!notNext) {
|
||
|
this.next();
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
};
|
||
|
pp$9.expect = function(type) {
|
||
|
this.eat(type) || this.unexpected();
|
||
|
};
|
||
|
pp$9.unexpected = function(pos) {
|
||
|
this.raise(pos != null ? pos : this.start, "Unexpected token");
|
||
|
};
|
||
|
var DestructuringErrors = function DestructuringErrors2() {
|
||
|
this.shorthandAssign = this.trailingComma = this.parenthesizedAssign = this.parenthesizedBind = this.doubleProto = -1;
|
||
|
};
|
||
|
pp$9.checkPatternErrors = function(refDestructuringErrors, isAssign) {
|
||
|
if (!refDestructuringErrors) {
|
||
|
return;
|
||
|
}
|
||
|
if (refDestructuringErrors.trailingComma > -1) {
|
||
|
this.raiseRecoverable(refDestructuringErrors.trailingComma, "Comma is not permitted after the rest element");
|
||
|
}
|
||
|
var parens = isAssign ? refDestructuringErrors.parenthesizedAssign : refDestructuringErrors.parenthesizedBind;
|
||
|
if (parens > -1) {
|
||
|
this.raiseRecoverable(parens, isAssign ? "Assigning to rvalue" : "Parenthesized pattern");
|
||
|
}
|
||
|
};
|
||
|
pp$9.checkExpressionErrors = function(refDestructuringErrors, andThrow) {
|
||
|
if (!refDestructuringErrors) {
|
||
|
return false;
|
||
|
}
|
||
|
var shorthandAssign = refDestructuringErrors.shorthandAssign;
|
||
|
var doubleProto = refDestructuringErrors.doubleProto;
|
||
|
if (!andThrow) {
|
||
|
return shorthandAssign >= 0 || doubleProto >= 0;
|
||
|
}
|
||
|
if (shorthandAssign >= 0) {
|
||
|
this.raise(shorthandAssign, "Shorthand property assignments are valid only in destructuring patterns");
|
||
|
}
|
||
|
if (doubleProto >= 0) {
|
||
|
this.raiseRecoverable(doubleProto, "Redefinition of __proto__ property");
|
||
|
}
|
||
|
};
|
||
|
pp$9.checkYieldAwaitInDefaultParams = function() {
|
||
|
if (this.yieldPos && (!this.awaitPos || this.yieldPos < this.awaitPos)) {
|
||
|
this.raise(this.yieldPos, "Yield expression cannot be a default value");
|
||
|
}
|
||
|
if (this.awaitPos) {
|
||
|
this.raise(this.awaitPos, "Await expression cannot be a default value");
|
||
|
}
|
||
|
};
|
||
|
pp$9.isSimpleAssignTarget = function(expr) {
|
||
|
if (expr.type === "ParenthesizedExpression") {
|
||
|
return this.isSimpleAssignTarget(expr.expression);
|
||
|
}
|
||
|
return expr.type === "Identifier" || expr.type === "MemberExpression";
|
||
|
};
|
||
|
var pp$8 = Parser.prototype;
|
||
|
pp$8.parseTopLevel = function(node) {
|
||
|
var exports = /* @__PURE__ */ Object.create(null);
|
||
|
if (!node.body) {
|
||
|
node.body = [];
|
||
|
}
|
||
|
while (this.type !== types$1.eof) {
|
||
|
var stmt = this.parseStatement(null, true, exports);
|
||
|
node.body.push(stmt);
|
||
|
}
|
||
|
if (this.inModule) {
|
||
|
for (var i = 0, list = Object.keys(this.undefinedExports); i < list.length; i += 1) {
|
||
|
var name = list[i];
|
||
|
this.raiseRecoverable(this.undefinedExports[name].start, "Export '" + name + "' is not defined");
|
||
|
}
|
||
|
}
|
||
|
this.adaptDirectivePrologue(node.body);
|
||
|
this.next();
|
||
|
node.sourceType = this.options.sourceType;
|
||
|
return this.finishNode(node, "Program");
|
||
|
};
|
||
|
var loopLabel = { kind: "loop" }, switchLabel = { kind: "switch" };
|
||
|
pp$8.isLet = function(context) {
|
||
|
if (this.options.ecmaVersion < 6 || !this.isContextual("let")) {
|
||
|
return false;
|
||
|
}
|
||
|
skipWhiteSpace.lastIndex = this.pos;
|
||
|
var skip = skipWhiteSpace.exec(this.input);
|
||
|
var next = this.pos + skip[0].length, nextCh = this.input.charCodeAt(next);
|
||
|
if (nextCh === 91 || nextCh === 92 || nextCh > 55295 && nextCh < 56320) {
|
||
|
return true;
|
||
|
}
|
||
|
if (context) {
|
||
|
return false;
|
||
|
}
|
||
|
if (nextCh === 123) {
|
||
|
return true;
|
||
|
}
|
||
|
if (isIdentifierStart(nextCh, true)) {
|
||
|
var pos = next + 1;
|
||
|
while (isIdentifierChar(nextCh = this.input.charCodeAt(pos), true)) {
|
||
|
++pos;
|
||
|
}
|
||
|
if (nextCh === 92 || nextCh > 55295 && nextCh < 56320) {
|
||
|
return true;
|
||
|
}
|
||
|
var ident = this.input.slice(next, pos);
|
||
|
if (!keywordRelationalOperator.test(ident)) {
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$8.isAsyncFunction = function() {
|
||
|
if (this.options.ecmaVersion < 8 || !this.isContextual("async")) {
|
||
|
return false;
|
||
|
}
|
||
|
skipWhiteSpace.lastIndex = this.pos;
|
||
|
var skip = skipWhiteSpace.exec(this.input);
|
||
|
var next = this.pos + skip[0].length, after;
|
||
|
return !lineBreak.test(this.input.slice(this.pos, next)) && this.input.slice(next, next + 8) === "function" && (next + 8 === this.input.length || !(isIdentifierChar(after = this.input.charCodeAt(next + 8)) || after > 55295 && after < 56320));
|
||
|
};
|
||
|
pp$8.parseStatement = function(context, topLevel, exports) {
|
||
|
var starttype = this.type, node = this.startNode(), kind;
|
||
|
if (this.isLet(context)) {
|
||
|
starttype = types$1._var;
|
||
|
kind = "let";
|
||
|
}
|
||
|
switch (starttype) {
|
||
|
case types$1._break:
|
||
|
case types$1._continue:
|
||
|
return this.parseBreakContinueStatement(node, starttype.keyword);
|
||
|
case types$1._debugger:
|
||
|
return this.parseDebuggerStatement(node);
|
||
|
case types$1._do:
|
||
|
return this.parseDoStatement(node);
|
||
|
case types$1._for:
|
||
|
return this.parseForStatement(node);
|
||
|
case types$1._function:
|
||
|
if (context && (this.strict || context !== "if" && context !== "label") && this.options.ecmaVersion >= 6) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
return this.parseFunctionStatement(node, false, !context);
|
||
|
case types$1._class:
|
||
|
if (context) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
return this.parseClass(node, true);
|
||
|
case types$1._if:
|
||
|
return this.parseIfStatement(node);
|
||
|
case types$1._return:
|
||
|
return this.parseReturnStatement(node);
|
||
|
case types$1._switch:
|
||
|
return this.parseSwitchStatement(node);
|
||
|
case types$1._throw:
|
||
|
return this.parseThrowStatement(node);
|
||
|
case types$1._try:
|
||
|
return this.parseTryStatement(node);
|
||
|
case types$1._const:
|
||
|
case types$1._var:
|
||
|
kind = kind || this.value;
|
||
|
if (context && kind !== "var") {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
return this.parseVarStatement(node, kind);
|
||
|
case types$1._while:
|
||
|
return this.parseWhileStatement(node);
|
||
|
case types$1._with:
|
||
|
return this.parseWithStatement(node);
|
||
|
case types$1.braceL:
|
||
|
return this.parseBlock(true, node);
|
||
|
case types$1.semi:
|
||
|
return this.parseEmptyStatement(node);
|
||
|
case types$1._export:
|
||
|
case types$1._import:
|
||
|
if (this.options.ecmaVersion > 10 && starttype === types$1._import) {
|
||
|
skipWhiteSpace.lastIndex = this.pos;
|
||
|
var skip = skipWhiteSpace.exec(this.input);
|
||
|
var next = this.pos + skip[0].length, nextCh = this.input.charCodeAt(next);
|
||
|
if (nextCh === 40 || nextCh === 46) {
|
||
|
return this.parseExpressionStatement(node, this.parseExpression());
|
||
|
}
|
||
|
}
|
||
|
if (!this.options.allowImportExportEverywhere) {
|
||
|
if (!topLevel) {
|
||
|
this.raise(this.start, "'import' and 'export' may only appear at the top level");
|
||
|
}
|
||
|
if (!this.inModule) {
|
||
|
this.raise(this.start, "'import' and 'export' may appear only with 'sourceType: module'");
|
||
|
}
|
||
|
}
|
||
|
return starttype === types$1._import ? this.parseImport(node) : this.parseExport(node, exports);
|
||
|
default:
|
||
|
if (this.isAsyncFunction()) {
|
||
|
if (context) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
this.next();
|
||
|
return this.parseFunctionStatement(node, true, !context);
|
||
|
}
|
||
|
var maybeName = this.value, expr = this.parseExpression();
|
||
|
if (starttype === types$1.name && expr.type === "Identifier" && this.eat(types$1.colon)) {
|
||
|
return this.parseLabeledStatement(node, maybeName, expr, context);
|
||
|
} else {
|
||
|
return this.parseExpressionStatement(node, expr);
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
pp$8.parseBreakContinueStatement = function(node, keyword) {
|
||
|
var isBreak = keyword === "break";
|
||
|
this.next();
|
||
|
if (this.eat(types$1.semi) || this.insertSemicolon()) {
|
||
|
node.label = null;
|
||
|
} else if (this.type !== types$1.name) {
|
||
|
this.unexpected();
|
||
|
} else {
|
||
|
node.label = this.parseIdent();
|
||
|
this.semicolon();
|
||
|
}
|
||
|
var i = 0;
|
||
|
for (; i < this.labels.length; ++i) {
|
||
|
var lab = this.labels[i];
|
||
|
if (node.label == null || lab.name === node.label.name) {
|
||
|
if (lab.kind != null && (isBreak || lab.kind === "loop")) {
|
||
|
break;
|
||
|
}
|
||
|
if (node.label && isBreak) {
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if (i === this.labels.length) {
|
||
|
this.raise(node.start, "Unsyntactic " + keyword);
|
||
|
}
|
||
|
return this.finishNode(node, isBreak ? "BreakStatement" : "ContinueStatement");
|
||
|
};
|
||
|
pp$8.parseDebuggerStatement = function(node) {
|
||
|
this.next();
|
||
|
this.semicolon();
|
||
|
return this.finishNode(node, "DebuggerStatement");
|
||
|
};
|
||
|
pp$8.parseDoStatement = function(node) {
|
||
|
this.next();
|
||
|
this.labels.push(loopLabel);
|
||
|
node.body = this.parseStatement("do");
|
||
|
this.labels.pop();
|
||
|
this.expect(types$1._while);
|
||
|
node.test = this.parseParenExpression();
|
||
|
if (this.options.ecmaVersion >= 6) {
|
||
|
this.eat(types$1.semi);
|
||
|
} else {
|
||
|
this.semicolon();
|
||
|
}
|
||
|
return this.finishNode(node, "DoWhileStatement");
|
||
|
};
|
||
|
pp$8.parseForStatement = function(node) {
|
||
|
this.next();
|
||
|
var awaitAt = this.options.ecmaVersion >= 9 && this.canAwait && this.eatContextual("await") ? this.lastTokStart : -1;
|
||
|
this.labels.push(loopLabel);
|
||
|
this.enterScope(0);
|
||
|
this.expect(types$1.parenL);
|
||
|
if (this.type === types$1.semi) {
|
||
|
if (awaitAt > -1) {
|
||
|
this.unexpected(awaitAt);
|
||
|
}
|
||
|
return this.parseFor(node, null);
|
||
|
}
|
||
|
var isLet = this.isLet();
|
||
|
if (this.type === types$1._var || this.type === types$1._const || isLet) {
|
||
|
var init$1 = this.startNode(), kind = isLet ? "let" : this.value;
|
||
|
this.next();
|
||
|
this.parseVar(init$1, true, kind);
|
||
|
this.finishNode(init$1, "VariableDeclaration");
|
||
|
if ((this.type === types$1._in || this.options.ecmaVersion >= 6 && this.isContextual("of")) && init$1.declarations.length === 1) {
|
||
|
if (this.options.ecmaVersion >= 9) {
|
||
|
if (this.type === types$1._in) {
|
||
|
if (awaitAt > -1) {
|
||
|
this.unexpected(awaitAt);
|
||
|
}
|
||
|
} else {
|
||
|
node.await = awaitAt > -1;
|
||
|
}
|
||
|
}
|
||
|
return this.parseForIn(node, init$1);
|
||
|
}
|
||
|
if (awaitAt > -1) {
|
||
|
this.unexpected(awaitAt);
|
||
|
}
|
||
|
return this.parseFor(node, init$1);
|
||
|
}
|
||
|
var startsWithLet = this.isContextual("let"), isForOf = false;
|
||
|
var refDestructuringErrors = new DestructuringErrors();
|
||
|
var init = this.parseExpression(awaitAt > -1 ? "await" : true, refDestructuringErrors);
|
||
|
if (this.type === types$1._in || (isForOf = this.options.ecmaVersion >= 6 && this.isContextual("of"))) {
|
||
|
if (this.options.ecmaVersion >= 9) {
|
||
|
if (this.type === types$1._in) {
|
||
|
if (awaitAt > -1) {
|
||
|
this.unexpected(awaitAt);
|
||
|
}
|
||
|
} else {
|
||
|
node.await = awaitAt > -1;
|
||
|
}
|
||
|
}
|
||
|
if (startsWithLet && isForOf) {
|
||
|
this.raise(init.start, "The left-hand side of a for-of loop may not start with 'let'.");
|
||
|
}
|
||
|
this.toAssignable(init, false, refDestructuringErrors);
|
||
|
this.checkLValPattern(init);
|
||
|
return this.parseForIn(node, init);
|
||
|
} else {
|
||
|
this.checkExpressionErrors(refDestructuringErrors, true);
|
||
|
}
|
||
|
if (awaitAt > -1) {
|
||
|
this.unexpected(awaitAt);
|
||
|
}
|
||
|
return this.parseFor(node, init);
|
||
|
};
|
||
|
pp$8.parseFunctionStatement = function(node, isAsync, declarationPosition) {
|
||
|
this.next();
|
||
|
return this.parseFunction(node, FUNC_STATEMENT | (declarationPosition ? 0 : FUNC_HANGING_STATEMENT), false, isAsync);
|
||
|
};
|
||
|
pp$8.parseIfStatement = function(node) {
|
||
|
this.next();
|
||
|
node.test = this.parseParenExpression();
|
||
|
node.consequent = this.parseStatement("if");
|
||
|
node.alternate = this.eat(types$1._else) ? this.parseStatement("if") : null;
|
||
|
return this.finishNode(node, "IfStatement");
|
||
|
};
|
||
|
pp$8.parseReturnStatement = function(node) {
|
||
|
if (!this.inFunction && !this.options.allowReturnOutsideFunction) {
|
||
|
this.raise(this.start, "'return' outside of function");
|
||
|
}
|
||
|
this.next();
|
||
|
if (this.eat(types$1.semi) || this.insertSemicolon()) {
|
||
|
node.argument = null;
|
||
|
} else {
|
||
|
node.argument = this.parseExpression();
|
||
|
this.semicolon();
|
||
|
}
|
||
|
return this.finishNode(node, "ReturnStatement");
|
||
|
};
|
||
|
pp$8.parseSwitchStatement = function(node) {
|
||
|
this.next();
|
||
|
node.discriminant = this.parseParenExpression();
|
||
|
node.cases = [];
|
||
|
this.expect(types$1.braceL);
|
||
|
this.labels.push(switchLabel);
|
||
|
this.enterScope(0);
|
||
|
var cur;
|
||
|
for (var sawDefault = false; this.type !== types$1.braceR; ) {
|
||
|
if (this.type === types$1._case || this.type === types$1._default) {
|
||
|
var isCase = this.type === types$1._case;
|
||
|
if (cur) {
|
||
|
this.finishNode(cur, "SwitchCase");
|
||
|
}
|
||
|
node.cases.push(cur = this.startNode());
|
||
|
cur.consequent = [];
|
||
|
this.next();
|
||
|
if (isCase) {
|
||
|
cur.test = this.parseExpression();
|
||
|
} else {
|
||
|
if (sawDefault) {
|
||
|
this.raiseRecoverable(this.lastTokStart, "Multiple default clauses");
|
||
|
}
|
||
|
sawDefault = true;
|
||
|
cur.test = null;
|
||
|
}
|
||
|
this.expect(types$1.colon);
|
||
|
} else {
|
||
|
if (!cur) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
cur.consequent.push(this.parseStatement(null));
|
||
|
}
|
||
|
}
|
||
|
this.exitScope();
|
||
|
if (cur) {
|
||
|
this.finishNode(cur, "SwitchCase");
|
||
|
}
|
||
|
this.next();
|
||
|
this.labels.pop();
|
||
|
return this.finishNode(node, "SwitchStatement");
|
||
|
};
|
||
|
pp$8.parseThrowStatement = function(node) {
|
||
|
this.next();
|
||
|
if (lineBreak.test(this.input.slice(this.lastTokEnd, this.start))) {
|
||
|
this.raise(this.lastTokEnd, "Illegal newline after throw");
|
||
|
}
|
||
|
node.argument = this.parseExpression();
|
||
|
this.semicolon();
|
||
|
return this.finishNode(node, "ThrowStatement");
|
||
|
};
|
||
|
var empty$1 = [];
|
||
|
pp$8.parseTryStatement = function(node) {
|
||
|
this.next();
|
||
|
node.block = this.parseBlock();
|
||
|
node.handler = null;
|
||
|
if (this.type === types$1._catch) {
|
||
|
var clause = this.startNode();
|
||
|
this.next();
|
||
|
if (this.eat(types$1.parenL)) {
|
||
|
clause.param = this.parseBindingAtom();
|
||
|
var simple = clause.param.type === "Identifier";
|
||
|
this.enterScope(simple ? SCOPE_SIMPLE_CATCH : 0);
|
||
|
this.checkLValPattern(clause.param, simple ? BIND_SIMPLE_CATCH : BIND_LEXICAL);
|
||
|
this.expect(types$1.parenR);
|
||
|
} else {
|
||
|
if (this.options.ecmaVersion < 10) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
clause.param = null;
|
||
|
this.enterScope(0);
|
||
|
}
|
||
|
clause.body = this.parseBlock(false);
|
||
|
this.exitScope();
|
||
|
node.handler = this.finishNode(clause, "CatchClause");
|
||
|
}
|
||
|
node.finalizer = this.eat(types$1._finally) ? this.parseBlock() : null;
|
||
|
if (!node.handler && !node.finalizer) {
|
||
|
this.raise(node.start, "Missing catch or finally clause");
|
||
|
}
|
||
|
return this.finishNode(node, "TryStatement");
|
||
|
};
|
||
|
pp$8.parseVarStatement = function(node, kind) {
|
||
|
this.next();
|
||
|
this.parseVar(node, false, kind);
|
||
|
this.semicolon();
|
||
|
return this.finishNode(node, "VariableDeclaration");
|
||
|
};
|
||
|
pp$8.parseWhileStatement = function(node) {
|
||
|
this.next();
|
||
|
node.test = this.parseParenExpression();
|
||
|
this.labels.push(loopLabel);
|
||
|
node.body = this.parseStatement("while");
|
||
|
this.labels.pop();
|
||
|
return this.finishNode(node, "WhileStatement");
|
||
|
};
|
||
|
pp$8.parseWithStatement = function(node) {
|
||
|
if (this.strict) {
|
||
|
this.raise(this.start, "'with' in strict mode");
|
||
|
}
|
||
|
this.next();
|
||
|
node.object = this.parseParenExpression();
|
||
|
node.body = this.parseStatement("with");
|
||
|
return this.finishNode(node, "WithStatement");
|
||
|
};
|
||
|
pp$8.parseEmptyStatement = function(node) {
|
||
|
this.next();
|
||
|
return this.finishNode(node, "EmptyStatement");
|
||
|
};
|
||
|
pp$8.parseLabeledStatement = function(node, maybeName, expr, context) {
|
||
|
for (var i$1 = 0, list = this.labels; i$1 < list.length; i$1 += 1) {
|
||
|
var label = list[i$1];
|
||
|
if (label.name === maybeName) {
|
||
|
this.raise(expr.start, "Label '" + maybeName + "' is already declared");
|
||
|
}
|
||
|
}
|
||
|
var kind = this.type.isLoop ? "loop" : this.type === types$1._switch ? "switch" : null;
|
||
|
for (var i = this.labels.length - 1; i >= 0; i--) {
|
||
|
var label$1 = this.labels[i];
|
||
|
if (label$1.statementStart === node.start) {
|
||
|
label$1.statementStart = this.start;
|
||
|
label$1.kind = kind;
|
||
|
} else {
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
this.labels.push({ name: maybeName, kind, statementStart: this.start });
|
||
|
node.body = this.parseStatement(context ? context.indexOf("label") === -1 ? context + "label" : context : "label");
|
||
|
this.labels.pop();
|
||
|
node.label = expr;
|
||
|
return this.finishNode(node, "LabeledStatement");
|
||
|
};
|
||
|
pp$8.parseExpressionStatement = function(node, expr) {
|
||
|
node.expression = expr;
|
||
|
this.semicolon();
|
||
|
return this.finishNode(node, "ExpressionStatement");
|
||
|
};
|
||
|
pp$8.parseBlock = function(createNewLexicalScope, node, exitStrict) {
|
||
|
if (createNewLexicalScope === void 0)
|
||
|
createNewLexicalScope = true;
|
||
|
if (node === void 0)
|
||
|
node = this.startNode();
|
||
|
node.body = [];
|
||
|
this.expect(types$1.braceL);
|
||
|
if (createNewLexicalScope) {
|
||
|
this.enterScope(0);
|
||
|
}
|
||
|
while (this.type !== types$1.braceR) {
|
||
|
var stmt = this.parseStatement(null);
|
||
|
node.body.push(stmt);
|
||
|
}
|
||
|
if (exitStrict) {
|
||
|
this.strict = false;
|
||
|
}
|
||
|
this.next();
|
||
|
if (createNewLexicalScope) {
|
||
|
this.exitScope();
|
||
|
}
|
||
|
return this.finishNode(node, "BlockStatement");
|
||
|
};
|
||
|
pp$8.parseFor = function(node, init) {
|
||
|
node.init = init;
|
||
|
this.expect(types$1.semi);
|
||
|
node.test = this.type === types$1.semi ? null : this.parseExpression();
|
||
|
this.expect(types$1.semi);
|
||
|
node.update = this.type === types$1.parenR ? null : this.parseExpression();
|
||
|
this.expect(types$1.parenR);
|
||
|
node.body = this.parseStatement("for");
|
||
|
this.exitScope();
|
||
|
this.labels.pop();
|
||
|
return this.finishNode(node, "ForStatement");
|
||
|
};
|
||
|
pp$8.parseForIn = function(node, init) {
|
||
|
var isForIn = this.type === types$1._in;
|
||
|
this.next();
|
||
|
if (init.type === "VariableDeclaration" && init.declarations[0].init != null && (!isForIn || this.options.ecmaVersion < 8 || this.strict || init.kind !== "var" || init.declarations[0].id.type !== "Identifier")) {
|
||
|
this.raise(
|
||
|
init.start,
|
||
|
(isForIn ? "for-in" : "for-of") + " loop variable declaration may not have an initializer"
|
||
|
);
|
||
|
}
|
||
|
node.left = init;
|
||
|
node.right = isForIn ? this.parseExpression() : this.parseMaybeAssign();
|
||
|
this.expect(types$1.parenR);
|
||
|
node.body = this.parseStatement("for");
|
||
|
this.exitScope();
|
||
|
this.labels.pop();
|
||
|
return this.finishNode(node, isForIn ? "ForInStatement" : "ForOfStatement");
|
||
|
};
|
||
|
pp$8.parseVar = function(node, isFor, kind) {
|
||
|
node.declarations = [];
|
||
|
node.kind = kind;
|
||
|
for (; ; ) {
|
||
|
var decl = this.startNode();
|
||
|
this.parseVarId(decl, kind);
|
||
|
if (this.eat(types$1.eq)) {
|
||
|
decl.init = this.parseMaybeAssign(isFor);
|
||
|
} else if (kind === "const" && !(this.type === types$1._in || this.options.ecmaVersion >= 6 && this.isContextual("of"))) {
|
||
|
this.unexpected();
|
||
|
} else if (decl.id.type !== "Identifier" && !(isFor && (this.type === types$1._in || this.isContextual("of")))) {
|
||
|
this.raise(this.lastTokEnd, "Complex binding patterns require an initialization value");
|
||
|
} else {
|
||
|
decl.init = null;
|
||
|
}
|
||
|
node.declarations.push(this.finishNode(decl, "VariableDeclarator"));
|
||
|
if (!this.eat(types$1.comma)) {
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
return node;
|
||
|
};
|
||
|
pp$8.parseVarId = function(decl, kind) {
|
||
|
decl.id = this.parseBindingAtom();
|
||
|
this.checkLValPattern(decl.id, kind === "var" ? BIND_VAR : BIND_LEXICAL, false);
|
||
|
};
|
||
|
var FUNC_STATEMENT = 1, FUNC_HANGING_STATEMENT = 2, FUNC_NULLABLE_ID = 4;
|
||
|
pp$8.parseFunction = function(node, statement, allowExpressionBody, isAsync, forInit) {
|
||
|
this.initFunction(node);
|
||
|
if (this.options.ecmaVersion >= 9 || this.options.ecmaVersion >= 6 && !isAsync) {
|
||
|
if (this.type === types$1.star && statement & FUNC_HANGING_STATEMENT) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
node.generator = this.eat(types$1.star);
|
||
|
}
|
||
|
if (this.options.ecmaVersion >= 8) {
|
||
|
node.async = !!isAsync;
|
||
|
}
|
||
|
if (statement & FUNC_STATEMENT) {
|
||
|
node.id = statement & FUNC_NULLABLE_ID && this.type !== types$1.name ? null : this.parseIdent();
|
||
|
if (node.id && !(statement & FUNC_HANGING_STATEMENT)) {
|
||
|
this.checkLValSimple(node.id, this.strict || node.generator || node.async ? this.treatFunctionsAsVar ? BIND_VAR : BIND_LEXICAL : BIND_FUNCTION);
|
||
|
}
|
||
|
}
|
||
|
var oldYieldPos = this.yieldPos, oldAwaitPos = this.awaitPos, oldAwaitIdentPos = this.awaitIdentPos;
|
||
|
this.yieldPos = 0;
|
||
|
this.awaitPos = 0;
|
||
|
this.awaitIdentPos = 0;
|
||
|
this.enterScope(functionFlags(node.async, node.generator));
|
||
|
if (!(statement & FUNC_STATEMENT)) {
|
||
|
node.id = this.type === types$1.name ? this.parseIdent() : null;
|
||
|
}
|
||
|
this.parseFunctionParams(node);
|
||
|
this.parseFunctionBody(node, allowExpressionBody, false, forInit);
|
||
|
this.yieldPos = oldYieldPos;
|
||
|
this.awaitPos = oldAwaitPos;
|
||
|
this.awaitIdentPos = oldAwaitIdentPos;
|
||
|
return this.finishNode(node, statement & FUNC_STATEMENT ? "FunctionDeclaration" : "FunctionExpression");
|
||
|
};
|
||
|
pp$8.parseFunctionParams = function(node) {
|
||
|
this.expect(types$1.parenL);
|
||
|
node.params = this.parseBindingList(types$1.parenR, false, this.options.ecmaVersion >= 8);
|
||
|
this.checkYieldAwaitInDefaultParams();
|
||
|
};
|
||
|
pp$8.parseClass = function(node, isStatement) {
|
||
|
this.next();
|
||
|
var oldStrict = this.strict;
|
||
|
this.strict = true;
|
||
|
this.parseClassId(node, isStatement);
|
||
|
this.parseClassSuper(node);
|
||
|
var privateNameMap = this.enterClassBody();
|
||
|
var classBody = this.startNode();
|
||
|
var hadConstructor = false;
|
||
|
classBody.body = [];
|
||
|
this.expect(types$1.braceL);
|
||
|
while (this.type !== types$1.braceR) {
|
||
|
var element = this.parseClassElement(node.superClass !== null);
|
||
|
if (element) {
|
||
|
classBody.body.push(element);
|
||
|
if (element.type === "MethodDefinition" && element.kind === "constructor") {
|
||
|
if (hadConstructor) {
|
||
|
this.raise(element.start, "Duplicate constructor in the same class");
|
||
|
}
|
||
|
hadConstructor = true;
|
||
|
} else if (element.key && element.key.type === "PrivateIdentifier" && isPrivateNameConflicted(privateNameMap, element)) {
|
||
|
this.raiseRecoverable(element.key.start, "Identifier '#" + element.key.name + "' has already been declared");
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
this.strict = oldStrict;
|
||
|
this.next();
|
||
|
node.body = this.finishNode(classBody, "ClassBody");
|
||
|
this.exitClassBody();
|
||
|
return this.finishNode(node, isStatement ? "ClassDeclaration" : "ClassExpression");
|
||
|
};
|
||
|
pp$8.parseClassElement = function(constructorAllowsSuper) {
|
||
|
if (this.eat(types$1.semi)) {
|
||
|
return null;
|
||
|
}
|
||
|
var ecmaVersion = this.options.ecmaVersion;
|
||
|
var node = this.startNode();
|
||
|
var keyName = "";
|
||
|
var isGenerator = false;
|
||
|
var isAsync = false;
|
||
|
var kind = "method";
|
||
|
var isStatic = false;
|
||
|
if (this.eatContextual("static")) {
|
||
|
if (ecmaVersion >= 13 && this.eat(types$1.braceL)) {
|
||
|
this.parseClassStaticBlock(node);
|
||
|
return node;
|
||
|
}
|
||
|
if (this.isClassElementNameStart() || this.type === types$1.star) {
|
||
|
isStatic = true;
|
||
|
} else {
|
||
|
keyName = "static";
|
||
|
}
|
||
|
}
|
||
|
node.static = isStatic;
|
||
|
if (!keyName && ecmaVersion >= 8 && this.eatContextual("async")) {
|
||
|
if ((this.isClassElementNameStart() || this.type === types$1.star) && !this.canInsertSemicolon()) {
|
||
|
isAsync = true;
|
||
|
} else {
|
||
|
keyName = "async";
|
||
|
}
|
||
|
}
|
||
|
if (!keyName && (ecmaVersion >= 9 || !isAsync) && this.eat(types$1.star)) {
|
||
|
isGenerator = true;
|
||
|
}
|
||
|
if (!keyName && !isAsync && !isGenerator) {
|
||
|
var lastValue = this.value;
|
||
|
if (this.eatContextual("get") || this.eatContextual("set")) {
|
||
|
if (this.isClassElementNameStart()) {
|
||
|
kind = lastValue;
|
||
|
} else {
|
||
|
keyName = lastValue;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if (keyName) {
|
||
|
node.computed = false;
|
||
|
node.key = this.startNodeAt(this.lastTokStart, this.lastTokStartLoc);
|
||
|
node.key.name = keyName;
|
||
|
this.finishNode(node.key, "Identifier");
|
||
|
} else {
|
||
|
this.parseClassElementName(node);
|
||
|
}
|
||
|
if (ecmaVersion < 13 || this.type === types$1.parenL || kind !== "method" || isGenerator || isAsync) {
|
||
|
var isConstructor = !node.static && checkKeyName(node, "constructor");
|
||
|
var allowsDirectSuper = isConstructor && constructorAllowsSuper;
|
||
|
if (isConstructor && kind !== "method") {
|
||
|
this.raise(node.key.start, "Constructor can't have get/set modifier");
|
||
|
}
|
||
|
node.kind = isConstructor ? "constructor" : kind;
|
||
|
this.parseClassMethod(node, isGenerator, isAsync, allowsDirectSuper);
|
||
|
} else {
|
||
|
this.parseClassField(node);
|
||
|
}
|
||
|
return node;
|
||
|
};
|
||
|
pp$8.isClassElementNameStart = function() {
|
||
|
return this.type === types$1.name || this.type === types$1.privateId || this.type === types$1.num || this.type === types$1.string || this.type === types$1.bracketL || this.type.keyword;
|
||
|
};
|
||
|
pp$8.parseClassElementName = function(element) {
|
||
|
if (this.type === types$1.privateId) {
|
||
|
if (this.value === "constructor") {
|
||
|
this.raise(this.start, "Classes can't have an element named '#constructor'");
|
||
|
}
|
||
|
element.computed = false;
|
||
|
element.key = this.parsePrivateIdent();
|
||
|
} else {
|
||
|
this.parsePropertyName(element);
|
||
|
}
|
||
|
};
|
||
|
pp$8.parseClassMethod = function(method, isGenerator, isAsync, allowsDirectSuper) {
|
||
|
var key = method.key;
|
||
|
if (method.kind === "constructor") {
|
||
|
if (isGenerator) {
|
||
|
this.raise(key.start, "Constructor can't be a generator");
|
||
|
}
|
||
|
if (isAsync) {
|
||
|
this.raise(key.start, "Constructor can't be an async method");
|
||
|
}
|
||
|
} else if (method.static && checkKeyName(method, "prototype")) {
|
||
|
this.raise(key.start, "Classes may not have a static property named prototype");
|
||
|
}
|
||
|
var value = method.value = this.parseMethod(isGenerator, isAsync, allowsDirectSuper);
|
||
|
if (method.kind === "get" && value.params.length !== 0) {
|
||
|
this.raiseRecoverable(value.start, "getter should have no params");
|
||
|
}
|
||
|
if (method.kind === "set" && value.params.length !== 1) {
|
||
|
this.raiseRecoverable(value.start, "setter should have exactly one param");
|
||
|
}
|
||
|
if (method.kind === "set" && value.params[0].type === "RestElement") {
|
||
|
this.raiseRecoverable(value.params[0].start, "Setter cannot use rest params");
|
||
|
}
|
||
|
return this.finishNode(method, "MethodDefinition");
|
||
|
};
|
||
|
pp$8.parseClassField = function(field) {
|
||
|
if (checkKeyName(field, "constructor")) {
|
||
|
this.raise(field.key.start, "Classes can't have a field named 'constructor'");
|
||
|
} else if (field.static && checkKeyName(field, "prototype")) {
|
||
|
this.raise(field.key.start, "Classes can't have a static field named 'prototype'");
|
||
|
}
|
||
|
if (this.eat(types$1.eq)) {
|
||
|
var scope = this.currentThisScope();
|
||
|
var inClassFieldInit = scope.inClassFieldInit;
|
||
|
scope.inClassFieldInit = true;
|
||
|
field.value = this.parseMaybeAssign();
|
||
|
scope.inClassFieldInit = inClassFieldInit;
|
||
|
} else {
|
||
|
field.value = null;
|
||
|
}
|
||
|
this.semicolon();
|
||
|
return this.finishNode(field, "PropertyDefinition");
|
||
|
};
|
||
|
pp$8.parseClassStaticBlock = function(node) {
|
||
|
node.body = [];
|
||
|
var oldLabels = this.labels;
|
||
|
this.labels = [];
|
||
|
this.enterScope(SCOPE_CLASS_STATIC_BLOCK | SCOPE_SUPER);
|
||
|
while (this.type !== types$1.braceR) {
|
||
|
var stmt = this.parseStatement(null);
|
||
|
node.body.push(stmt);
|
||
|
}
|
||
|
this.next();
|
||
|
this.exitScope();
|
||
|
this.labels = oldLabels;
|
||
|
return this.finishNode(node, "StaticBlock");
|
||
|
};
|
||
|
pp$8.parseClassId = function(node, isStatement) {
|
||
|
if (this.type === types$1.name) {
|
||
|
node.id = this.parseIdent();
|
||
|
if (isStatement) {
|
||
|
this.checkLValSimple(node.id, BIND_LEXICAL, false);
|
||
|
}
|
||
|
} else {
|
||
|
if (isStatement === true) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
node.id = null;
|
||
|
}
|
||
|
};
|
||
|
pp$8.parseClassSuper = function(node) {
|
||
|
node.superClass = this.eat(types$1._extends) ? this.parseExprSubscripts(false) : null;
|
||
|
};
|
||
|
pp$8.enterClassBody = function() {
|
||
|
var element = { declared: /* @__PURE__ */ Object.create(null), used: [] };
|
||
|
this.privateNameStack.push(element);
|
||
|
return element.declared;
|
||
|
};
|
||
|
pp$8.exitClassBody = function() {
|
||
|
var ref2 = this.privateNameStack.pop();
|
||
|
var declared = ref2.declared;
|
||
|
var used = ref2.used;
|
||
|
var len = this.privateNameStack.length;
|
||
|
var parent = len === 0 ? null : this.privateNameStack[len - 1];
|
||
|
for (var i = 0; i < used.length; ++i) {
|
||
|
var id = used[i];
|
||
|
if (!hasOwn(declared, id.name)) {
|
||
|
if (parent) {
|
||
|
parent.used.push(id);
|
||
|
} else {
|
||
|
this.raiseRecoverable(id.start, "Private field '#" + id.name + "' must be declared in an enclosing class");
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
function isPrivateNameConflicted(privateNameMap, element) {
|
||
|
var name = element.key.name;
|
||
|
var curr = privateNameMap[name];
|
||
|
var next = "true";
|
||
|
if (element.type === "MethodDefinition" && (element.kind === "get" || element.kind === "set")) {
|
||
|
next = (element.static ? "s" : "i") + element.kind;
|
||
|
}
|
||
|
if (curr === "iget" && next === "iset" || curr === "iset" && next === "iget" || curr === "sget" && next === "sset" || curr === "sset" && next === "sget") {
|
||
|
privateNameMap[name] = "true";
|
||
|
return false;
|
||
|
} else if (!curr) {
|
||
|
privateNameMap[name] = next;
|
||
|
return false;
|
||
|
} else {
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
function checkKeyName(node, name) {
|
||
|
var computed = node.computed;
|
||
|
var key = node.key;
|
||
|
return !computed && (key.type === "Identifier" && key.name === name || key.type === "Literal" && key.value === name);
|
||
|
}
|
||
|
pp$8.parseExport = function(node, exports) {
|
||
|
this.next();
|
||
|
if (this.eat(types$1.star)) {
|
||
|
if (this.options.ecmaVersion >= 11) {
|
||
|
if (this.eatContextual("as")) {
|
||
|
node.exported = this.parseModuleExportName();
|
||
|
this.checkExport(exports, node.exported, this.lastTokStart);
|
||
|
} else {
|
||
|
node.exported = null;
|
||
|
}
|
||
|
}
|
||
|
this.expectContextual("from");
|
||
|
if (this.type !== types$1.string) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
node.source = this.parseExprAtom();
|
||
|
this.semicolon();
|
||
|
return this.finishNode(node, "ExportAllDeclaration");
|
||
|
}
|
||
|
if (this.eat(types$1._default)) {
|
||
|
this.checkExport(exports, "default", this.lastTokStart);
|
||
|
var isAsync;
|
||
|
if (this.type === types$1._function || (isAsync = this.isAsyncFunction())) {
|
||
|
var fNode = this.startNode();
|
||
|
this.next();
|
||
|
if (isAsync) {
|
||
|
this.next();
|
||
|
}
|
||
|
node.declaration = this.parseFunction(fNode, FUNC_STATEMENT | FUNC_NULLABLE_ID, false, isAsync);
|
||
|
} else if (this.type === types$1._class) {
|
||
|
var cNode = this.startNode();
|
||
|
node.declaration = this.parseClass(cNode, "nullableID");
|
||
|
} else {
|
||
|
node.declaration = this.parseMaybeAssign();
|
||
|
this.semicolon();
|
||
|
}
|
||
|
return this.finishNode(node, "ExportDefaultDeclaration");
|
||
|
}
|
||
|
if (this.shouldParseExportStatement()) {
|
||
|
node.declaration = this.parseStatement(null);
|
||
|
if (node.declaration.type === "VariableDeclaration") {
|
||
|
this.checkVariableExport(exports, node.declaration.declarations);
|
||
|
} else {
|
||
|
this.checkExport(exports, node.declaration.id, node.declaration.id.start);
|
||
|
}
|
||
|
node.specifiers = [];
|
||
|
node.source = null;
|
||
|
} else {
|
||
|
node.declaration = null;
|
||
|
node.specifiers = this.parseExportSpecifiers(exports);
|
||
|
if (this.eatContextual("from")) {
|
||
|
if (this.type !== types$1.string) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
node.source = this.parseExprAtom();
|
||
|
} else {
|
||
|
for (var i = 0, list = node.specifiers; i < list.length; i += 1) {
|
||
|
var spec = list[i];
|
||
|
this.checkUnreserved(spec.local);
|
||
|
this.checkLocalExport(spec.local);
|
||
|
if (spec.local.type === "Literal") {
|
||
|
this.raise(spec.local.start, "A string literal cannot be used as an exported binding without `from`.");
|
||
|
}
|
||
|
}
|
||
|
node.source = null;
|
||
|
}
|
||
|
this.semicolon();
|
||
|
}
|
||
|
return this.finishNode(node, "ExportNamedDeclaration");
|
||
|
};
|
||
|
pp$8.checkExport = function(exports, name, pos) {
|
||
|
if (!exports) {
|
||
|
return;
|
||
|
}
|
||
|
if (typeof name !== "string") {
|
||
|
name = name.type === "Identifier" ? name.name : name.value;
|
||
|
}
|
||
|
if (hasOwn(exports, name)) {
|
||
|
this.raiseRecoverable(pos, "Duplicate export '" + name + "'");
|
||
|
}
|
||
|
exports[name] = true;
|
||
|
};
|
||
|
pp$8.checkPatternExport = function(exports, pat) {
|
||
|
var type = pat.type;
|
||
|
if (type === "Identifier") {
|
||
|
this.checkExport(exports, pat, pat.start);
|
||
|
} else if (type === "ObjectPattern") {
|
||
|
for (var i = 0, list = pat.properties; i < list.length; i += 1) {
|
||
|
var prop = list[i];
|
||
|
this.checkPatternExport(exports, prop);
|
||
|
}
|
||
|
} else if (type === "ArrayPattern") {
|
||
|
for (var i$1 = 0, list$1 = pat.elements; i$1 < list$1.length; i$1 += 1) {
|
||
|
var elt = list$1[i$1];
|
||
|
if (elt) {
|
||
|
this.checkPatternExport(exports, elt);
|
||
|
}
|
||
|
}
|
||
|
} else if (type === "Property") {
|
||
|
this.checkPatternExport(exports, pat.value);
|
||
|
} else if (type === "AssignmentPattern") {
|
||
|
this.checkPatternExport(exports, pat.left);
|
||
|
} else if (type === "RestElement") {
|
||
|
this.checkPatternExport(exports, pat.argument);
|
||
|
} else if (type === "ParenthesizedExpression") {
|
||
|
this.checkPatternExport(exports, pat.expression);
|
||
|
}
|
||
|
};
|
||
|
pp$8.checkVariableExport = function(exports, decls) {
|
||
|
if (!exports) {
|
||
|
return;
|
||
|
}
|
||
|
for (var i = 0, list = decls; i < list.length; i += 1) {
|
||
|
var decl = list[i];
|
||
|
this.checkPatternExport(exports, decl.id);
|
||
|
}
|
||
|
};
|
||
|
pp$8.shouldParseExportStatement = function() {
|
||
|
return this.type.keyword === "var" || this.type.keyword === "const" || this.type.keyword === "class" || this.type.keyword === "function" || this.isLet() || this.isAsyncFunction();
|
||
|
};
|
||
|
pp$8.parseExportSpecifiers = function(exports) {
|
||
|
var nodes = [], first = true;
|
||
|
this.expect(types$1.braceL);
|
||
|
while (!this.eat(types$1.braceR)) {
|
||
|
if (!first) {
|
||
|
this.expect(types$1.comma);
|
||
|
if (this.afterTrailingComma(types$1.braceR)) {
|
||
|
break;
|
||
|
}
|
||
|
} else {
|
||
|
first = false;
|
||
|
}
|
||
|
var node = this.startNode();
|
||
|
node.local = this.parseModuleExportName();
|
||
|
node.exported = this.eatContextual("as") ? this.parseModuleExportName() : node.local;
|
||
|
this.checkExport(
|
||
|
exports,
|
||
|
node.exported,
|
||
|
node.exported.start
|
||
|
);
|
||
|
nodes.push(this.finishNode(node, "ExportSpecifier"));
|
||
|
}
|
||
|
return nodes;
|
||
|
};
|
||
|
pp$8.parseImport = function(node) {
|
||
|
this.next();
|
||
|
if (this.type === types$1.string) {
|
||
|
node.specifiers = empty$1;
|
||
|
node.source = this.parseExprAtom();
|
||
|
} else {
|
||
|
node.specifiers = this.parseImportSpecifiers();
|
||
|
this.expectContextual("from");
|
||
|
node.source = this.type === types$1.string ? this.parseExprAtom() : this.unexpected();
|
||
|
}
|
||
|
this.semicolon();
|
||
|
return this.finishNode(node, "ImportDeclaration");
|
||
|
};
|
||
|
pp$8.parseImportSpecifiers = function() {
|
||
|
var nodes = [], first = true;
|
||
|
if (this.type === types$1.name) {
|
||
|
var node = this.startNode();
|
||
|
node.local = this.parseIdent();
|
||
|
this.checkLValSimple(node.local, BIND_LEXICAL);
|
||
|
nodes.push(this.finishNode(node, "ImportDefaultSpecifier"));
|
||
|
if (!this.eat(types$1.comma)) {
|
||
|
return nodes;
|
||
|
}
|
||
|
}
|
||
|
if (this.type === types$1.star) {
|
||
|
var node$1 = this.startNode();
|
||
|
this.next();
|
||
|
this.expectContextual("as");
|
||
|
node$1.local = this.parseIdent();
|
||
|
this.checkLValSimple(node$1.local, BIND_LEXICAL);
|
||
|
nodes.push(this.finishNode(node$1, "ImportNamespaceSpecifier"));
|
||
|
return nodes;
|
||
|
}
|
||
|
this.expect(types$1.braceL);
|
||
|
while (!this.eat(types$1.braceR)) {
|
||
|
if (!first) {
|
||
|
this.expect(types$1.comma);
|
||
|
if (this.afterTrailingComma(types$1.braceR)) {
|
||
|
break;
|
||
|
}
|
||
|
} else {
|
||
|
first = false;
|
||
|
}
|
||
|
var node$2 = this.startNode();
|
||
|
node$2.imported = this.parseModuleExportName();
|
||
|
if (this.eatContextual("as")) {
|
||
|
node$2.local = this.parseIdent();
|
||
|
} else {
|
||
|
this.checkUnreserved(node$2.imported);
|
||
|
node$2.local = node$2.imported;
|
||
|
}
|
||
|
this.checkLValSimple(node$2.local, BIND_LEXICAL);
|
||
|
nodes.push(this.finishNode(node$2, "ImportSpecifier"));
|
||
|
}
|
||
|
return nodes;
|
||
|
};
|
||
|
pp$8.parseModuleExportName = function() {
|
||
|
if (this.options.ecmaVersion >= 13 && this.type === types$1.string) {
|
||
|
var stringLiteral = this.parseLiteral(this.value);
|
||
|
if (loneSurrogate.test(stringLiteral.value)) {
|
||
|
this.raise(stringLiteral.start, "An export name cannot include a lone surrogate.");
|
||
|
}
|
||
|
return stringLiteral;
|
||
|
}
|
||
|
return this.parseIdent(true);
|
||
|
};
|
||
|
pp$8.adaptDirectivePrologue = function(statements) {
|
||
|
for (var i = 0; i < statements.length && this.isDirectiveCandidate(statements[i]); ++i) {
|
||
|
statements[i].directive = statements[i].expression.raw.slice(1, -1);
|
||
|
}
|
||
|
};
|
||
|
pp$8.isDirectiveCandidate = function(statement) {
|
||
|
return this.options.ecmaVersion >= 5 && statement.type === "ExpressionStatement" && statement.expression.type === "Literal" && typeof statement.expression.value === "string" && (this.input[statement.start] === '"' || this.input[statement.start] === "'");
|
||
|
};
|
||
|
var pp$7 = Parser.prototype;
|
||
|
pp$7.toAssignable = function(node, isBinding, refDestructuringErrors) {
|
||
|
if (this.options.ecmaVersion >= 6 && node) {
|
||
|
switch (node.type) {
|
||
|
case "Identifier":
|
||
|
if (this.inAsync && node.name === "await") {
|
||
|
this.raise(node.start, "Cannot use 'await' as identifier inside an async function");
|
||
|
}
|
||
|
break;
|
||
|
case "ObjectPattern":
|
||
|
case "ArrayPattern":
|
||
|
case "AssignmentPattern":
|
||
|
case "RestElement":
|
||
|
break;
|
||
|
case "ObjectExpression":
|
||
|
node.type = "ObjectPattern";
|
||
|
if (refDestructuringErrors) {
|
||
|
this.checkPatternErrors(refDestructuringErrors, true);
|
||
|
}
|
||
|
for (var i = 0, list = node.properties; i < list.length; i += 1) {
|
||
|
var prop = list[i];
|
||
|
this.toAssignable(prop, isBinding);
|
||
|
if (prop.type === "RestElement" && (prop.argument.type === "ArrayPattern" || prop.argument.type === "ObjectPattern")) {
|
||
|
this.raise(prop.argument.start, "Unexpected token");
|
||
|
}
|
||
|
}
|
||
|
break;
|
||
|
case "Property":
|
||
|
if (node.kind !== "init") {
|
||
|
this.raise(node.key.start, "Object pattern can't contain getter or setter");
|
||
|
}
|
||
|
this.toAssignable(node.value, isBinding);
|
||
|
break;
|
||
|
case "ArrayExpression":
|
||
|
node.type = "ArrayPattern";
|
||
|
if (refDestructuringErrors) {
|
||
|
this.checkPatternErrors(refDestructuringErrors, true);
|
||
|
}
|
||
|
this.toAssignableList(node.elements, isBinding);
|
||
|
break;
|
||
|
case "SpreadElement":
|
||
|
node.type = "RestElement";
|
||
|
this.toAssignable(node.argument, isBinding);
|
||
|
if (node.argument.type === "AssignmentPattern") {
|
||
|
this.raise(node.argument.start, "Rest elements cannot have a default value");
|
||
|
}
|
||
|
break;
|
||
|
case "AssignmentExpression":
|
||
|
if (node.operator !== "=") {
|
||
|
this.raise(node.left.end, "Only '=' operator can be used for specifying default value.");
|
||
|
}
|
||
|
node.type = "AssignmentPattern";
|
||
|
delete node.operator;
|
||
|
this.toAssignable(node.left, isBinding);
|
||
|
break;
|
||
|
case "ParenthesizedExpression":
|
||
|
this.toAssignable(node.expression, isBinding, refDestructuringErrors);
|
||
|
break;
|
||
|
case "ChainExpression":
|
||
|
this.raiseRecoverable(node.start, "Optional chaining cannot appear in left-hand side");
|
||
|
break;
|
||
|
case "MemberExpression":
|
||
|
if (!isBinding) {
|
||
|
break;
|
||
|
}
|
||
|
default:
|
||
|
this.raise(node.start, "Assigning to rvalue");
|
||
|
}
|
||
|
} else if (refDestructuringErrors) {
|
||
|
this.checkPatternErrors(refDestructuringErrors, true);
|
||
|
}
|
||
|
return node;
|
||
|
};
|
||
|
pp$7.toAssignableList = function(exprList, isBinding) {
|
||
|
var end = exprList.length;
|
||
|
for (var i = 0; i < end; i++) {
|
||
|
var elt = exprList[i];
|
||
|
if (elt) {
|
||
|
this.toAssignable(elt, isBinding);
|
||
|
}
|
||
|
}
|
||
|
if (end) {
|
||
|
var last = exprList[end - 1];
|
||
|
if (this.options.ecmaVersion === 6 && isBinding && last && last.type === "RestElement" && last.argument.type !== "Identifier") {
|
||
|
this.unexpected(last.argument.start);
|
||
|
}
|
||
|
}
|
||
|
return exprList;
|
||
|
};
|
||
|
pp$7.parseSpread = function(refDestructuringErrors) {
|
||
|
var node = this.startNode();
|
||
|
this.next();
|
||
|
node.argument = this.parseMaybeAssign(false, refDestructuringErrors);
|
||
|
return this.finishNode(node, "SpreadElement");
|
||
|
};
|
||
|
pp$7.parseRestBinding = function() {
|
||
|
var node = this.startNode();
|
||
|
this.next();
|
||
|
if (this.options.ecmaVersion === 6 && this.type !== types$1.name) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
node.argument = this.parseBindingAtom();
|
||
|
return this.finishNode(node, "RestElement");
|
||
|
};
|
||
|
pp$7.parseBindingAtom = function() {
|
||
|
if (this.options.ecmaVersion >= 6) {
|
||
|
switch (this.type) {
|
||
|
case types$1.bracketL:
|
||
|
var node = this.startNode();
|
||
|
this.next();
|
||
|
node.elements = this.parseBindingList(types$1.bracketR, true, true);
|
||
|
return this.finishNode(node, "ArrayPattern");
|
||
|
case types$1.braceL:
|
||
|
return this.parseObj(true);
|
||
|
}
|
||
|
}
|
||
|
return this.parseIdent();
|
||
|
};
|
||
|
pp$7.parseBindingList = function(close, allowEmpty, allowTrailingComma) {
|
||
|
var elts = [], first = true;
|
||
|
while (!this.eat(close)) {
|
||
|
if (first) {
|
||
|
first = false;
|
||
|
} else {
|
||
|
this.expect(types$1.comma);
|
||
|
}
|
||
|
if (allowEmpty && this.type === types$1.comma) {
|
||
|
elts.push(null);
|
||
|
} else if (allowTrailingComma && this.afterTrailingComma(close)) {
|
||
|
break;
|
||
|
} else if (this.type === types$1.ellipsis) {
|
||
|
var rest = this.parseRestBinding();
|
||
|
this.parseBindingListItem(rest);
|
||
|
elts.push(rest);
|
||
|
if (this.type === types$1.comma) {
|
||
|
this.raise(this.start, "Comma is not permitted after the rest element");
|
||
|
}
|
||
|
this.expect(close);
|
||
|
break;
|
||
|
} else {
|
||
|
var elem = this.parseMaybeDefault(this.start, this.startLoc);
|
||
|
this.parseBindingListItem(elem);
|
||
|
elts.push(elem);
|
||
|
}
|
||
|
}
|
||
|
return elts;
|
||
|
};
|
||
|
pp$7.parseBindingListItem = function(param) {
|
||
|
return param;
|
||
|
};
|
||
|
pp$7.parseMaybeDefault = function(startPos, startLoc, left) {
|
||
|
left = left || this.parseBindingAtom();
|
||
|
if (this.options.ecmaVersion < 6 || !this.eat(types$1.eq)) {
|
||
|
return left;
|
||
|
}
|
||
|
var node = this.startNodeAt(startPos, startLoc);
|
||
|
node.left = left;
|
||
|
node.right = this.parseMaybeAssign();
|
||
|
return this.finishNode(node, "AssignmentPattern");
|
||
|
};
|
||
|
pp$7.checkLValSimple = function(expr, bindingType, checkClashes) {
|
||
|
if (bindingType === void 0)
|
||
|
bindingType = BIND_NONE;
|
||
|
var isBind = bindingType !== BIND_NONE;
|
||
|
switch (expr.type) {
|
||
|
case "Identifier":
|
||
|
if (this.strict && this.reservedWordsStrictBind.test(expr.name)) {
|
||
|
this.raiseRecoverable(expr.start, (isBind ? "Binding " : "Assigning to ") + expr.name + " in strict mode");
|
||
|
}
|
||
|
if (isBind) {
|
||
|
if (bindingType === BIND_LEXICAL && expr.name === "let") {
|
||
|
this.raiseRecoverable(expr.start, "let is disallowed as a lexically bound name");
|
||
|
}
|
||
|
if (checkClashes) {
|
||
|
if (hasOwn(checkClashes, expr.name)) {
|
||
|
this.raiseRecoverable(expr.start, "Argument name clash");
|
||
|
}
|
||
|
checkClashes[expr.name] = true;
|
||
|
}
|
||
|
if (bindingType !== BIND_OUTSIDE) {
|
||
|
this.declareName(expr.name, bindingType, expr.start);
|
||
|
}
|
||
|
}
|
||
|
break;
|
||
|
case "ChainExpression":
|
||
|
this.raiseRecoverable(expr.start, "Optional chaining cannot appear in left-hand side");
|
||
|
break;
|
||
|
case "MemberExpression":
|
||
|
if (isBind) {
|
||
|
this.raiseRecoverable(expr.start, "Binding member expression");
|
||
|
}
|
||
|
break;
|
||
|
case "ParenthesizedExpression":
|
||
|
if (isBind) {
|
||
|
this.raiseRecoverable(expr.start, "Binding parenthesized expression");
|
||
|
}
|
||
|
return this.checkLValSimple(expr.expression, bindingType, checkClashes);
|
||
|
default:
|
||
|
this.raise(expr.start, (isBind ? "Binding" : "Assigning to") + " rvalue");
|
||
|
}
|
||
|
};
|
||
|
pp$7.checkLValPattern = function(expr, bindingType, checkClashes) {
|
||
|
if (bindingType === void 0)
|
||
|
bindingType = BIND_NONE;
|
||
|
switch (expr.type) {
|
||
|
case "ObjectPattern":
|
||
|
for (var i = 0, list = expr.properties; i < list.length; i += 1) {
|
||
|
var prop = list[i];
|
||
|
this.checkLValInnerPattern(prop, bindingType, checkClashes);
|
||
|
}
|
||
|
break;
|
||
|
case "ArrayPattern":
|
||
|
for (var i$1 = 0, list$1 = expr.elements; i$1 < list$1.length; i$1 += 1) {
|
||
|
var elem = list$1[i$1];
|
||
|
if (elem) {
|
||
|
this.checkLValInnerPattern(elem, bindingType, checkClashes);
|
||
|
}
|
||
|
}
|
||
|
break;
|
||
|
default:
|
||
|
this.checkLValSimple(expr, bindingType, checkClashes);
|
||
|
}
|
||
|
};
|
||
|
pp$7.checkLValInnerPattern = function(expr, bindingType, checkClashes) {
|
||
|
if (bindingType === void 0)
|
||
|
bindingType = BIND_NONE;
|
||
|
switch (expr.type) {
|
||
|
case "Property":
|
||
|
this.checkLValInnerPattern(expr.value, bindingType, checkClashes);
|
||
|
break;
|
||
|
case "AssignmentPattern":
|
||
|
this.checkLValPattern(expr.left, bindingType, checkClashes);
|
||
|
break;
|
||
|
case "RestElement":
|
||
|
this.checkLValPattern(expr.argument, bindingType, checkClashes);
|
||
|
break;
|
||
|
default:
|
||
|
this.checkLValPattern(expr, bindingType, checkClashes);
|
||
|
}
|
||
|
};
|
||
|
var TokContext = function TokContext2(token, isExpr, preserveSpace, override, generator) {
|
||
|
this.token = token;
|
||
|
this.isExpr = !!isExpr;
|
||
|
this.preserveSpace = !!preserveSpace;
|
||
|
this.override = override;
|
||
|
this.generator = !!generator;
|
||
|
};
|
||
|
var types = {
|
||
|
b_stat: new TokContext("{", false),
|
||
|
b_expr: new TokContext("{", true),
|
||
|
b_tmpl: new TokContext("${", false),
|
||
|
p_stat: new TokContext("(", false),
|
||
|
p_expr: new TokContext("(", true),
|
||
|
q_tmpl: new TokContext("`", true, true, function(p) {
|
||
|
return p.tryReadTemplateToken();
|
||
|
}),
|
||
|
f_stat: new TokContext("function", false),
|
||
|
f_expr: new TokContext("function", true),
|
||
|
f_expr_gen: new TokContext("function", true, false, null, true),
|
||
|
f_gen: new TokContext("function", false, false, null, true)
|
||
|
};
|
||
|
var pp$6 = Parser.prototype;
|
||
|
pp$6.initialContext = function() {
|
||
|
return [types.b_stat];
|
||
|
};
|
||
|
pp$6.curContext = function() {
|
||
|
return this.context[this.context.length - 1];
|
||
|
};
|
||
|
pp$6.braceIsBlock = function(prevType) {
|
||
|
var parent = this.curContext();
|
||
|
if (parent === types.f_expr || parent === types.f_stat) {
|
||
|
return true;
|
||
|
}
|
||
|
if (prevType === types$1.colon && (parent === types.b_stat || parent === types.b_expr)) {
|
||
|
return !parent.isExpr;
|
||
|
}
|
||
|
if (prevType === types$1._return || prevType === types$1.name && this.exprAllowed) {
|
||
|
return lineBreak.test(this.input.slice(this.lastTokEnd, this.start));
|
||
|
}
|
||
|
if (prevType === types$1._else || prevType === types$1.semi || prevType === types$1.eof || prevType === types$1.parenR || prevType === types$1.arrow) {
|
||
|
return true;
|
||
|
}
|
||
|
if (prevType === types$1.braceL) {
|
||
|
return parent === types.b_stat;
|
||
|
}
|
||
|
if (prevType === types$1._var || prevType === types$1._const || prevType === types$1.name) {
|
||
|
return false;
|
||
|
}
|
||
|
return !this.exprAllowed;
|
||
|
};
|
||
|
pp$6.inGeneratorContext = function() {
|
||
|
for (var i = this.context.length - 1; i >= 1; i--) {
|
||
|
var context = this.context[i];
|
||
|
if (context.token === "function") {
|
||
|
return context.generator;
|
||
|
}
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$6.updateContext = function(prevType) {
|
||
|
var update, type = this.type;
|
||
|
if (type.keyword && prevType === types$1.dot) {
|
||
|
this.exprAllowed = false;
|
||
|
} else if (update = type.updateContext) {
|
||
|
update.call(this, prevType);
|
||
|
} else {
|
||
|
this.exprAllowed = type.beforeExpr;
|
||
|
}
|
||
|
};
|
||
|
pp$6.overrideContext = function(tokenCtx) {
|
||
|
if (this.curContext() !== tokenCtx) {
|
||
|
this.context[this.context.length - 1] = tokenCtx;
|
||
|
}
|
||
|
};
|
||
|
types$1.parenR.updateContext = types$1.braceR.updateContext = function() {
|
||
|
if (this.context.length === 1) {
|
||
|
this.exprAllowed = true;
|
||
|
return;
|
||
|
}
|
||
|
var out = this.context.pop();
|
||
|
if (out === types.b_stat && this.curContext().token === "function") {
|
||
|
out = this.context.pop();
|
||
|
}
|
||
|
this.exprAllowed = !out.isExpr;
|
||
|
};
|
||
|
types$1.braceL.updateContext = function(prevType) {
|
||
|
this.context.push(this.braceIsBlock(prevType) ? types.b_stat : types.b_expr);
|
||
|
this.exprAllowed = true;
|
||
|
};
|
||
|
types$1.dollarBraceL.updateContext = function() {
|
||
|
this.context.push(types.b_tmpl);
|
||
|
this.exprAllowed = true;
|
||
|
};
|
||
|
types$1.parenL.updateContext = function(prevType) {
|
||
|
var statementParens = prevType === types$1._if || prevType === types$1._for || prevType === types$1._with || prevType === types$1._while;
|
||
|
this.context.push(statementParens ? types.p_stat : types.p_expr);
|
||
|
this.exprAllowed = true;
|
||
|
};
|
||
|
types$1.incDec.updateContext = function() {
|
||
|
};
|
||
|
types$1._function.updateContext = types$1._class.updateContext = function(prevType) {
|
||
|
if (prevType.beforeExpr && prevType !== types$1._else && !(prevType === types$1.semi && this.curContext() !== types.p_stat) && !(prevType === types$1._return && lineBreak.test(this.input.slice(this.lastTokEnd, this.start))) && !((prevType === types$1.colon || prevType === types$1.braceL) && this.curContext() === types.b_stat)) {
|
||
|
this.context.push(types.f_expr);
|
||
|
} else {
|
||
|
this.context.push(types.f_stat);
|
||
|
}
|
||
|
this.exprAllowed = false;
|
||
|
};
|
||
|
types$1.backQuote.updateContext = function() {
|
||
|
if (this.curContext() === types.q_tmpl) {
|
||
|
this.context.pop();
|
||
|
} else {
|
||
|
this.context.push(types.q_tmpl);
|
||
|
}
|
||
|
this.exprAllowed = false;
|
||
|
};
|
||
|
types$1.star.updateContext = function(prevType) {
|
||
|
if (prevType === types$1._function) {
|
||
|
var index = this.context.length - 1;
|
||
|
if (this.context[index] === types.f_expr) {
|
||
|
this.context[index] = types.f_expr_gen;
|
||
|
} else {
|
||
|
this.context[index] = types.f_gen;
|
||
|
}
|
||
|
}
|
||
|
this.exprAllowed = true;
|
||
|
};
|
||
|
types$1.name.updateContext = function(prevType) {
|
||
|
var allowed = false;
|
||
|
if (this.options.ecmaVersion >= 6 && prevType !== types$1.dot) {
|
||
|
if (this.value === "of" && !this.exprAllowed || this.value === "yield" && this.inGeneratorContext()) {
|
||
|
allowed = true;
|
||
|
}
|
||
|
}
|
||
|
this.exprAllowed = allowed;
|
||
|
};
|
||
|
var pp$5 = Parser.prototype;
|
||
|
pp$5.checkPropClash = function(prop, propHash, refDestructuringErrors) {
|
||
|
if (this.options.ecmaVersion >= 9 && prop.type === "SpreadElement") {
|
||
|
return;
|
||
|
}
|
||
|
if (this.options.ecmaVersion >= 6 && (prop.computed || prop.method || prop.shorthand)) {
|
||
|
return;
|
||
|
}
|
||
|
var key = prop.key;
|
||
|
var name;
|
||
|
switch (key.type) {
|
||
|
case "Identifier":
|
||
|
name = key.name;
|
||
|
break;
|
||
|
case "Literal":
|
||
|
name = String(key.value);
|
||
|
break;
|
||
|
default:
|
||
|
return;
|
||
|
}
|
||
|
var kind = prop.kind;
|
||
|
if (this.options.ecmaVersion >= 6) {
|
||
|
if (name === "__proto__" && kind === "init") {
|
||
|
if (propHash.proto) {
|
||
|
if (refDestructuringErrors) {
|
||
|
if (refDestructuringErrors.doubleProto < 0) {
|
||
|
refDestructuringErrors.doubleProto = key.start;
|
||
|
}
|
||
|
} else {
|
||
|
this.raiseRecoverable(key.start, "Redefinition of __proto__ property");
|
||
|
}
|
||
|
}
|
||
|
propHash.proto = true;
|
||
|
}
|
||
|
return;
|
||
|
}
|
||
|
name = "$" + name;
|
||
|
var other = propHash[name];
|
||
|
if (other) {
|
||
|
var redefinition;
|
||
|
if (kind === "init") {
|
||
|
redefinition = this.strict && other.init || other.get || other.set;
|
||
|
} else {
|
||
|
redefinition = other.init || other[kind];
|
||
|
}
|
||
|
if (redefinition) {
|
||
|
this.raiseRecoverable(key.start, "Redefinition of property");
|
||
|
}
|
||
|
} else {
|
||
|
other = propHash[name] = {
|
||
|
init: false,
|
||
|
get: false,
|
||
|
set: false
|
||
|
};
|
||
|
}
|
||
|
other[kind] = true;
|
||
|
};
|
||
|
pp$5.parseExpression = function(forInit, refDestructuringErrors) {
|
||
|
var startPos = this.start, startLoc = this.startLoc;
|
||
|
var expr = this.parseMaybeAssign(forInit, refDestructuringErrors);
|
||
|
if (this.type === types$1.comma) {
|
||
|
var node = this.startNodeAt(startPos, startLoc);
|
||
|
node.expressions = [expr];
|
||
|
while (this.eat(types$1.comma)) {
|
||
|
node.expressions.push(this.parseMaybeAssign(forInit, refDestructuringErrors));
|
||
|
}
|
||
|
return this.finishNode(node, "SequenceExpression");
|
||
|
}
|
||
|
return expr;
|
||
|
};
|
||
|
pp$5.parseMaybeAssign = function(forInit, refDestructuringErrors, afterLeftParse) {
|
||
|
if (this.isContextual("yield")) {
|
||
|
if (this.inGenerator) {
|
||
|
return this.parseYield(forInit);
|
||
|
} else {
|
||
|
this.exprAllowed = false;
|
||
|
}
|
||
|
}
|
||
|
var ownDestructuringErrors = false, oldParenAssign = -1, oldTrailingComma = -1, oldDoubleProto = -1;
|
||
|
if (refDestructuringErrors) {
|
||
|
oldParenAssign = refDestructuringErrors.parenthesizedAssign;
|
||
|
oldTrailingComma = refDestructuringErrors.trailingComma;
|
||
|
oldDoubleProto = refDestructuringErrors.doubleProto;
|
||
|
refDestructuringErrors.parenthesizedAssign = refDestructuringErrors.trailingComma = -1;
|
||
|
} else {
|
||
|
refDestructuringErrors = new DestructuringErrors();
|
||
|
ownDestructuringErrors = true;
|
||
|
}
|
||
|
var startPos = this.start, startLoc = this.startLoc;
|
||
|
if (this.type === types$1.parenL || this.type === types$1.name) {
|
||
|
this.potentialArrowAt = this.start;
|
||
|
this.potentialArrowInForAwait = forInit === "await";
|
||
|
}
|
||
|
var left = this.parseMaybeConditional(forInit, refDestructuringErrors);
|
||
|
if (afterLeftParse) {
|
||
|
left = afterLeftParse.call(this, left, startPos, startLoc);
|
||
|
}
|
||
|
if (this.type.isAssign) {
|
||
|
var node = this.startNodeAt(startPos, startLoc);
|
||
|
node.operator = this.value;
|
||
|
if (this.type === types$1.eq) {
|
||
|
left = this.toAssignable(left, false, refDestructuringErrors);
|
||
|
}
|
||
|
if (!ownDestructuringErrors) {
|
||
|
refDestructuringErrors.parenthesizedAssign = refDestructuringErrors.trailingComma = refDestructuringErrors.doubleProto = -1;
|
||
|
}
|
||
|
if (refDestructuringErrors.shorthandAssign >= left.start) {
|
||
|
refDestructuringErrors.shorthandAssign = -1;
|
||
|
}
|
||
|
if (this.type === types$1.eq) {
|
||
|
this.checkLValPattern(left);
|
||
|
} else {
|
||
|
this.checkLValSimple(left);
|
||
|
}
|
||
|
node.left = left;
|
||
|
this.next();
|
||
|
node.right = this.parseMaybeAssign(forInit);
|
||
|
if (oldDoubleProto > -1) {
|
||
|
refDestructuringErrors.doubleProto = oldDoubleProto;
|
||
|
}
|
||
|
return this.finishNode(node, "AssignmentExpression");
|
||
|
} else {
|
||
|
if (ownDestructuringErrors) {
|
||
|
this.checkExpressionErrors(refDestructuringErrors, true);
|
||
|
}
|
||
|
}
|
||
|
if (oldParenAssign > -1) {
|
||
|
refDestructuringErrors.parenthesizedAssign = oldParenAssign;
|
||
|
}
|
||
|
if (oldTrailingComma > -1) {
|
||
|
refDestructuringErrors.trailingComma = oldTrailingComma;
|
||
|
}
|
||
|
return left;
|
||
|
};
|
||
|
pp$5.parseMaybeConditional = function(forInit, refDestructuringErrors) {
|
||
|
var startPos = this.start, startLoc = this.startLoc;
|
||
|
var expr = this.parseExprOps(forInit, refDestructuringErrors);
|
||
|
if (this.checkExpressionErrors(refDestructuringErrors)) {
|
||
|
return expr;
|
||
|
}
|
||
|
if (this.eat(types$1.question)) {
|
||
|
var node = this.startNodeAt(startPos, startLoc);
|
||
|
node.test = expr;
|
||
|
node.consequent = this.parseMaybeAssign();
|
||
|
this.expect(types$1.colon);
|
||
|
node.alternate = this.parseMaybeAssign(forInit);
|
||
|
return this.finishNode(node, "ConditionalExpression");
|
||
|
}
|
||
|
return expr;
|
||
|
};
|
||
|
pp$5.parseExprOps = function(forInit, refDestructuringErrors) {
|
||
|
var startPos = this.start, startLoc = this.startLoc;
|
||
|
var expr = this.parseMaybeUnary(refDestructuringErrors, false, false, forInit);
|
||
|
if (this.checkExpressionErrors(refDestructuringErrors)) {
|
||
|
return expr;
|
||
|
}
|
||
|
return expr.start === startPos && expr.type === "ArrowFunctionExpression" ? expr : this.parseExprOp(expr, startPos, startLoc, -1, forInit);
|
||
|
};
|
||
|
pp$5.parseExprOp = function(left, leftStartPos, leftStartLoc, minPrec, forInit) {
|
||
|
var prec = this.type.binop;
|
||
|
if (prec != null && (!forInit || this.type !== types$1._in)) {
|
||
|
if (prec > minPrec) {
|
||
|
var logical = this.type === types$1.logicalOR || this.type === types$1.logicalAND;
|
||
|
var coalesce = this.type === types$1.coalesce;
|
||
|
if (coalesce) {
|
||
|
prec = types$1.logicalAND.binop;
|
||
|
}
|
||
|
var op = this.value;
|
||
|
this.next();
|
||
|
var startPos = this.start, startLoc = this.startLoc;
|
||
|
var right = this.parseExprOp(this.parseMaybeUnary(null, false, false, forInit), startPos, startLoc, prec, forInit);
|
||
|
var node = this.buildBinary(leftStartPos, leftStartLoc, left, right, op, logical || coalesce);
|
||
|
if (logical && this.type === types$1.coalesce || coalesce && (this.type === types$1.logicalOR || this.type === types$1.logicalAND)) {
|
||
|
this.raiseRecoverable(this.start, "Logical expressions and coalesce expressions cannot be mixed. Wrap either by parentheses");
|
||
|
}
|
||
|
return this.parseExprOp(node, leftStartPos, leftStartLoc, minPrec, forInit);
|
||
|
}
|
||
|
}
|
||
|
return left;
|
||
|
};
|
||
|
pp$5.buildBinary = function(startPos, startLoc, left, right, op, logical) {
|
||
|
if (right.type === "PrivateIdentifier") {
|
||
|
this.raise(right.start, "Private identifier can only be left side of binary expression");
|
||
|
}
|
||
|
var node = this.startNodeAt(startPos, startLoc);
|
||
|
node.left = left;
|
||
|
node.operator = op;
|
||
|
node.right = right;
|
||
|
return this.finishNode(node, logical ? "LogicalExpression" : "BinaryExpression");
|
||
|
};
|
||
|
pp$5.parseMaybeUnary = function(refDestructuringErrors, sawUnary, incDec, forInit) {
|
||
|
var startPos = this.start, startLoc = this.startLoc, expr;
|
||
|
if (this.isContextual("await") && this.canAwait) {
|
||
|
expr = this.parseAwait(forInit);
|
||
|
sawUnary = true;
|
||
|
} else if (this.type.prefix) {
|
||
|
var node = this.startNode(), update = this.type === types$1.incDec;
|
||
|
node.operator = this.value;
|
||
|
node.prefix = true;
|
||
|
this.next();
|
||
|
node.argument = this.parseMaybeUnary(null, true, update, forInit);
|
||
|
this.checkExpressionErrors(refDestructuringErrors, true);
|
||
|
if (update) {
|
||
|
this.checkLValSimple(node.argument);
|
||
|
} else if (this.strict && node.operator === "delete" && node.argument.type === "Identifier") {
|
||
|
this.raiseRecoverable(node.start, "Deleting local variable in strict mode");
|
||
|
} else if (node.operator === "delete" && isPrivateFieldAccess(node.argument)) {
|
||
|
this.raiseRecoverable(node.start, "Private fields can not be deleted");
|
||
|
} else {
|
||
|
sawUnary = true;
|
||
|
}
|
||
|
expr = this.finishNode(node, update ? "UpdateExpression" : "UnaryExpression");
|
||
|
} else if (!sawUnary && this.type === types$1.privateId) {
|
||
|
if (forInit || this.privateNameStack.length === 0) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
expr = this.parsePrivateIdent();
|
||
|
if (this.type !== types$1._in) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
} else {
|
||
|
expr = this.parseExprSubscripts(refDestructuringErrors, forInit);
|
||
|
if (this.checkExpressionErrors(refDestructuringErrors)) {
|
||
|
return expr;
|
||
|
}
|
||
|
while (this.type.postfix && !this.canInsertSemicolon()) {
|
||
|
var node$1 = this.startNodeAt(startPos, startLoc);
|
||
|
node$1.operator = this.value;
|
||
|
node$1.prefix = false;
|
||
|
node$1.argument = expr;
|
||
|
this.checkLValSimple(expr);
|
||
|
this.next();
|
||
|
expr = this.finishNode(node$1, "UpdateExpression");
|
||
|
}
|
||
|
}
|
||
|
if (!incDec && this.eat(types$1.starstar)) {
|
||
|
if (sawUnary) {
|
||
|
this.unexpected(this.lastTokStart);
|
||
|
} else {
|
||
|
return this.buildBinary(startPos, startLoc, expr, this.parseMaybeUnary(null, false, false, forInit), "**", false);
|
||
|
}
|
||
|
} else {
|
||
|
return expr;
|
||
|
}
|
||
|
};
|
||
|
function isPrivateFieldAccess(node) {
|
||
|
return node.type === "MemberExpression" && node.property.type === "PrivateIdentifier" || node.type === "ChainExpression" && isPrivateFieldAccess(node.expression);
|
||
|
}
|
||
|
pp$5.parseExprSubscripts = function(refDestructuringErrors, forInit) {
|
||
|
var startPos = this.start, startLoc = this.startLoc;
|
||
|
var expr = this.parseExprAtom(refDestructuringErrors, forInit);
|
||
|
if (expr.type === "ArrowFunctionExpression" && this.input.slice(this.lastTokStart, this.lastTokEnd) !== ")") {
|
||
|
return expr;
|
||
|
}
|
||
|
var result = this.parseSubscripts(expr, startPos, startLoc, false, forInit);
|
||
|
if (refDestructuringErrors && result.type === "MemberExpression") {
|
||
|
if (refDestructuringErrors.parenthesizedAssign >= result.start) {
|
||
|
refDestructuringErrors.parenthesizedAssign = -1;
|
||
|
}
|
||
|
if (refDestructuringErrors.parenthesizedBind >= result.start) {
|
||
|
refDestructuringErrors.parenthesizedBind = -1;
|
||
|
}
|
||
|
if (refDestructuringErrors.trailingComma >= result.start) {
|
||
|
refDestructuringErrors.trailingComma = -1;
|
||
|
}
|
||
|
}
|
||
|
return result;
|
||
|
};
|
||
|
pp$5.parseSubscripts = function(base, startPos, startLoc, noCalls, forInit) {
|
||
|
var maybeAsyncArrow = this.options.ecmaVersion >= 8 && base.type === "Identifier" && base.name === "async" && this.lastTokEnd === base.end && !this.canInsertSemicolon() && base.end - base.start === 5 && this.potentialArrowAt === base.start;
|
||
|
var optionalChained = false;
|
||
|
while (true) {
|
||
|
var element = this.parseSubscript(base, startPos, startLoc, noCalls, maybeAsyncArrow, optionalChained, forInit);
|
||
|
if (element.optional) {
|
||
|
optionalChained = true;
|
||
|
}
|
||
|
if (element === base || element.type === "ArrowFunctionExpression") {
|
||
|
if (optionalChained) {
|
||
|
var chainNode = this.startNodeAt(startPos, startLoc);
|
||
|
chainNode.expression = element;
|
||
|
element = this.finishNode(chainNode, "ChainExpression");
|
||
|
}
|
||
|
return element;
|
||
|
}
|
||
|
base = element;
|
||
|
}
|
||
|
};
|
||
|
pp$5.parseSubscript = function(base, startPos, startLoc, noCalls, maybeAsyncArrow, optionalChained, forInit) {
|
||
|
var optionalSupported = this.options.ecmaVersion >= 11;
|
||
|
var optional = optionalSupported && this.eat(types$1.questionDot);
|
||
|
if (noCalls && optional) {
|
||
|
this.raise(this.lastTokStart, "Optional chaining cannot appear in the callee of new expressions");
|
||
|
}
|
||
|
var computed = this.eat(types$1.bracketL);
|
||
|
if (computed || optional && this.type !== types$1.parenL && this.type !== types$1.backQuote || this.eat(types$1.dot)) {
|
||
|
var node = this.startNodeAt(startPos, startLoc);
|
||
|
node.object = base;
|
||
|
if (computed) {
|
||
|
node.property = this.parseExpression();
|
||
|
this.expect(types$1.bracketR);
|
||
|
} else if (this.type === types$1.privateId && base.type !== "Super") {
|
||
|
node.property = this.parsePrivateIdent();
|
||
|
} else {
|
||
|
node.property = this.parseIdent(this.options.allowReserved !== "never");
|
||
|
}
|
||
|
node.computed = !!computed;
|
||
|
if (optionalSupported) {
|
||
|
node.optional = optional;
|
||
|
}
|
||
|
base = this.finishNode(node, "MemberExpression");
|
||
|
} else if (!noCalls && this.eat(types$1.parenL)) {
|
||
|
var refDestructuringErrors = new DestructuringErrors(), oldYieldPos = this.yieldPos, oldAwaitPos = this.awaitPos, oldAwaitIdentPos = this.awaitIdentPos;
|
||
|
this.yieldPos = 0;
|
||
|
this.awaitPos = 0;
|
||
|
this.awaitIdentPos = 0;
|
||
|
var exprList = this.parseExprList(types$1.parenR, this.options.ecmaVersion >= 8, false, refDestructuringErrors);
|
||
|
if (maybeAsyncArrow && !optional && !this.canInsertSemicolon() && this.eat(types$1.arrow)) {
|
||
|
this.checkPatternErrors(refDestructuringErrors, false);
|
||
|
this.checkYieldAwaitInDefaultParams();
|
||
|
if (this.awaitIdentPos > 0) {
|
||
|
this.raise(this.awaitIdentPos, "Cannot use 'await' as identifier inside an async function");
|
||
|
}
|
||
|
this.yieldPos = oldYieldPos;
|
||
|
this.awaitPos = oldAwaitPos;
|
||
|
this.awaitIdentPos = oldAwaitIdentPos;
|
||
|
return this.parseArrowExpression(this.startNodeAt(startPos, startLoc), exprList, true, forInit);
|
||
|
}
|
||
|
this.checkExpressionErrors(refDestructuringErrors, true);
|
||
|
this.yieldPos = oldYieldPos || this.yieldPos;
|
||
|
this.awaitPos = oldAwaitPos || this.awaitPos;
|
||
|
this.awaitIdentPos = oldAwaitIdentPos || this.awaitIdentPos;
|
||
|
var node$1 = this.startNodeAt(startPos, startLoc);
|
||
|
node$1.callee = base;
|
||
|
node$1.arguments = exprList;
|
||
|
if (optionalSupported) {
|
||
|
node$1.optional = optional;
|
||
|
}
|
||
|
base = this.finishNode(node$1, "CallExpression");
|
||
|
} else if (this.type === types$1.backQuote) {
|
||
|
if (optional || optionalChained) {
|
||
|
this.raise(this.start, "Optional chaining cannot appear in the tag of tagged template expressions");
|
||
|
}
|
||
|
var node$2 = this.startNodeAt(startPos, startLoc);
|
||
|
node$2.tag = base;
|
||
|
node$2.quasi = this.parseTemplate({ isTagged: true });
|
||
|
base = this.finishNode(node$2, "TaggedTemplateExpression");
|
||
|
}
|
||
|
return base;
|
||
|
};
|
||
|
pp$5.parseExprAtom = function(refDestructuringErrors, forInit) {
|
||
|
if (this.type === types$1.slash) {
|
||
|
this.readRegexp();
|
||
|
}
|
||
|
var node, canBeArrow = this.potentialArrowAt === this.start;
|
||
|
switch (this.type) {
|
||
|
case types$1._super:
|
||
|
if (!this.allowSuper) {
|
||
|
this.raise(this.start, "'super' keyword outside a method");
|
||
|
}
|
||
|
node = this.startNode();
|
||
|
this.next();
|
||
|
if (this.type === types$1.parenL && !this.allowDirectSuper) {
|
||
|
this.raise(node.start, "super() call outside constructor of a subclass");
|
||
|
}
|
||
|
if (this.type !== types$1.dot && this.type !== types$1.bracketL && this.type !== types$1.parenL) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
return this.finishNode(node, "Super");
|
||
|
case types$1._this:
|
||
|
node = this.startNode();
|
||
|
this.next();
|
||
|
return this.finishNode(node, "ThisExpression");
|
||
|
case types$1.name:
|
||
|
var startPos = this.start, startLoc = this.startLoc, containsEsc = this.containsEsc;
|
||
|
var id = this.parseIdent(false);
|
||
|
if (this.options.ecmaVersion >= 8 && !containsEsc && id.name === "async" && !this.canInsertSemicolon() && this.eat(types$1._function)) {
|
||
|
this.overrideContext(types.f_expr);
|
||
|
return this.parseFunction(this.startNodeAt(startPos, startLoc), 0, false, true, forInit);
|
||
|
}
|
||
|
if (canBeArrow && !this.canInsertSemicolon()) {
|
||
|
if (this.eat(types$1.arrow)) {
|
||
|
return this.parseArrowExpression(this.startNodeAt(startPos, startLoc), [id], false, forInit);
|
||
|
}
|
||
|
if (this.options.ecmaVersion >= 8 && id.name === "async" && this.type === types$1.name && !containsEsc && (!this.potentialArrowInForAwait || this.value !== "of" || this.containsEsc)) {
|
||
|
id = this.parseIdent(false);
|
||
|
if (this.canInsertSemicolon() || !this.eat(types$1.arrow)) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
return this.parseArrowExpression(this.startNodeAt(startPos, startLoc), [id], true, forInit);
|
||
|
}
|
||
|
}
|
||
|
return id;
|
||
|
case types$1.regexp:
|
||
|
var value = this.value;
|
||
|
node = this.parseLiteral(value.value);
|
||
|
node.regex = { pattern: value.pattern, flags: value.flags };
|
||
|
return node;
|
||
|
case types$1.num:
|
||
|
case types$1.string:
|
||
|
return this.parseLiteral(this.value);
|
||
|
case types$1._null:
|
||
|
case types$1._true:
|
||
|
case types$1._false:
|
||
|
node = this.startNode();
|
||
|
node.value = this.type === types$1._null ? null : this.type === types$1._true;
|
||
|
node.raw = this.type.keyword;
|
||
|
this.next();
|
||
|
return this.finishNode(node, "Literal");
|
||
|
case types$1.parenL:
|
||
|
var start = this.start, expr = this.parseParenAndDistinguishExpression(canBeArrow, forInit);
|
||
|
if (refDestructuringErrors) {
|
||
|
if (refDestructuringErrors.parenthesizedAssign < 0 && !this.isSimpleAssignTarget(expr)) {
|
||
|
refDestructuringErrors.parenthesizedAssign = start;
|
||
|
}
|
||
|
if (refDestructuringErrors.parenthesizedBind < 0) {
|
||
|
refDestructuringErrors.parenthesizedBind = start;
|
||
|
}
|
||
|
}
|
||
|
return expr;
|
||
|
case types$1.bracketL:
|
||
|
node = this.startNode();
|
||
|
this.next();
|
||
|
node.elements = this.parseExprList(types$1.bracketR, true, true, refDestructuringErrors);
|
||
|
return this.finishNode(node, "ArrayExpression");
|
||
|
case types$1.braceL:
|
||
|
this.overrideContext(types.b_expr);
|
||
|
return this.parseObj(false, refDestructuringErrors);
|
||
|
case types$1._function:
|
||
|
node = this.startNode();
|
||
|
this.next();
|
||
|
return this.parseFunction(node, 0);
|
||
|
case types$1._class:
|
||
|
return this.parseClass(this.startNode(), false);
|
||
|
case types$1._new:
|
||
|
return this.parseNew();
|
||
|
case types$1.backQuote:
|
||
|
return this.parseTemplate();
|
||
|
case types$1._import:
|
||
|
if (this.options.ecmaVersion >= 11) {
|
||
|
return this.parseExprImport();
|
||
|
} else {
|
||
|
return this.unexpected();
|
||
|
}
|
||
|
default:
|
||
|
this.unexpected();
|
||
|
}
|
||
|
};
|
||
|
pp$5.parseExprImport = function() {
|
||
|
var node = this.startNode();
|
||
|
if (this.containsEsc) {
|
||
|
this.raiseRecoverable(this.start, "Escape sequence in keyword import");
|
||
|
}
|
||
|
var meta = this.parseIdent(true);
|
||
|
switch (this.type) {
|
||
|
case types$1.parenL:
|
||
|
return this.parseDynamicImport(node);
|
||
|
case types$1.dot:
|
||
|
node.meta = meta;
|
||
|
return this.parseImportMeta(node);
|
||
|
default:
|
||
|
this.unexpected();
|
||
|
}
|
||
|
};
|
||
|
pp$5.parseDynamicImport = function(node) {
|
||
|
this.next();
|
||
|
node.source = this.parseMaybeAssign();
|
||
|
if (!this.eat(types$1.parenR)) {
|
||
|
var errorPos = this.start;
|
||
|
if (this.eat(types$1.comma) && this.eat(types$1.parenR)) {
|
||
|
this.raiseRecoverable(errorPos, "Trailing comma is not allowed in import()");
|
||
|
} else {
|
||
|
this.unexpected(errorPos);
|
||
|
}
|
||
|
}
|
||
|
return this.finishNode(node, "ImportExpression");
|
||
|
};
|
||
|
pp$5.parseImportMeta = function(node) {
|
||
|
this.next();
|
||
|
var containsEsc = this.containsEsc;
|
||
|
node.property = this.parseIdent(true);
|
||
|
if (node.property.name !== "meta") {
|
||
|
this.raiseRecoverable(node.property.start, "The only valid meta property for import is 'import.meta'");
|
||
|
}
|
||
|
if (containsEsc) {
|
||
|
this.raiseRecoverable(node.start, "'import.meta' must not contain escaped characters");
|
||
|
}
|
||
|
if (this.options.sourceType !== "module" && !this.options.allowImportExportEverywhere) {
|
||
|
this.raiseRecoverable(node.start, "Cannot use 'import.meta' outside a module");
|
||
|
}
|
||
|
return this.finishNode(node, "MetaProperty");
|
||
|
};
|
||
|
pp$5.parseLiteral = function(value) {
|
||
|
var node = this.startNode();
|
||
|
node.value = value;
|
||
|
node.raw = this.input.slice(this.start, this.end);
|
||
|
if (node.raw.charCodeAt(node.raw.length - 1) === 110) {
|
||
|
node.bigint = node.raw.slice(0, -1).replace(/_/g, "");
|
||
|
}
|
||
|
this.next();
|
||
|
return this.finishNode(node, "Literal");
|
||
|
};
|
||
|
pp$5.parseParenExpression = function() {
|
||
|
this.expect(types$1.parenL);
|
||
|
var val = this.parseExpression();
|
||
|
this.expect(types$1.parenR);
|
||
|
return val;
|
||
|
};
|
||
|
pp$5.parseParenAndDistinguishExpression = function(canBeArrow, forInit) {
|
||
|
var startPos = this.start, startLoc = this.startLoc, val, allowTrailingComma = this.options.ecmaVersion >= 8;
|
||
|
if (this.options.ecmaVersion >= 6) {
|
||
|
this.next();
|
||
|
var innerStartPos = this.start, innerStartLoc = this.startLoc;
|
||
|
var exprList = [], first = true, lastIsComma = false;
|
||
|
var refDestructuringErrors = new DestructuringErrors(), oldYieldPos = this.yieldPos, oldAwaitPos = this.awaitPos, spreadStart;
|
||
|
this.yieldPos = 0;
|
||
|
this.awaitPos = 0;
|
||
|
while (this.type !== types$1.parenR) {
|
||
|
first ? first = false : this.expect(types$1.comma);
|
||
|
if (allowTrailingComma && this.afterTrailingComma(types$1.parenR, true)) {
|
||
|
lastIsComma = true;
|
||
|
break;
|
||
|
} else if (this.type === types$1.ellipsis) {
|
||
|
spreadStart = this.start;
|
||
|
exprList.push(this.parseParenItem(this.parseRestBinding()));
|
||
|
if (this.type === types$1.comma) {
|
||
|
this.raise(this.start, "Comma is not permitted after the rest element");
|
||
|
}
|
||
|
break;
|
||
|
} else {
|
||
|
exprList.push(this.parseMaybeAssign(false, refDestructuringErrors, this.parseParenItem));
|
||
|
}
|
||
|
}
|
||
|
var innerEndPos = this.lastTokEnd, innerEndLoc = this.lastTokEndLoc;
|
||
|
this.expect(types$1.parenR);
|
||
|
if (canBeArrow && !this.canInsertSemicolon() && this.eat(types$1.arrow)) {
|
||
|
this.checkPatternErrors(refDestructuringErrors, false);
|
||
|
this.checkYieldAwaitInDefaultParams();
|
||
|
this.yieldPos = oldYieldPos;
|
||
|
this.awaitPos = oldAwaitPos;
|
||
|
return this.parseParenArrowList(startPos, startLoc, exprList, forInit);
|
||
|
}
|
||
|
if (!exprList.length || lastIsComma) {
|
||
|
this.unexpected(this.lastTokStart);
|
||
|
}
|
||
|
if (spreadStart) {
|
||
|
this.unexpected(spreadStart);
|
||
|
}
|
||
|
this.checkExpressionErrors(refDestructuringErrors, true);
|
||
|
this.yieldPos = oldYieldPos || this.yieldPos;
|
||
|
this.awaitPos = oldAwaitPos || this.awaitPos;
|
||
|
if (exprList.length > 1) {
|
||
|
val = this.startNodeAt(innerStartPos, innerStartLoc);
|
||
|
val.expressions = exprList;
|
||
|
this.finishNodeAt(val, "SequenceExpression", innerEndPos, innerEndLoc);
|
||
|
} else {
|
||
|
val = exprList[0];
|
||
|
}
|
||
|
} else {
|
||
|
val = this.parseParenExpression();
|
||
|
}
|
||
|
if (this.options.preserveParens) {
|
||
|
var par = this.startNodeAt(startPos, startLoc);
|
||
|
par.expression = val;
|
||
|
return this.finishNode(par, "ParenthesizedExpression");
|
||
|
} else {
|
||
|
return val;
|
||
|
}
|
||
|
};
|
||
|
pp$5.parseParenItem = function(item) {
|
||
|
return item;
|
||
|
};
|
||
|
pp$5.parseParenArrowList = function(startPos, startLoc, exprList, forInit) {
|
||
|
return this.parseArrowExpression(this.startNodeAt(startPos, startLoc), exprList, false, forInit);
|
||
|
};
|
||
|
var empty = [];
|
||
|
pp$5.parseNew = function() {
|
||
|
if (this.containsEsc) {
|
||
|
this.raiseRecoverable(this.start, "Escape sequence in keyword new");
|
||
|
}
|
||
|
var node = this.startNode();
|
||
|
var meta = this.parseIdent(true);
|
||
|
if (this.options.ecmaVersion >= 6 && this.eat(types$1.dot)) {
|
||
|
node.meta = meta;
|
||
|
var containsEsc = this.containsEsc;
|
||
|
node.property = this.parseIdent(true);
|
||
|
if (node.property.name !== "target") {
|
||
|
this.raiseRecoverable(node.property.start, "The only valid meta property for new is 'new.target'");
|
||
|
}
|
||
|
if (containsEsc) {
|
||
|
this.raiseRecoverable(node.start, "'new.target' must not contain escaped characters");
|
||
|
}
|
||
|
if (!this.allowNewDotTarget) {
|
||
|
this.raiseRecoverable(node.start, "'new.target' can only be used in functions and class static block");
|
||
|
}
|
||
|
return this.finishNode(node, "MetaProperty");
|
||
|
}
|
||
|
var startPos = this.start, startLoc = this.startLoc, isImport = this.type === types$1._import;
|
||
|
node.callee = this.parseSubscripts(this.parseExprAtom(), startPos, startLoc, true, false);
|
||
|
if (isImport && node.callee.type === "ImportExpression") {
|
||
|
this.raise(startPos, "Cannot use new with import()");
|
||
|
}
|
||
|
if (this.eat(types$1.parenL)) {
|
||
|
node.arguments = this.parseExprList(types$1.parenR, this.options.ecmaVersion >= 8, false);
|
||
|
} else {
|
||
|
node.arguments = empty;
|
||
|
}
|
||
|
return this.finishNode(node, "NewExpression");
|
||
|
};
|
||
|
pp$5.parseTemplateElement = function(ref2) {
|
||
|
var isTagged = ref2.isTagged;
|
||
|
var elem = this.startNode();
|
||
|
if (this.type === types$1.invalidTemplate) {
|
||
|
if (!isTagged) {
|
||
|
this.raiseRecoverable(this.start, "Bad escape sequence in untagged template literal");
|
||
|
}
|
||
|
elem.value = {
|
||
|
raw: this.value,
|
||
|
cooked: null
|
||
|
};
|
||
|
} else {
|
||
|
elem.value = {
|
||
|
raw: this.input.slice(this.start, this.end).replace(/\r\n?/g, "\n"),
|
||
|
cooked: this.value
|
||
|
};
|
||
|
}
|
||
|
this.next();
|
||
|
elem.tail = this.type === types$1.backQuote;
|
||
|
return this.finishNode(elem, "TemplateElement");
|
||
|
};
|
||
|
pp$5.parseTemplate = function(ref2) {
|
||
|
if (ref2 === void 0)
|
||
|
ref2 = {};
|
||
|
var isTagged = ref2.isTagged;
|
||
|
if (isTagged === void 0)
|
||
|
isTagged = false;
|
||
|
var node = this.startNode();
|
||
|
this.next();
|
||
|
node.expressions = [];
|
||
|
var curElt = this.parseTemplateElement({ isTagged });
|
||
|
node.quasis = [curElt];
|
||
|
while (!curElt.tail) {
|
||
|
if (this.type === types$1.eof) {
|
||
|
this.raise(this.pos, "Unterminated template literal");
|
||
|
}
|
||
|
this.expect(types$1.dollarBraceL);
|
||
|
node.expressions.push(this.parseExpression());
|
||
|
this.expect(types$1.braceR);
|
||
|
node.quasis.push(curElt = this.parseTemplateElement({ isTagged }));
|
||
|
}
|
||
|
this.next();
|
||
|
return this.finishNode(node, "TemplateLiteral");
|
||
|
};
|
||
|
pp$5.isAsyncProp = function(prop) {
|
||
|
return !prop.computed && prop.key.type === "Identifier" && prop.key.name === "async" && (this.type === types$1.name || this.type === types$1.num || this.type === types$1.string || this.type === types$1.bracketL || this.type.keyword || this.options.ecmaVersion >= 9 && this.type === types$1.star) && !lineBreak.test(this.input.slice(this.lastTokEnd, this.start));
|
||
|
};
|
||
|
pp$5.parseObj = function(isPattern, refDestructuringErrors) {
|
||
|
var node = this.startNode(), first = true, propHash = {};
|
||
|
node.properties = [];
|
||
|
this.next();
|
||
|
while (!this.eat(types$1.braceR)) {
|
||
|
if (!first) {
|
||
|
this.expect(types$1.comma);
|
||
|
if (this.options.ecmaVersion >= 5 && this.afterTrailingComma(types$1.braceR)) {
|
||
|
break;
|
||
|
}
|
||
|
} else {
|
||
|
first = false;
|
||
|
}
|
||
|
var prop = this.parseProperty(isPattern, refDestructuringErrors);
|
||
|
if (!isPattern) {
|
||
|
this.checkPropClash(prop, propHash, refDestructuringErrors);
|
||
|
}
|
||
|
node.properties.push(prop);
|
||
|
}
|
||
|
return this.finishNode(node, isPattern ? "ObjectPattern" : "ObjectExpression");
|
||
|
};
|
||
|
pp$5.parseProperty = function(isPattern, refDestructuringErrors) {
|
||
|
var prop = this.startNode(), isGenerator, isAsync, startPos, startLoc;
|
||
|
if (this.options.ecmaVersion >= 9 && this.eat(types$1.ellipsis)) {
|
||
|
if (isPattern) {
|
||
|
prop.argument = this.parseIdent(false);
|
||
|
if (this.type === types$1.comma) {
|
||
|
this.raise(this.start, "Comma is not permitted after the rest element");
|
||
|
}
|
||
|
return this.finishNode(prop, "RestElement");
|
||
|
}
|
||
|
prop.argument = this.parseMaybeAssign(false, refDestructuringErrors);
|
||
|
if (this.type === types$1.comma && refDestructuringErrors && refDestructuringErrors.trailingComma < 0) {
|
||
|
refDestructuringErrors.trailingComma = this.start;
|
||
|
}
|
||
|
return this.finishNode(prop, "SpreadElement");
|
||
|
}
|
||
|
if (this.options.ecmaVersion >= 6) {
|
||
|
prop.method = false;
|
||
|
prop.shorthand = false;
|
||
|
if (isPattern || refDestructuringErrors) {
|
||
|
startPos = this.start;
|
||
|
startLoc = this.startLoc;
|
||
|
}
|
||
|
if (!isPattern) {
|
||
|
isGenerator = this.eat(types$1.star);
|
||
|
}
|
||
|
}
|
||
|
var containsEsc = this.containsEsc;
|
||
|
this.parsePropertyName(prop);
|
||
|
if (!isPattern && !containsEsc && this.options.ecmaVersion >= 8 && !isGenerator && this.isAsyncProp(prop)) {
|
||
|
isAsync = true;
|
||
|
isGenerator = this.options.ecmaVersion >= 9 && this.eat(types$1.star);
|
||
|
this.parsePropertyName(prop, refDestructuringErrors);
|
||
|
} else {
|
||
|
isAsync = false;
|
||
|
}
|
||
|
this.parsePropertyValue(prop, isPattern, isGenerator, isAsync, startPos, startLoc, refDestructuringErrors, containsEsc);
|
||
|
return this.finishNode(prop, "Property");
|
||
|
};
|
||
|
pp$5.parsePropertyValue = function(prop, isPattern, isGenerator, isAsync, startPos, startLoc, refDestructuringErrors, containsEsc) {
|
||
|
if ((isGenerator || isAsync) && this.type === types$1.colon) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
if (this.eat(types$1.colon)) {
|
||
|
prop.value = isPattern ? this.parseMaybeDefault(this.start, this.startLoc) : this.parseMaybeAssign(false, refDestructuringErrors);
|
||
|
prop.kind = "init";
|
||
|
} else if (this.options.ecmaVersion >= 6 && this.type === types$1.parenL) {
|
||
|
if (isPattern) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
prop.kind = "init";
|
||
|
prop.method = true;
|
||
|
prop.value = this.parseMethod(isGenerator, isAsync);
|
||
|
} else if (!isPattern && !containsEsc && this.options.ecmaVersion >= 5 && !prop.computed && prop.key.type === "Identifier" && (prop.key.name === "get" || prop.key.name === "set") && (this.type !== types$1.comma && this.type !== types$1.braceR && this.type !== types$1.eq)) {
|
||
|
if (isGenerator || isAsync) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
prop.kind = prop.key.name;
|
||
|
this.parsePropertyName(prop);
|
||
|
prop.value = this.parseMethod(false);
|
||
|
var paramCount = prop.kind === "get" ? 0 : 1;
|
||
|
if (prop.value.params.length !== paramCount) {
|
||
|
var start = prop.value.start;
|
||
|
if (prop.kind === "get") {
|
||
|
this.raiseRecoverable(start, "getter should have no params");
|
||
|
} else {
|
||
|
this.raiseRecoverable(start, "setter should have exactly one param");
|
||
|
}
|
||
|
} else {
|
||
|
if (prop.kind === "set" && prop.value.params[0].type === "RestElement") {
|
||
|
this.raiseRecoverable(prop.value.params[0].start, "Setter cannot use rest params");
|
||
|
}
|
||
|
}
|
||
|
} else if (this.options.ecmaVersion >= 6 && !prop.computed && prop.key.type === "Identifier") {
|
||
|
if (isGenerator || isAsync) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
this.checkUnreserved(prop.key);
|
||
|
if (prop.key.name === "await" && !this.awaitIdentPos) {
|
||
|
this.awaitIdentPos = startPos;
|
||
|
}
|
||
|
prop.kind = "init";
|
||
|
if (isPattern) {
|
||
|
prop.value = this.parseMaybeDefault(startPos, startLoc, this.copyNode(prop.key));
|
||
|
} else if (this.type === types$1.eq && refDestructuringErrors) {
|
||
|
if (refDestructuringErrors.shorthandAssign < 0) {
|
||
|
refDestructuringErrors.shorthandAssign = this.start;
|
||
|
}
|
||
|
prop.value = this.parseMaybeDefault(startPos, startLoc, this.copyNode(prop.key));
|
||
|
} else {
|
||
|
prop.value = this.copyNode(prop.key);
|
||
|
}
|
||
|
prop.shorthand = true;
|
||
|
} else {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
};
|
||
|
pp$5.parsePropertyName = function(prop) {
|
||
|
if (this.options.ecmaVersion >= 6) {
|
||
|
if (this.eat(types$1.bracketL)) {
|
||
|
prop.computed = true;
|
||
|
prop.key = this.parseMaybeAssign();
|
||
|
this.expect(types$1.bracketR);
|
||
|
return prop.key;
|
||
|
} else {
|
||
|
prop.computed = false;
|
||
|
}
|
||
|
}
|
||
|
return prop.key = this.type === types$1.num || this.type === types$1.string ? this.parseExprAtom() : this.parseIdent(this.options.allowReserved !== "never");
|
||
|
};
|
||
|
pp$5.initFunction = function(node) {
|
||
|
node.id = null;
|
||
|
if (this.options.ecmaVersion >= 6) {
|
||
|
node.generator = node.expression = false;
|
||
|
}
|
||
|
if (this.options.ecmaVersion >= 8) {
|
||
|
node.async = false;
|
||
|
}
|
||
|
};
|
||
|
pp$5.parseMethod = function(isGenerator, isAsync, allowDirectSuper) {
|
||
|
var node = this.startNode(), oldYieldPos = this.yieldPos, oldAwaitPos = this.awaitPos, oldAwaitIdentPos = this.awaitIdentPos;
|
||
|
this.initFunction(node);
|
||
|
if (this.options.ecmaVersion >= 6) {
|
||
|
node.generator = isGenerator;
|
||
|
}
|
||
|
if (this.options.ecmaVersion >= 8) {
|
||
|
node.async = !!isAsync;
|
||
|
}
|
||
|
this.yieldPos = 0;
|
||
|
this.awaitPos = 0;
|
||
|
this.awaitIdentPos = 0;
|
||
|
this.enterScope(functionFlags(isAsync, node.generator) | SCOPE_SUPER | (allowDirectSuper ? SCOPE_DIRECT_SUPER : 0));
|
||
|
this.expect(types$1.parenL);
|
||
|
node.params = this.parseBindingList(types$1.parenR, false, this.options.ecmaVersion >= 8);
|
||
|
this.checkYieldAwaitInDefaultParams();
|
||
|
this.parseFunctionBody(node, false, true, false);
|
||
|
this.yieldPos = oldYieldPos;
|
||
|
this.awaitPos = oldAwaitPos;
|
||
|
this.awaitIdentPos = oldAwaitIdentPos;
|
||
|
return this.finishNode(node, "FunctionExpression");
|
||
|
};
|
||
|
pp$5.parseArrowExpression = function(node, params, isAsync, forInit) {
|
||
|
var oldYieldPos = this.yieldPos, oldAwaitPos = this.awaitPos, oldAwaitIdentPos = this.awaitIdentPos;
|
||
|
this.enterScope(functionFlags(isAsync, false) | SCOPE_ARROW);
|
||
|
this.initFunction(node);
|
||
|
if (this.options.ecmaVersion >= 8) {
|
||
|
node.async = !!isAsync;
|
||
|
}
|
||
|
this.yieldPos = 0;
|
||
|
this.awaitPos = 0;
|
||
|
this.awaitIdentPos = 0;
|
||
|
node.params = this.toAssignableList(params, true);
|
||
|
this.parseFunctionBody(node, true, false, forInit);
|
||
|
this.yieldPos = oldYieldPos;
|
||
|
this.awaitPos = oldAwaitPos;
|
||
|
this.awaitIdentPos = oldAwaitIdentPos;
|
||
|
return this.finishNode(node, "ArrowFunctionExpression");
|
||
|
};
|
||
|
pp$5.parseFunctionBody = function(node, isArrowFunction, isMethod, forInit) {
|
||
|
var isExpression = isArrowFunction && this.type !== types$1.braceL;
|
||
|
var oldStrict = this.strict, useStrict = false;
|
||
|
if (isExpression) {
|
||
|
node.body = this.parseMaybeAssign(forInit);
|
||
|
node.expression = true;
|
||
|
this.checkParams(node, false);
|
||
|
} else {
|
||
|
var nonSimple = this.options.ecmaVersion >= 7 && !this.isSimpleParamList(node.params);
|
||
|
if (!oldStrict || nonSimple) {
|
||
|
useStrict = this.strictDirective(this.end);
|
||
|
if (useStrict && nonSimple) {
|
||
|
this.raiseRecoverable(node.start, "Illegal 'use strict' directive in function with non-simple parameter list");
|
||
|
}
|
||
|
}
|
||
|
var oldLabels = this.labels;
|
||
|
this.labels = [];
|
||
|
if (useStrict) {
|
||
|
this.strict = true;
|
||
|
}
|
||
|
this.checkParams(node, !oldStrict && !useStrict && !isArrowFunction && !isMethod && this.isSimpleParamList(node.params));
|
||
|
if (this.strict && node.id) {
|
||
|
this.checkLValSimple(node.id, BIND_OUTSIDE);
|
||
|
}
|
||
|
node.body = this.parseBlock(false, void 0, useStrict && !oldStrict);
|
||
|
node.expression = false;
|
||
|
this.adaptDirectivePrologue(node.body.body);
|
||
|
this.labels = oldLabels;
|
||
|
}
|
||
|
this.exitScope();
|
||
|
};
|
||
|
pp$5.isSimpleParamList = function(params) {
|
||
|
for (var i = 0, list = params; i < list.length; i += 1) {
|
||
|
var param = list[i];
|
||
|
if (param.type !== "Identifier") {
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
return true;
|
||
|
};
|
||
|
pp$5.checkParams = function(node, allowDuplicates) {
|
||
|
var nameHash = /* @__PURE__ */ Object.create(null);
|
||
|
for (var i = 0, list = node.params; i < list.length; i += 1) {
|
||
|
var param = list[i];
|
||
|
this.checkLValInnerPattern(param, BIND_VAR, allowDuplicates ? null : nameHash);
|
||
|
}
|
||
|
};
|
||
|
pp$5.parseExprList = function(close, allowTrailingComma, allowEmpty, refDestructuringErrors) {
|
||
|
var elts = [], first = true;
|
||
|
while (!this.eat(close)) {
|
||
|
if (!first) {
|
||
|
this.expect(types$1.comma);
|
||
|
if (allowTrailingComma && this.afterTrailingComma(close)) {
|
||
|
break;
|
||
|
}
|
||
|
} else {
|
||
|
first = false;
|
||
|
}
|
||
|
var elt = void 0;
|
||
|
if (allowEmpty && this.type === types$1.comma) {
|
||
|
elt = null;
|
||
|
} else if (this.type === types$1.ellipsis) {
|
||
|
elt = this.parseSpread(refDestructuringErrors);
|
||
|
if (refDestructuringErrors && this.type === types$1.comma && refDestructuringErrors.trailingComma < 0) {
|
||
|
refDestructuringErrors.trailingComma = this.start;
|
||
|
}
|
||
|
} else {
|
||
|
elt = this.parseMaybeAssign(false, refDestructuringErrors);
|
||
|
}
|
||
|
elts.push(elt);
|
||
|
}
|
||
|
return elts;
|
||
|
};
|
||
|
pp$5.checkUnreserved = function(ref2) {
|
||
|
var start = ref2.start;
|
||
|
var end = ref2.end;
|
||
|
var name = ref2.name;
|
||
|
if (this.inGenerator && name === "yield") {
|
||
|
this.raiseRecoverable(start, "Cannot use 'yield' as identifier inside a generator");
|
||
|
}
|
||
|
if (this.inAsync && name === "await") {
|
||
|
this.raiseRecoverable(start, "Cannot use 'await' as identifier inside an async function");
|
||
|
}
|
||
|
if (this.currentThisScope().inClassFieldInit && name === "arguments") {
|
||
|
this.raiseRecoverable(start, "Cannot use 'arguments' in class field initializer");
|
||
|
}
|
||
|
if (this.inClassStaticBlock && (name === "arguments" || name === "await")) {
|
||
|
this.raise(start, "Cannot use " + name + " in class static initialization block");
|
||
|
}
|
||
|
if (this.keywords.test(name)) {
|
||
|
this.raise(start, "Unexpected keyword '" + name + "'");
|
||
|
}
|
||
|
if (this.options.ecmaVersion < 6 && this.input.slice(start, end).indexOf("\\") !== -1) {
|
||
|
return;
|
||
|
}
|
||
|
var re = this.strict ? this.reservedWordsStrict : this.reservedWords;
|
||
|
if (re.test(name)) {
|
||
|
if (!this.inAsync && name === "await") {
|
||
|
this.raiseRecoverable(start, "Cannot use keyword 'await' outside an async function");
|
||
|
}
|
||
|
this.raiseRecoverable(start, "The keyword '" + name + "' is reserved");
|
||
|
}
|
||
|
};
|
||
|
pp$5.parseIdent = function(liberal, isBinding) {
|
||
|
var node = this.startNode();
|
||
|
if (this.type === types$1.name) {
|
||
|
node.name = this.value;
|
||
|
} else if (this.type.keyword) {
|
||
|
node.name = this.type.keyword;
|
||
|
if ((node.name === "class" || node.name === "function") && (this.lastTokEnd !== this.lastTokStart + 1 || this.input.charCodeAt(this.lastTokStart) !== 46)) {
|
||
|
this.context.pop();
|
||
|
}
|
||
|
} else {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
this.next(!!liberal);
|
||
|
this.finishNode(node, "Identifier");
|
||
|
if (!liberal) {
|
||
|
this.checkUnreserved(node);
|
||
|
if (node.name === "await" && !this.awaitIdentPos) {
|
||
|
this.awaitIdentPos = node.start;
|
||
|
}
|
||
|
}
|
||
|
return node;
|
||
|
};
|
||
|
pp$5.parsePrivateIdent = function() {
|
||
|
var node = this.startNode();
|
||
|
if (this.type === types$1.privateId) {
|
||
|
node.name = this.value;
|
||
|
} else {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
this.next();
|
||
|
this.finishNode(node, "PrivateIdentifier");
|
||
|
if (this.privateNameStack.length === 0) {
|
||
|
this.raise(node.start, "Private field '#" + node.name + "' must be declared in an enclosing class");
|
||
|
} else {
|
||
|
this.privateNameStack[this.privateNameStack.length - 1].used.push(node);
|
||
|
}
|
||
|
return node;
|
||
|
};
|
||
|
pp$5.parseYield = function(forInit) {
|
||
|
if (!this.yieldPos) {
|
||
|
this.yieldPos = this.start;
|
||
|
}
|
||
|
var node = this.startNode();
|
||
|
this.next();
|
||
|
if (this.type === types$1.semi || this.canInsertSemicolon() || this.type !== types$1.star && !this.type.startsExpr) {
|
||
|
node.delegate = false;
|
||
|
node.argument = null;
|
||
|
} else {
|
||
|
node.delegate = this.eat(types$1.star);
|
||
|
node.argument = this.parseMaybeAssign(forInit);
|
||
|
}
|
||
|
return this.finishNode(node, "YieldExpression");
|
||
|
};
|
||
|
pp$5.parseAwait = function(forInit) {
|
||
|
if (!this.awaitPos) {
|
||
|
this.awaitPos = this.start;
|
||
|
}
|
||
|
var node = this.startNode();
|
||
|
this.next();
|
||
|
node.argument = this.parseMaybeUnary(null, true, false, forInit);
|
||
|
return this.finishNode(node, "AwaitExpression");
|
||
|
};
|
||
|
var pp$4 = Parser.prototype;
|
||
|
pp$4.raise = function(pos, message) {
|
||
|
var loc = getLineInfo(this.input, pos);
|
||
|
message += " (" + loc.line + ":" + loc.column + ")";
|
||
|
var err = new SyntaxError(message);
|
||
|
err.pos = pos;
|
||
|
err.loc = loc;
|
||
|
err.raisedAt = this.pos;
|
||
|
throw err;
|
||
|
};
|
||
|
pp$4.raiseRecoverable = pp$4.raise;
|
||
|
pp$4.curPosition = function() {
|
||
|
if (this.options.locations) {
|
||
|
return new Position(this.curLine, this.pos - this.lineStart);
|
||
|
}
|
||
|
};
|
||
|
var pp$3 = Parser.prototype;
|
||
|
var Scope = function Scope2(flags) {
|
||
|
this.flags = flags;
|
||
|
this.var = [];
|
||
|
this.lexical = [];
|
||
|
this.functions = [];
|
||
|
this.inClassFieldInit = false;
|
||
|
};
|
||
|
pp$3.enterScope = function(flags) {
|
||
|
this.scopeStack.push(new Scope(flags));
|
||
|
};
|
||
|
pp$3.exitScope = function() {
|
||
|
this.scopeStack.pop();
|
||
|
};
|
||
|
pp$3.treatFunctionsAsVarInScope = function(scope) {
|
||
|
return scope.flags & SCOPE_FUNCTION || !this.inModule && scope.flags & SCOPE_TOP;
|
||
|
};
|
||
|
pp$3.declareName = function(name, bindingType, pos) {
|
||
|
var redeclared = false;
|
||
|
if (bindingType === BIND_LEXICAL) {
|
||
|
var scope = this.currentScope();
|
||
|
redeclared = scope.lexical.indexOf(name) > -1 || scope.functions.indexOf(name) > -1 || scope.var.indexOf(name) > -1;
|
||
|
scope.lexical.push(name);
|
||
|
if (this.inModule && scope.flags & SCOPE_TOP) {
|
||
|
delete this.undefinedExports[name];
|
||
|
}
|
||
|
} else if (bindingType === BIND_SIMPLE_CATCH) {
|
||
|
var scope$1 = this.currentScope();
|
||
|
scope$1.lexical.push(name);
|
||
|
} else if (bindingType === BIND_FUNCTION) {
|
||
|
var scope$2 = this.currentScope();
|
||
|
if (this.treatFunctionsAsVar) {
|
||
|
redeclared = scope$2.lexical.indexOf(name) > -1;
|
||
|
} else {
|
||
|
redeclared = scope$2.lexical.indexOf(name) > -1 || scope$2.var.indexOf(name) > -1;
|
||
|
}
|
||
|
scope$2.functions.push(name);
|
||
|
} else {
|
||
|
for (var i = this.scopeStack.length - 1; i >= 0; --i) {
|
||
|
var scope$3 = this.scopeStack[i];
|
||
|
if (scope$3.lexical.indexOf(name) > -1 && !(scope$3.flags & SCOPE_SIMPLE_CATCH && scope$3.lexical[0] === name) || !this.treatFunctionsAsVarInScope(scope$3) && scope$3.functions.indexOf(name) > -1) {
|
||
|
redeclared = true;
|
||
|
break;
|
||
|
}
|
||
|
scope$3.var.push(name);
|
||
|
if (this.inModule && scope$3.flags & SCOPE_TOP) {
|
||
|
delete this.undefinedExports[name];
|
||
|
}
|
||
|
if (scope$3.flags & SCOPE_VAR) {
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if (redeclared) {
|
||
|
this.raiseRecoverable(pos, "Identifier '" + name + "' has already been declared");
|
||
|
}
|
||
|
};
|
||
|
pp$3.checkLocalExport = function(id) {
|
||
|
if (this.scopeStack[0].lexical.indexOf(id.name) === -1 && this.scopeStack[0].var.indexOf(id.name) === -1) {
|
||
|
this.undefinedExports[id.name] = id;
|
||
|
}
|
||
|
};
|
||
|
pp$3.currentScope = function() {
|
||
|
return this.scopeStack[this.scopeStack.length - 1];
|
||
|
};
|
||
|
pp$3.currentVarScope = function() {
|
||
|
for (var i = this.scopeStack.length - 1; ; i--) {
|
||
|
var scope = this.scopeStack[i];
|
||
|
if (scope.flags & SCOPE_VAR) {
|
||
|
return scope;
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
pp$3.currentThisScope = function() {
|
||
|
for (var i = this.scopeStack.length - 1; ; i--) {
|
||
|
var scope = this.scopeStack[i];
|
||
|
if (scope.flags & SCOPE_VAR && !(scope.flags & SCOPE_ARROW)) {
|
||
|
return scope;
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
var Node = function Node2(parser, pos, loc) {
|
||
|
this.type = "";
|
||
|
this.start = pos;
|
||
|
this.end = 0;
|
||
|
if (parser.options.locations) {
|
||
|
this.loc = new SourceLocation(parser, loc);
|
||
|
}
|
||
|
if (parser.options.directSourceFile) {
|
||
|
this.sourceFile = parser.options.directSourceFile;
|
||
|
}
|
||
|
if (parser.options.ranges) {
|
||
|
this.range = [pos, 0];
|
||
|
}
|
||
|
};
|
||
|
var pp$2 = Parser.prototype;
|
||
|
pp$2.startNode = function() {
|
||
|
return new Node(this, this.start, this.startLoc);
|
||
|
};
|
||
|
pp$2.startNodeAt = function(pos, loc) {
|
||
|
return new Node(this, pos, loc);
|
||
|
};
|
||
|
function finishNodeAt(node, type, pos, loc) {
|
||
|
node.type = type;
|
||
|
node.end = pos;
|
||
|
if (this.options.locations) {
|
||
|
node.loc.end = loc;
|
||
|
}
|
||
|
if (this.options.ranges) {
|
||
|
node.range[1] = pos;
|
||
|
}
|
||
|
return node;
|
||
|
}
|
||
|
pp$2.finishNode = function(node, type) {
|
||
|
return finishNodeAt.call(this, node, type, this.lastTokEnd, this.lastTokEndLoc);
|
||
|
};
|
||
|
pp$2.finishNodeAt = function(node, type, pos, loc) {
|
||
|
return finishNodeAt.call(this, node, type, pos, loc);
|
||
|
};
|
||
|
pp$2.copyNode = function(node) {
|
||
|
var newNode = new Node(this, node.start, this.startLoc);
|
||
|
for (var prop in node) {
|
||
|
newNode[prop] = node[prop];
|
||
|
}
|
||
|
return newNode;
|
||
|
};
|
||
|
var ecma9BinaryProperties = "ASCII ASCII_Hex_Digit AHex Alphabetic Alpha Any Assigned Bidi_Control Bidi_C Bidi_Mirrored Bidi_M Case_Ignorable CI Cased Changes_When_Casefolded CWCF Changes_When_Casemapped CWCM Changes_When_Lowercased CWL Changes_When_NFKC_Casefolded CWKCF Changes_When_Titlecased CWT Changes_When_Uppercased CWU Dash Default_Ignorable_Code_Point DI Deprecated Dep Diacritic Dia Emoji Emoji_Component Emoji_Modifier Emoji_Modifier_Base Emoji_Presentation Extender Ext Grapheme_Base Gr_Base Grapheme_Extend Gr_Ext Hex_Digit Hex IDS_Binary_Operator IDSB IDS_Trinary_Operator IDST ID_Continue IDC ID_Start IDS Ideographic Ideo Join_Control Join_C Logical_Order_Exception LOE Lowercase Lower Math Noncharacter_Code_Point NChar Pattern_Syntax Pat_Syn Pattern_White_Space Pat_WS Quotation_Mark QMark Radical Regional_Indicator RI Sentence_Terminal STerm Soft_Dotted SD Terminal_Punctuation Term Unified_Ideograph UIdeo Uppercase Upper Variation_Selector VS White_Space space XID_Continue XIDC XID_Start XIDS";
|
||
|
var ecma10BinaryProperties = ecma9BinaryProperties + " Extended_Pictographic";
|
||
|
var ecma11BinaryProperties = ecma10BinaryProperties;
|
||
|
var ecma12BinaryProperties = ecma11BinaryProperties + " EBase EComp EMod EPres ExtPict";
|
||
|
var ecma13BinaryProperties = ecma12BinaryProperties;
|
||
|
var unicodeBinaryProperties = {
|
||
|
9: ecma9BinaryProperties,
|
||
|
10: ecma10BinaryProperties,
|
||
|
11: ecma11BinaryProperties,
|
||
|
12: ecma12BinaryProperties,
|
||
|
13: ecma13BinaryProperties
|
||
|
};
|
||
|
var unicodeGeneralCategoryValues = "Cased_Letter LC Close_Punctuation Pe Connector_Punctuation Pc Control Cc cntrl Currency_Symbol Sc Dash_Punctuation Pd Decimal_Number Nd digit Enclosing_Mark Me Final_Punctuation Pf Format Cf Initial_Punctuation Pi Letter L Letter_Number Nl Line_Separator Zl Lowercase_Letter Ll Mark M Combining_Mark Math_Symbol Sm Modifier_Letter Lm Modifier_Symbol Sk Nonspacing_Mark Mn Number N Open_Punctuation Ps Other C Other_Letter Lo Other_Number No Other_Punctuation Po Other_Symbol So Paragraph_Separator Zp Private_Use Co Punctuation P punct Separator Z Space_Separator Zs Spacing_Mark Mc Surrogate Cs Symbol S Titlecase_Letter Lt Unassigned Cn Uppercase_Letter Lu";
|
||
|
var ecma9ScriptValues = "Adlam Adlm Ahom Anatolian_Hieroglyphs Hluw Arabic Arab Armenian Armn Avestan Avst Balinese Bali Bamum Bamu Bassa_Vah Bass Batak Batk Bengali Beng Bhaiksuki Bhks Bopomofo Bopo Brahmi Brah Braille Brai Buginese Bugi Buhid Buhd Canadian_Aboriginal Cans Carian Cari Caucasian_Albanian Aghb Chakma Cakm Cham Cham Cherokee Cher Common Zyyy Coptic Copt Qaac Cuneiform Xsux Cypriot Cprt Cyrillic Cyrl Deseret Dsrt Devanagari Deva Duployan Dupl Egyptian_Hieroglyphs Egyp Elbasan Elba Ethiopic Ethi Georgian Geor Glagolitic Glag Gothic Goth Grantha Gran Greek Grek Gujarati Gujr Gurmukhi Guru Han Hani Hangul Hang Hanunoo Hano Hatran Hatr Hebrew Hebr Hiragana Hira Imperial_Aramaic Armi Inherited Zinh Qaai Inscriptional_Pahlavi Phli Inscriptional_Parthian Prti Javanese Java Kaithi Kthi Kannada Knda Katakana Kana Kayah_Li Kali Kharoshthi Khar Khmer Khmr Khojki Khoj Khudawadi Sind Lao Laoo Latin Latn Lepcha Lepc Limbu Limb Linear_A Lina Linear_B Linb Lisu Lisu Lycian Lyci Lydian Lydi Mahajani Mahj Malayalam Mlym Mandaic Mand Manichaean Mani Marchen Marc Masaram_Gondi Gonm Meetei_Mayek Mtei Mende_Kikakui Mend Meroitic_Cursive Merc Meroitic_Hieroglyphs Mero Miao Plrd Modi Mongolian Mong Mro Mroo Multani Mult Myanmar Mymr Nabataean Nbat New_Tai_Lue Talu Newa Newa Nko Nkoo Nushu Nshu Ogham Ogam Ol_Chiki Olck Old_Hungarian Hung Old_Italic Ital Old_North_Arabian Narb Old_Permic Perm Old_Persian Xpeo Old_South_Arabian Sarb Old_Turkic Orkh Oriya Orya Osage Osge Osmanya Osma Pahawh_Hmong Hmng Palmyrene Palm Pau_Cin_Hau Pauc Phags_Pa Phag Phoenician Phnx Psalter_Pahlavi Phlp Rejang Rjng Runic Runr Samaritan Samr Saurashtra Saur Sharada Shrd Shavian Shaw Siddham Sidd SignWriting Sgnw Sinhala Sinh Sora_Sompeng Sora Soyombo Soyo Sundanese Sund Syloti_Nagri Sylo Syriac Syrc Tagalog Tglg Tagbanwa Tagb Tai_Le Tale Tai_Tham Lana Tai_Viet Tavt Takri Takr Tamil Taml Tangut Tang Telugu Telu Thaana Thaa Thai Thai Tibetan Tibt Tifinagh Tfng Tirhuta Tirh Ugaritic Ugar Vai Vaii Warang_Citi Wara Yi Yiii Zanabazar_Square Zanb";
|
||
|
var ecma10ScriptValues = ecma9ScriptValues + " Dogra Dogr Gunjala_Gondi Gong Hanifi_Rohingya Rohg Makasar Maka Medefaidrin Medf Old_Sogdian Sogo Sogdian Sogd";
|
||
|
var ecma11ScriptValues = ecma10ScriptValues + " Elymaic Elym Nandinagari Nand Nyiakeng_Puachue_Hmong Hmnp Wancho Wcho";
|
||
|
var ecma12ScriptValues = ecma11ScriptValues + " Chorasmian Chrs Diak Dives_Akuru Khitan_Small_Script Kits Yezi Yezidi";
|
||
|
var ecma13ScriptValues = ecma12ScriptValues + " Cypro_Minoan Cpmn Old_Uyghur Ougr Tangsa Tnsa Toto Vithkuqi Vith";
|
||
|
var unicodeScriptValues = {
|
||
|
9: ecma9ScriptValues,
|
||
|
10: ecma10ScriptValues,
|
||
|
11: ecma11ScriptValues,
|
||
|
12: ecma12ScriptValues,
|
||
|
13: ecma13ScriptValues
|
||
|
};
|
||
|
var data = {};
|
||
|
function buildUnicodeData(ecmaVersion) {
|
||
|
var d = data[ecmaVersion] = {
|
||
|
binary: wordsRegexp(unicodeBinaryProperties[ecmaVersion] + " " + unicodeGeneralCategoryValues),
|
||
|
nonBinary: {
|
||
|
General_Category: wordsRegexp(unicodeGeneralCategoryValues),
|
||
|
Script: wordsRegexp(unicodeScriptValues[ecmaVersion])
|
||
|
}
|
||
|
};
|
||
|
d.nonBinary.Script_Extensions = d.nonBinary.Script;
|
||
|
d.nonBinary.gc = d.nonBinary.General_Category;
|
||
|
d.nonBinary.sc = d.nonBinary.Script;
|
||
|
d.nonBinary.scx = d.nonBinary.Script_Extensions;
|
||
|
}
|
||
|
for (var i = 0, list = [9, 10, 11, 12, 13]; i < list.length; i += 1) {
|
||
|
var ecmaVersion = list[i];
|
||
|
buildUnicodeData(ecmaVersion);
|
||
|
}
|
||
|
var pp$1 = Parser.prototype;
|
||
|
var RegExpValidationState = function RegExpValidationState2(parser) {
|
||
|
this.parser = parser;
|
||
|
this.validFlags = "gim" + (parser.options.ecmaVersion >= 6 ? "uy" : "") + (parser.options.ecmaVersion >= 9 ? "s" : "") + (parser.options.ecmaVersion >= 13 ? "d" : "");
|
||
|
this.unicodeProperties = data[parser.options.ecmaVersion >= 13 ? 13 : parser.options.ecmaVersion];
|
||
|
this.source = "";
|
||
|
this.flags = "";
|
||
|
this.start = 0;
|
||
|
this.switchU = false;
|
||
|
this.switchN = false;
|
||
|
this.pos = 0;
|
||
|
this.lastIntValue = 0;
|
||
|
this.lastStringValue = "";
|
||
|
this.lastAssertionIsQuantifiable = false;
|
||
|
this.numCapturingParens = 0;
|
||
|
this.maxBackReference = 0;
|
||
|
this.groupNames = [];
|
||
|
this.backReferenceNames = [];
|
||
|
};
|
||
|
RegExpValidationState.prototype.reset = function reset(start, pattern, flags) {
|
||
|
var unicode = flags.indexOf("u") !== -1;
|
||
|
this.start = start | 0;
|
||
|
this.source = pattern + "";
|
||
|
this.flags = flags;
|
||
|
this.switchU = unicode && this.parser.options.ecmaVersion >= 6;
|
||
|
this.switchN = unicode && this.parser.options.ecmaVersion >= 9;
|
||
|
};
|
||
|
RegExpValidationState.prototype.raise = function raise(message) {
|
||
|
this.parser.raiseRecoverable(this.start, "Invalid regular expression: /" + this.source + "/: " + message);
|
||
|
};
|
||
|
RegExpValidationState.prototype.at = function at(i, forceU) {
|
||
|
if (forceU === void 0)
|
||
|
forceU = false;
|
||
|
var s = this.source;
|
||
|
var l = s.length;
|
||
|
if (i >= l) {
|
||
|
return -1;
|
||
|
}
|
||
|
var c = s.charCodeAt(i);
|
||
|
if (!(forceU || this.switchU) || c <= 55295 || c >= 57344 || i + 1 >= l) {
|
||
|
return c;
|
||
|
}
|
||
|
var next = s.charCodeAt(i + 1);
|
||
|
return next >= 56320 && next <= 57343 ? (c << 10) + next - 56613888 : c;
|
||
|
};
|
||
|
RegExpValidationState.prototype.nextIndex = function nextIndex(i, forceU) {
|
||
|
if (forceU === void 0)
|
||
|
forceU = false;
|
||
|
var s = this.source;
|
||
|
var l = s.length;
|
||
|
if (i >= l) {
|
||
|
return l;
|
||
|
}
|
||
|
var c = s.charCodeAt(i), next;
|
||
|
if (!(forceU || this.switchU) || c <= 55295 || c >= 57344 || i + 1 >= l || (next = s.charCodeAt(i + 1)) < 56320 || next > 57343) {
|
||
|
return i + 1;
|
||
|
}
|
||
|
return i + 2;
|
||
|
};
|
||
|
RegExpValidationState.prototype.current = function current(forceU) {
|
||
|
if (forceU === void 0)
|
||
|
forceU = false;
|
||
|
return this.at(this.pos, forceU);
|
||
|
};
|
||
|
RegExpValidationState.prototype.lookahead = function lookahead(forceU) {
|
||
|
if (forceU === void 0)
|
||
|
forceU = false;
|
||
|
return this.at(this.nextIndex(this.pos, forceU), forceU);
|
||
|
};
|
||
|
RegExpValidationState.prototype.advance = function advance(forceU) {
|
||
|
if (forceU === void 0)
|
||
|
forceU = false;
|
||
|
this.pos = this.nextIndex(this.pos, forceU);
|
||
|
};
|
||
|
RegExpValidationState.prototype.eat = function eat(ch, forceU) {
|
||
|
if (forceU === void 0)
|
||
|
forceU = false;
|
||
|
if (this.current(forceU) === ch) {
|
||
|
this.advance(forceU);
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.validateRegExpFlags = function(state) {
|
||
|
var validFlags = state.validFlags;
|
||
|
var flags = state.flags;
|
||
|
for (var i = 0; i < flags.length; i++) {
|
||
|
var flag = flags.charAt(i);
|
||
|
if (validFlags.indexOf(flag) === -1) {
|
||
|
this.raise(state.start, "Invalid regular expression flag");
|
||
|
}
|
||
|
if (flags.indexOf(flag, i + 1) > -1) {
|
||
|
this.raise(state.start, "Duplicate regular expression flag");
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
pp$1.validateRegExpPattern = function(state) {
|
||
|
this.regexp_pattern(state);
|
||
|
if (!state.switchN && this.options.ecmaVersion >= 9 && state.groupNames.length > 0) {
|
||
|
state.switchN = true;
|
||
|
this.regexp_pattern(state);
|
||
|
}
|
||
|
};
|
||
|
pp$1.regexp_pattern = function(state) {
|
||
|
state.pos = 0;
|
||
|
state.lastIntValue = 0;
|
||
|
state.lastStringValue = "";
|
||
|
state.lastAssertionIsQuantifiable = false;
|
||
|
state.numCapturingParens = 0;
|
||
|
state.maxBackReference = 0;
|
||
|
state.groupNames.length = 0;
|
||
|
state.backReferenceNames.length = 0;
|
||
|
this.regexp_disjunction(state);
|
||
|
if (state.pos !== state.source.length) {
|
||
|
if (state.eat(41)) {
|
||
|
state.raise("Unmatched ')'");
|
||
|
}
|
||
|
if (state.eat(93) || state.eat(125)) {
|
||
|
state.raise("Lone quantifier brackets");
|
||
|
}
|
||
|
}
|
||
|
if (state.maxBackReference > state.numCapturingParens) {
|
||
|
state.raise("Invalid escape");
|
||
|
}
|
||
|
for (var i = 0, list = state.backReferenceNames; i < list.length; i += 1) {
|
||
|
var name = list[i];
|
||
|
if (state.groupNames.indexOf(name) === -1) {
|
||
|
state.raise("Invalid named capture referenced");
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
pp$1.regexp_disjunction = function(state) {
|
||
|
this.regexp_alternative(state);
|
||
|
while (state.eat(124)) {
|
||
|
this.regexp_alternative(state);
|
||
|
}
|
||
|
if (this.regexp_eatQuantifier(state, true)) {
|
||
|
state.raise("Nothing to repeat");
|
||
|
}
|
||
|
if (state.eat(123)) {
|
||
|
state.raise("Lone quantifier brackets");
|
||
|
}
|
||
|
};
|
||
|
pp$1.regexp_alternative = function(state) {
|
||
|
while (state.pos < state.source.length && this.regexp_eatTerm(state)) {
|
||
|
}
|
||
|
};
|
||
|
pp$1.regexp_eatTerm = function(state) {
|
||
|
if (this.regexp_eatAssertion(state)) {
|
||
|
if (state.lastAssertionIsQuantifiable && this.regexp_eatQuantifier(state)) {
|
||
|
if (state.switchU) {
|
||
|
state.raise("Invalid quantifier");
|
||
|
}
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
if (state.switchU ? this.regexp_eatAtom(state) : this.regexp_eatExtendedAtom(state)) {
|
||
|
this.regexp_eatQuantifier(state);
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatAssertion = function(state) {
|
||
|
var start = state.pos;
|
||
|
state.lastAssertionIsQuantifiable = false;
|
||
|
if (state.eat(94) || state.eat(36)) {
|
||
|
return true;
|
||
|
}
|
||
|
if (state.eat(92)) {
|
||
|
if (state.eat(66) || state.eat(98)) {
|
||
|
return true;
|
||
|
}
|
||
|
state.pos = start;
|
||
|
}
|
||
|
if (state.eat(40) && state.eat(63)) {
|
||
|
var lookbehind = false;
|
||
|
if (this.options.ecmaVersion >= 9) {
|
||
|
lookbehind = state.eat(60);
|
||
|
}
|
||
|
if (state.eat(61) || state.eat(33)) {
|
||
|
this.regexp_disjunction(state);
|
||
|
if (!state.eat(41)) {
|
||
|
state.raise("Unterminated group");
|
||
|
}
|
||
|
state.lastAssertionIsQuantifiable = !lookbehind;
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
state.pos = start;
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatQuantifier = function(state, noError) {
|
||
|
if (noError === void 0)
|
||
|
noError = false;
|
||
|
if (this.regexp_eatQuantifierPrefix(state, noError)) {
|
||
|
state.eat(63);
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatQuantifierPrefix = function(state, noError) {
|
||
|
return state.eat(42) || state.eat(43) || state.eat(63) || this.regexp_eatBracedQuantifier(state, noError);
|
||
|
};
|
||
|
pp$1.regexp_eatBracedQuantifier = function(state, noError) {
|
||
|
var start = state.pos;
|
||
|
if (state.eat(123)) {
|
||
|
var min = 0, max = -1;
|
||
|
if (this.regexp_eatDecimalDigits(state)) {
|
||
|
min = state.lastIntValue;
|
||
|
if (state.eat(44) && this.regexp_eatDecimalDigits(state)) {
|
||
|
max = state.lastIntValue;
|
||
|
}
|
||
|
if (state.eat(125)) {
|
||
|
if (max !== -1 && max < min && !noError) {
|
||
|
state.raise("numbers out of order in {} quantifier");
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
if (state.switchU && !noError) {
|
||
|
state.raise("Incomplete quantifier");
|
||
|
}
|
||
|
state.pos = start;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatAtom = function(state) {
|
||
|
return this.regexp_eatPatternCharacters(state) || state.eat(46) || this.regexp_eatReverseSolidusAtomEscape(state) || this.regexp_eatCharacterClass(state) || this.regexp_eatUncapturingGroup(state) || this.regexp_eatCapturingGroup(state);
|
||
|
};
|
||
|
pp$1.regexp_eatReverseSolidusAtomEscape = function(state) {
|
||
|
var start = state.pos;
|
||
|
if (state.eat(92)) {
|
||
|
if (this.regexp_eatAtomEscape(state)) {
|
||
|
return true;
|
||
|
}
|
||
|
state.pos = start;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatUncapturingGroup = function(state) {
|
||
|
var start = state.pos;
|
||
|
if (state.eat(40)) {
|
||
|
if (state.eat(63) && state.eat(58)) {
|
||
|
this.regexp_disjunction(state);
|
||
|
if (state.eat(41)) {
|
||
|
return true;
|
||
|
}
|
||
|
state.raise("Unterminated group");
|
||
|
}
|
||
|
state.pos = start;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatCapturingGroup = function(state) {
|
||
|
if (state.eat(40)) {
|
||
|
if (this.options.ecmaVersion >= 9) {
|
||
|
this.regexp_groupSpecifier(state);
|
||
|
} else if (state.current() === 63) {
|
||
|
state.raise("Invalid group");
|
||
|
}
|
||
|
this.regexp_disjunction(state);
|
||
|
if (state.eat(41)) {
|
||
|
state.numCapturingParens += 1;
|
||
|
return true;
|
||
|
}
|
||
|
state.raise("Unterminated group");
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatExtendedAtom = function(state) {
|
||
|
return state.eat(46) || this.regexp_eatReverseSolidusAtomEscape(state) || this.regexp_eatCharacterClass(state) || this.regexp_eatUncapturingGroup(state) || this.regexp_eatCapturingGroup(state) || this.regexp_eatInvalidBracedQuantifier(state) || this.regexp_eatExtendedPatternCharacter(state);
|
||
|
};
|
||
|
pp$1.regexp_eatInvalidBracedQuantifier = function(state) {
|
||
|
if (this.regexp_eatBracedQuantifier(state, true)) {
|
||
|
state.raise("Nothing to repeat");
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatSyntaxCharacter = function(state) {
|
||
|
var ch = state.current();
|
||
|
if (isSyntaxCharacter(ch)) {
|
||
|
state.lastIntValue = ch;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
function isSyntaxCharacter(ch) {
|
||
|
return ch === 36 || ch >= 40 && ch <= 43 || ch === 46 || ch === 63 || ch >= 91 && ch <= 94 || ch >= 123 && ch <= 125;
|
||
|
}
|
||
|
pp$1.regexp_eatPatternCharacters = function(state) {
|
||
|
var start = state.pos;
|
||
|
var ch = 0;
|
||
|
while ((ch = state.current()) !== -1 && !isSyntaxCharacter(ch)) {
|
||
|
state.advance();
|
||
|
}
|
||
|
return state.pos !== start;
|
||
|
};
|
||
|
pp$1.regexp_eatExtendedPatternCharacter = function(state) {
|
||
|
var ch = state.current();
|
||
|
if (ch !== -1 && ch !== 36 && !(ch >= 40 && ch <= 43) && ch !== 46 && ch !== 63 && ch !== 91 && ch !== 94 && ch !== 124) {
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_groupSpecifier = function(state) {
|
||
|
if (state.eat(63)) {
|
||
|
if (this.regexp_eatGroupName(state)) {
|
||
|
if (state.groupNames.indexOf(state.lastStringValue) !== -1) {
|
||
|
state.raise("Duplicate capture group name");
|
||
|
}
|
||
|
state.groupNames.push(state.lastStringValue);
|
||
|
return;
|
||
|
}
|
||
|
state.raise("Invalid group");
|
||
|
}
|
||
|
};
|
||
|
pp$1.regexp_eatGroupName = function(state) {
|
||
|
state.lastStringValue = "";
|
||
|
if (state.eat(60)) {
|
||
|
if (this.regexp_eatRegExpIdentifierName(state) && state.eat(62)) {
|
||
|
return true;
|
||
|
}
|
||
|
state.raise("Invalid capture group name");
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatRegExpIdentifierName = function(state) {
|
||
|
state.lastStringValue = "";
|
||
|
if (this.regexp_eatRegExpIdentifierStart(state)) {
|
||
|
state.lastStringValue += codePointToString(state.lastIntValue);
|
||
|
while (this.regexp_eatRegExpIdentifierPart(state)) {
|
||
|
state.lastStringValue += codePointToString(state.lastIntValue);
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatRegExpIdentifierStart = function(state) {
|
||
|
var start = state.pos;
|
||
|
var forceU = this.options.ecmaVersion >= 11;
|
||
|
var ch = state.current(forceU);
|
||
|
state.advance(forceU);
|
||
|
if (ch === 92 && this.regexp_eatRegExpUnicodeEscapeSequence(state, forceU)) {
|
||
|
ch = state.lastIntValue;
|
||
|
}
|
||
|
if (isRegExpIdentifierStart(ch)) {
|
||
|
state.lastIntValue = ch;
|
||
|
return true;
|
||
|
}
|
||
|
state.pos = start;
|
||
|
return false;
|
||
|
};
|
||
|
function isRegExpIdentifierStart(ch) {
|
||
|
return isIdentifierStart(ch, true) || ch === 36 || ch === 95;
|
||
|
}
|
||
|
pp$1.regexp_eatRegExpIdentifierPart = function(state) {
|
||
|
var start = state.pos;
|
||
|
var forceU = this.options.ecmaVersion >= 11;
|
||
|
var ch = state.current(forceU);
|
||
|
state.advance(forceU);
|
||
|
if (ch === 92 && this.regexp_eatRegExpUnicodeEscapeSequence(state, forceU)) {
|
||
|
ch = state.lastIntValue;
|
||
|
}
|
||
|
if (isRegExpIdentifierPart(ch)) {
|
||
|
state.lastIntValue = ch;
|
||
|
return true;
|
||
|
}
|
||
|
state.pos = start;
|
||
|
return false;
|
||
|
};
|
||
|
function isRegExpIdentifierPart(ch) {
|
||
|
return isIdentifierChar(ch, true) || ch === 36 || ch === 95 || ch === 8204 || ch === 8205;
|
||
|
}
|
||
|
pp$1.regexp_eatAtomEscape = function(state) {
|
||
|
if (this.regexp_eatBackReference(state) || this.regexp_eatCharacterClassEscape(state) || this.regexp_eatCharacterEscape(state) || state.switchN && this.regexp_eatKGroupName(state)) {
|
||
|
return true;
|
||
|
}
|
||
|
if (state.switchU) {
|
||
|
if (state.current() === 99) {
|
||
|
state.raise("Invalid unicode escape");
|
||
|
}
|
||
|
state.raise("Invalid escape");
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatBackReference = function(state) {
|
||
|
var start = state.pos;
|
||
|
if (this.regexp_eatDecimalEscape(state)) {
|
||
|
var n = state.lastIntValue;
|
||
|
if (state.switchU) {
|
||
|
if (n > state.maxBackReference) {
|
||
|
state.maxBackReference = n;
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
if (n <= state.numCapturingParens) {
|
||
|
return true;
|
||
|
}
|
||
|
state.pos = start;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatKGroupName = function(state) {
|
||
|
if (state.eat(107)) {
|
||
|
if (this.regexp_eatGroupName(state)) {
|
||
|
state.backReferenceNames.push(state.lastStringValue);
|
||
|
return true;
|
||
|
}
|
||
|
state.raise("Invalid named reference");
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatCharacterEscape = function(state) {
|
||
|
return this.regexp_eatControlEscape(state) || this.regexp_eatCControlLetter(state) || this.regexp_eatZero(state) || this.regexp_eatHexEscapeSequence(state) || this.regexp_eatRegExpUnicodeEscapeSequence(state, false) || !state.switchU && this.regexp_eatLegacyOctalEscapeSequence(state) || this.regexp_eatIdentityEscape(state);
|
||
|
};
|
||
|
pp$1.regexp_eatCControlLetter = function(state) {
|
||
|
var start = state.pos;
|
||
|
if (state.eat(99)) {
|
||
|
if (this.regexp_eatControlLetter(state)) {
|
||
|
return true;
|
||
|
}
|
||
|
state.pos = start;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatZero = function(state) {
|
||
|
if (state.current() === 48 && !isDecimalDigit(state.lookahead())) {
|
||
|
state.lastIntValue = 0;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatControlEscape = function(state) {
|
||
|
var ch = state.current();
|
||
|
if (ch === 116) {
|
||
|
state.lastIntValue = 9;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
if (ch === 110) {
|
||
|
state.lastIntValue = 10;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
if (ch === 118) {
|
||
|
state.lastIntValue = 11;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
if (ch === 102) {
|
||
|
state.lastIntValue = 12;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
if (ch === 114) {
|
||
|
state.lastIntValue = 13;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatControlLetter = function(state) {
|
||
|
var ch = state.current();
|
||
|
if (isControlLetter(ch)) {
|
||
|
state.lastIntValue = ch % 32;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
function isControlLetter(ch) {
|
||
|
return ch >= 65 && ch <= 90 || ch >= 97 && ch <= 122;
|
||
|
}
|
||
|
pp$1.regexp_eatRegExpUnicodeEscapeSequence = function(state, forceU) {
|
||
|
if (forceU === void 0)
|
||
|
forceU = false;
|
||
|
var start = state.pos;
|
||
|
var switchU = forceU || state.switchU;
|
||
|
if (state.eat(117)) {
|
||
|
if (this.regexp_eatFixedHexDigits(state, 4)) {
|
||
|
var lead = state.lastIntValue;
|
||
|
if (switchU && lead >= 55296 && lead <= 56319) {
|
||
|
var leadSurrogateEnd = state.pos;
|
||
|
if (state.eat(92) && state.eat(117) && this.regexp_eatFixedHexDigits(state, 4)) {
|
||
|
var trail = state.lastIntValue;
|
||
|
if (trail >= 56320 && trail <= 57343) {
|
||
|
state.lastIntValue = (lead - 55296) * 1024 + (trail - 56320) + 65536;
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
state.pos = leadSurrogateEnd;
|
||
|
state.lastIntValue = lead;
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
if (switchU && state.eat(123) && this.regexp_eatHexDigits(state) && state.eat(125) && isValidUnicode(state.lastIntValue)) {
|
||
|
return true;
|
||
|
}
|
||
|
if (switchU) {
|
||
|
state.raise("Invalid unicode escape");
|
||
|
}
|
||
|
state.pos = start;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
function isValidUnicode(ch) {
|
||
|
return ch >= 0 && ch <= 1114111;
|
||
|
}
|
||
|
pp$1.regexp_eatIdentityEscape = function(state) {
|
||
|
if (state.switchU) {
|
||
|
if (this.regexp_eatSyntaxCharacter(state)) {
|
||
|
return true;
|
||
|
}
|
||
|
if (state.eat(47)) {
|
||
|
state.lastIntValue = 47;
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
}
|
||
|
var ch = state.current();
|
||
|
if (ch !== 99 && (!state.switchN || ch !== 107)) {
|
||
|
state.lastIntValue = ch;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatDecimalEscape = function(state) {
|
||
|
state.lastIntValue = 0;
|
||
|
var ch = state.current();
|
||
|
if (ch >= 49 && ch <= 57) {
|
||
|
do {
|
||
|
state.lastIntValue = 10 * state.lastIntValue + (ch - 48);
|
||
|
state.advance();
|
||
|
} while ((ch = state.current()) >= 48 && ch <= 57);
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatCharacterClassEscape = function(state) {
|
||
|
var ch = state.current();
|
||
|
if (isCharacterClassEscape(ch)) {
|
||
|
state.lastIntValue = -1;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
if (state.switchU && this.options.ecmaVersion >= 9 && (ch === 80 || ch === 112)) {
|
||
|
state.lastIntValue = -1;
|
||
|
state.advance();
|
||
|
if (state.eat(123) && this.regexp_eatUnicodePropertyValueExpression(state) && state.eat(125)) {
|
||
|
return true;
|
||
|
}
|
||
|
state.raise("Invalid property name");
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
function isCharacterClassEscape(ch) {
|
||
|
return ch === 100 || ch === 68 || ch === 115 || ch === 83 || ch === 119 || ch === 87;
|
||
|
}
|
||
|
pp$1.regexp_eatUnicodePropertyValueExpression = function(state) {
|
||
|
var start = state.pos;
|
||
|
if (this.regexp_eatUnicodePropertyName(state) && state.eat(61)) {
|
||
|
var name = state.lastStringValue;
|
||
|
if (this.regexp_eatUnicodePropertyValue(state)) {
|
||
|
var value = state.lastStringValue;
|
||
|
this.regexp_validateUnicodePropertyNameAndValue(state, name, value);
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
state.pos = start;
|
||
|
if (this.regexp_eatLoneUnicodePropertyNameOrValue(state)) {
|
||
|
var nameOrValue = state.lastStringValue;
|
||
|
this.regexp_validateUnicodePropertyNameOrValue(state, nameOrValue);
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_validateUnicodePropertyNameAndValue = function(state, name, value) {
|
||
|
if (!hasOwn(state.unicodeProperties.nonBinary, name)) {
|
||
|
state.raise("Invalid property name");
|
||
|
}
|
||
|
if (!state.unicodeProperties.nonBinary[name].test(value)) {
|
||
|
state.raise("Invalid property value");
|
||
|
}
|
||
|
};
|
||
|
pp$1.regexp_validateUnicodePropertyNameOrValue = function(state, nameOrValue) {
|
||
|
if (!state.unicodeProperties.binary.test(nameOrValue)) {
|
||
|
state.raise("Invalid property name");
|
||
|
}
|
||
|
};
|
||
|
pp$1.regexp_eatUnicodePropertyName = function(state) {
|
||
|
var ch = 0;
|
||
|
state.lastStringValue = "";
|
||
|
while (isUnicodePropertyNameCharacter(ch = state.current())) {
|
||
|
state.lastStringValue += codePointToString(ch);
|
||
|
state.advance();
|
||
|
}
|
||
|
return state.lastStringValue !== "";
|
||
|
};
|
||
|
function isUnicodePropertyNameCharacter(ch) {
|
||
|
return isControlLetter(ch) || ch === 95;
|
||
|
}
|
||
|
pp$1.regexp_eatUnicodePropertyValue = function(state) {
|
||
|
var ch = 0;
|
||
|
state.lastStringValue = "";
|
||
|
while (isUnicodePropertyValueCharacter(ch = state.current())) {
|
||
|
state.lastStringValue += codePointToString(ch);
|
||
|
state.advance();
|
||
|
}
|
||
|
return state.lastStringValue !== "";
|
||
|
};
|
||
|
function isUnicodePropertyValueCharacter(ch) {
|
||
|
return isUnicodePropertyNameCharacter(ch) || isDecimalDigit(ch);
|
||
|
}
|
||
|
pp$1.regexp_eatLoneUnicodePropertyNameOrValue = function(state) {
|
||
|
return this.regexp_eatUnicodePropertyValue(state);
|
||
|
};
|
||
|
pp$1.regexp_eatCharacterClass = function(state) {
|
||
|
if (state.eat(91)) {
|
||
|
state.eat(94);
|
||
|
this.regexp_classRanges(state);
|
||
|
if (state.eat(93)) {
|
||
|
return true;
|
||
|
}
|
||
|
state.raise("Unterminated character class");
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_classRanges = function(state) {
|
||
|
while (this.regexp_eatClassAtom(state)) {
|
||
|
var left = state.lastIntValue;
|
||
|
if (state.eat(45) && this.regexp_eatClassAtom(state)) {
|
||
|
var right = state.lastIntValue;
|
||
|
if (state.switchU && (left === -1 || right === -1)) {
|
||
|
state.raise("Invalid character class");
|
||
|
}
|
||
|
if (left !== -1 && right !== -1 && left > right) {
|
||
|
state.raise("Range out of order in character class");
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
pp$1.regexp_eatClassAtom = function(state) {
|
||
|
var start = state.pos;
|
||
|
if (state.eat(92)) {
|
||
|
if (this.regexp_eatClassEscape(state)) {
|
||
|
return true;
|
||
|
}
|
||
|
if (state.switchU) {
|
||
|
var ch$1 = state.current();
|
||
|
if (ch$1 === 99 || isOctalDigit(ch$1)) {
|
||
|
state.raise("Invalid class escape");
|
||
|
}
|
||
|
state.raise("Invalid escape");
|
||
|
}
|
||
|
state.pos = start;
|
||
|
}
|
||
|
var ch = state.current();
|
||
|
if (ch !== 93) {
|
||
|
state.lastIntValue = ch;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatClassEscape = function(state) {
|
||
|
var start = state.pos;
|
||
|
if (state.eat(98)) {
|
||
|
state.lastIntValue = 8;
|
||
|
return true;
|
||
|
}
|
||
|
if (state.switchU && state.eat(45)) {
|
||
|
state.lastIntValue = 45;
|
||
|
return true;
|
||
|
}
|
||
|
if (!state.switchU && state.eat(99)) {
|
||
|
if (this.regexp_eatClassControlLetter(state)) {
|
||
|
return true;
|
||
|
}
|
||
|
state.pos = start;
|
||
|
}
|
||
|
return this.regexp_eatCharacterClassEscape(state) || this.regexp_eatCharacterEscape(state);
|
||
|
};
|
||
|
pp$1.regexp_eatClassControlLetter = function(state) {
|
||
|
var ch = state.current();
|
||
|
if (isDecimalDigit(ch) || ch === 95) {
|
||
|
state.lastIntValue = ch % 32;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatHexEscapeSequence = function(state) {
|
||
|
var start = state.pos;
|
||
|
if (state.eat(120)) {
|
||
|
if (this.regexp_eatFixedHexDigits(state, 2)) {
|
||
|
return true;
|
||
|
}
|
||
|
if (state.switchU) {
|
||
|
state.raise("Invalid escape");
|
||
|
}
|
||
|
state.pos = start;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatDecimalDigits = function(state) {
|
||
|
var start = state.pos;
|
||
|
var ch = 0;
|
||
|
state.lastIntValue = 0;
|
||
|
while (isDecimalDigit(ch = state.current())) {
|
||
|
state.lastIntValue = 10 * state.lastIntValue + (ch - 48);
|
||
|
state.advance();
|
||
|
}
|
||
|
return state.pos !== start;
|
||
|
};
|
||
|
function isDecimalDigit(ch) {
|
||
|
return ch >= 48 && ch <= 57;
|
||
|
}
|
||
|
pp$1.regexp_eatHexDigits = function(state) {
|
||
|
var start = state.pos;
|
||
|
var ch = 0;
|
||
|
state.lastIntValue = 0;
|
||
|
while (isHexDigit(ch = state.current())) {
|
||
|
state.lastIntValue = 16 * state.lastIntValue + hexToInt(ch);
|
||
|
state.advance();
|
||
|
}
|
||
|
return state.pos !== start;
|
||
|
};
|
||
|
function isHexDigit(ch) {
|
||
|
return ch >= 48 && ch <= 57 || ch >= 65 && ch <= 70 || ch >= 97 && ch <= 102;
|
||
|
}
|
||
|
function hexToInt(ch) {
|
||
|
if (ch >= 65 && ch <= 70) {
|
||
|
return 10 + (ch - 65);
|
||
|
}
|
||
|
if (ch >= 97 && ch <= 102) {
|
||
|
return 10 + (ch - 97);
|
||
|
}
|
||
|
return ch - 48;
|
||
|
}
|
||
|
pp$1.regexp_eatLegacyOctalEscapeSequence = function(state) {
|
||
|
if (this.regexp_eatOctalDigit(state)) {
|
||
|
var n1 = state.lastIntValue;
|
||
|
if (this.regexp_eatOctalDigit(state)) {
|
||
|
var n2 = state.lastIntValue;
|
||
|
if (n1 <= 3 && this.regexp_eatOctalDigit(state)) {
|
||
|
state.lastIntValue = n1 * 64 + n2 * 8 + state.lastIntValue;
|
||
|
} else {
|
||
|
state.lastIntValue = n1 * 8 + n2;
|
||
|
}
|
||
|
} else {
|
||
|
state.lastIntValue = n1;
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
pp$1.regexp_eatOctalDigit = function(state) {
|
||
|
var ch = state.current();
|
||
|
if (isOctalDigit(ch)) {
|
||
|
state.lastIntValue = ch - 48;
|
||
|
state.advance();
|
||
|
return true;
|
||
|
}
|
||
|
state.lastIntValue = 0;
|
||
|
return false;
|
||
|
};
|
||
|
function isOctalDigit(ch) {
|
||
|
return ch >= 48 && ch <= 55;
|
||
|
}
|
||
|
pp$1.regexp_eatFixedHexDigits = function(state, length) {
|
||
|
var start = state.pos;
|
||
|
state.lastIntValue = 0;
|
||
|
for (var i = 0; i < length; ++i) {
|
||
|
var ch = state.current();
|
||
|
if (!isHexDigit(ch)) {
|
||
|
state.pos = start;
|
||
|
return false;
|
||
|
}
|
||
|
state.lastIntValue = 16 * state.lastIntValue + hexToInt(ch);
|
||
|
state.advance();
|
||
|
}
|
||
|
return true;
|
||
|
};
|
||
|
var Token = function Token2(p) {
|
||
|
this.type = p.type;
|
||
|
this.value = p.value;
|
||
|
this.start = p.start;
|
||
|
this.end = p.end;
|
||
|
if (p.options.locations) {
|
||
|
this.loc = new SourceLocation(p, p.startLoc, p.endLoc);
|
||
|
}
|
||
|
if (p.options.ranges) {
|
||
|
this.range = [p.start, p.end];
|
||
|
}
|
||
|
};
|
||
|
var pp = Parser.prototype;
|
||
|
pp.next = function(ignoreEscapeSequenceInKeyword) {
|
||
|
if (!ignoreEscapeSequenceInKeyword && this.type.keyword && this.containsEsc) {
|
||
|
this.raiseRecoverable(this.start, "Escape sequence in keyword " + this.type.keyword);
|
||
|
}
|
||
|
if (this.options.onToken) {
|
||
|
this.options.onToken(new Token(this));
|
||
|
}
|
||
|
this.lastTokEnd = this.end;
|
||
|
this.lastTokStart = this.start;
|
||
|
this.lastTokEndLoc = this.endLoc;
|
||
|
this.lastTokStartLoc = this.startLoc;
|
||
|
this.nextToken();
|
||
|
};
|
||
|
pp.getToken = function() {
|
||
|
this.next();
|
||
|
return new Token(this);
|
||
|
};
|
||
|
if (typeof Symbol !== "undefined") {
|
||
|
pp[Symbol.iterator] = function() {
|
||
|
var this$1$1 = this;
|
||
|
return {
|
||
|
next: function() {
|
||
|
var token = this$1$1.getToken();
|
||
|
return {
|
||
|
done: token.type === types$1.eof,
|
||
|
value: token
|
||
|
};
|
||
|
}
|
||
|
};
|
||
|
};
|
||
|
}
|
||
|
pp.nextToken = function() {
|
||
|
var curContext = this.curContext();
|
||
|
if (!curContext || !curContext.preserveSpace) {
|
||
|
this.skipSpace();
|
||
|
}
|
||
|
this.start = this.pos;
|
||
|
if (this.options.locations) {
|
||
|
this.startLoc = this.curPosition();
|
||
|
}
|
||
|
if (this.pos >= this.input.length) {
|
||
|
return this.finishToken(types$1.eof);
|
||
|
}
|
||
|
if (curContext.override) {
|
||
|
return curContext.override(this);
|
||
|
} else {
|
||
|
this.readToken(this.fullCharCodeAtPos());
|
||
|
}
|
||
|
};
|
||
|
pp.readToken = function(code) {
|
||
|
if (isIdentifierStart(code, this.options.ecmaVersion >= 6) || code === 92) {
|
||
|
return this.readWord();
|
||
|
}
|
||
|
return this.getTokenFromCode(code);
|
||
|
};
|
||
|
pp.fullCharCodeAtPos = function() {
|
||
|
var code = this.input.charCodeAt(this.pos);
|
||
|
if (code <= 55295 || code >= 56320) {
|
||
|
return code;
|
||
|
}
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
return next <= 56319 || next >= 57344 ? code : (code << 10) + next - 56613888;
|
||
|
};
|
||
|
pp.skipBlockComment = function() {
|
||
|
var startLoc = this.options.onComment && this.curPosition();
|
||
|
var start = this.pos, end = this.input.indexOf("*/", this.pos += 2);
|
||
|
if (end === -1) {
|
||
|
this.raise(this.pos - 2, "Unterminated comment");
|
||
|
}
|
||
|
this.pos = end + 2;
|
||
|
if (this.options.locations) {
|
||
|
for (var nextBreak = void 0, pos = start; (nextBreak = nextLineBreak(this.input, pos, this.pos)) > -1; ) {
|
||
|
++this.curLine;
|
||
|
pos = this.lineStart = nextBreak;
|
||
|
}
|
||
|
}
|
||
|
if (this.options.onComment) {
|
||
|
this.options.onComment(
|
||
|
true,
|
||
|
this.input.slice(start + 2, end),
|
||
|
start,
|
||
|
this.pos,
|
||
|
startLoc,
|
||
|
this.curPosition()
|
||
|
);
|
||
|
}
|
||
|
};
|
||
|
pp.skipLineComment = function(startSkip) {
|
||
|
var start = this.pos;
|
||
|
var startLoc = this.options.onComment && this.curPosition();
|
||
|
var ch = this.input.charCodeAt(this.pos += startSkip);
|
||
|
while (this.pos < this.input.length && !isNewLine(ch)) {
|
||
|
ch = this.input.charCodeAt(++this.pos);
|
||
|
}
|
||
|
if (this.options.onComment) {
|
||
|
this.options.onComment(
|
||
|
false,
|
||
|
this.input.slice(start + startSkip, this.pos),
|
||
|
start,
|
||
|
this.pos,
|
||
|
startLoc,
|
||
|
this.curPosition()
|
||
|
);
|
||
|
}
|
||
|
};
|
||
|
pp.skipSpace = function() {
|
||
|
loop:
|
||
|
while (this.pos < this.input.length) {
|
||
|
var ch = this.input.charCodeAt(this.pos);
|
||
|
switch (ch) {
|
||
|
case 32:
|
||
|
case 160:
|
||
|
++this.pos;
|
||
|
break;
|
||
|
case 13:
|
||
|
if (this.input.charCodeAt(this.pos + 1) === 10) {
|
||
|
++this.pos;
|
||
|
}
|
||
|
case 10:
|
||
|
case 8232:
|
||
|
case 8233:
|
||
|
++this.pos;
|
||
|
if (this.options.locations) {
|
||
|
++this.curLine;
|
||
|
this.lineStart = this.pos;
|
||
|
}
|
||
|
break;
|
||
|
case 47:
|
||
|
switch (this.input.charCodeAt(this.pos + 1)) {
|
||
|
case 42:
|
||
|
this.skipBlockComment();
|
||
|
break;
|
||
|
case 47:
|
||
|
this.skipLineComment(2);
|
||
|
break;
|
||
|
default:
|
||
|
break loop;
|
||
|
}
|
||
|
break;
|
||
|
default:
|
||
|
if (ch > 8 && ch < 14 || ch >= 5760 && nonASCIIwhitespace.test(String.fromCharCode(ch))) {
|
||
|
++this.pos;
|
||
|
} else {
|
||
|
break loop;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
pp.finishToken = function(type, val) {
|
||
|
this.end = this.pos;
|
||
|
if (this.options.locations) {
|
||
|
this.endLoc = this.curPosition();
|
||
|
}
|
||
|
var prevType = this.type;
|
||
|
this.type = type;
|
||
|
this.value = val;
|
||
|
this.updateContext(prevType);
|
||
|
};
|
||
|
pp.readToken_dot = function() {
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
if (next >= 48 && next <= 57) {
|
||
|
return this.readNumber(true);
|
||
|
}
|
||
|
var next2 = this.input.charCodeAt(this.pos + 2);
|
||
|
if (this.options.ecmaVersion >= 6 && next === 46 && next2 === 46) {
|
||
|
this.pos += 3;
|
||
|
return this.finishToken(types$1.ellipsis);
|
||
|
} else {
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.dot);
|
||
|
}
|
||
|
};
|
||
|
pp.readToken_slash = function() {
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
if (this.exprAllowed) {
|
||
|
++this.pos;
|
||
|
return this.readRegexp();
|
||
|
}
|
||
|
if (next === 61) {
|
||
|
return this.finishOp(types$1.assign, 2);
|
||
|
}
|
||
|
return this.finishOp(types$1.slash, 1);
|
||
|
};
|
||
|
pp.readToken_mult_modulo_exp = function(code) {
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
var size = 1;
|
||
|
var tokentype = code === 42 ? types$1.star : types$1.modulo;
|
||
|
if (this.options.ecmaVersion >= 7 && code === 42 && next === 42) {
|
||
|
++size;
|
||
|
tokentype = types$1.starstar;
|
||
|
next = this.input.charCodeAt(this.pos + 2);
|
||
|
}
|
||
|
if (next === 61) {
|
||
|
return this.finishOp(types$1.assign, size + 1);
|
||
|
}
|
||
|
return this.finishOp(tokentype, size);
|
||
|
};
|
||
|
pp.readToken_pipe_amp = function(code) {
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
if (next === code) {
|
||
|
if (this.options.ecmaVersion >= 12) {
|
||
|
var next2 = this.input.charCodeAt(this.pos + 2);
|
||
|
if (next2 === 61) {
|
||
|
return this.finishOp(types$1.assign, 3);
|
||
|
}
|
||
|
}
|
||
|
return this.finishOp(code === 124 ? types$1.logicalOR : types$1.logicalAND, 2);
|
||
|
}
|
||
|
if (next === 61) {
|
||
|
return this.finishOp(types$1.assign, 2);
|
||
|
}
|
||
|
return this.finishOp(code === 124 ? types$1.bitwiseOR : types$1.bitwiseAND, 1);
|
||
|
};
|
||
|
pp.readToken_caret = function() {
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
if (next === 61) {
|
||
|
return this.finishOp(types$1.assign, 2);
|
||
|
}
|
||
|
return this.finishOp(types$1.bitwiseXOR, 1);
|
||
|
};
|
||
|
pp.readToken_plus_min = function(code) {
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
if (next === code) {
|
||
|
if (next === 45 && !this.inModule && this.input.charCodeAt(this.pos + 2) === 62 && (this.lastTokEnd === 0 || lineBreak.test(this.input.slice(this.lastTokEnd, this.pos)))) {
|
||
|
this.skipLineComment(3);
|
||
|
this.skipSpace();
|
||
|
return this.nextToken();
|
||
|
}
|
||
|
return this.finishOp(types$1.incDec, 2);
|
||
|
}
|
||
|
if (next === 61) {
|
||
|
return this.finishOp(types$1.assign, 2);
|
||
|
}
|
||
|
return this.finishOp(types$1.plusMin, 1);
|
||
|
};
|
||
|
pp.readToken_lt_gt = function(code) {
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
var size = 1;
|
||
|
if (next === code) {
|
||
|
size = code === 62 && this.input.charCodeAt(this.pos + 2) === 62 ? 3 : 2;
|
||
|
if (this.input.charCodeAt(this.pos + size) === 61) {
|
||
|
return this.finishOp(types$1.assign, size + 1);
|
||
|
}
|
||
|
return this.finishOp(types$1.bitShift, size);
|
||
|
}
|
||
|
if (next === 33 && code === 60 && !this.inModule && this.input.charCodeAt(this.pos + 2) === 45 && this.input.charCodeAt(this.pos + 3) === 45) {
|
||
|
this.skipLineComment(4);
|
||
|
this.skipSpace();
|
||
|
return this.nextToken();
|
||
|
}
|
||
|
if (next === 61) {
|
||
|
size = 2;
|
||
|
}
|
||
|
return this.finishOp(types$1.relational, size);
|
||
|
};
|
||
|
pp.readToken_eq_excl = function(code) {
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
if (next === 61) {
|
||
|
return this.finishOp(types$1.equality, this.input.charCodeAt(this.pos + 2) === 61 ? 3 : 2);
|
||
|
}
|
||
|
if (code === 61 && next === 62 && this.options.ecmaVersion >= 6) {
|
||
|
this.pos += 2;
|
||
|
return this.finishToken(types$1.arrow);
|
||
|
}
|
||
|
return this.finishOp(code === 61 ? types$1.eq : types$1.prefix, 1);
|
||
|
};
|
||
|
pp.readToken_question = function() {
|
||
|
var ecmaVersion = this.options.ecmaVersion;
|
||
|
if (ecmaVersion >= 11) {
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
if (next === 46) {
|
||
|
var next2 = this.input.charCodeAt(this.pos + 2);
|
||
|
if (next2 < 48 || next2 > 57) {
|
||
|
return this.finishOp(types$1.questionDot, 2);
|
||
|
}
|
||
|
}
|
||
|
if (next === 63) {
|
||
|
if (ecmaVersion >= 12) {
|
||
|
var next2$1 = this.input.charCodeAt(this.pos + 2);
|
||
|
if (next2$1 === 61) {
|
||
|
return this.finishOp(types$1.assign, 3);
|
||
|
}
|
||
|
}
|
||
|
return this.finishOp(types$1.coalesce, 2);
|
||
|
}
|
||
|
}
|
||
|
return this.finishOp(types$1.question, 1);
|
||
|
};
|
||
|
pp.readToken_numberSign = function() {
|
||
|
var ecmaVersion = this.options.ecmaVersion;
|
||
|
var code = 35;
|
||
|
if (ecmaVersion >= 13) {
|
||
|
++this.pos;
|
||
|
code = this.fullCharCodeAtPos();
|
||
|
if (isIdentifierStart(code, true) || code === 92) {
|
||
|
return this.finishToken(types$1.privateId, this.readWord1());
|
||
|
}
|
||
|
}
|
||
|
this.raise(this.pos, "Unexpected character '" + codePointToString(code) + "'");
|
||
|
};
|
||
|
pp.getTokenFromCode = function(code) {
|
||
|
switch (code) {
|
||
|
case 46:
|
||
|
return this.readToken_dot();
|
||
|
case 40:
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.parenL);
|
||
|
case 41:
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.parenR);
|
||
|
case 59:
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.semi);
|
||
|
case 44:
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.comma);
|
||
|
case 91:
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.bracketL);
|
||
|
case 93:
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.bracketR);
|
||
|
case 123:
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.braceL);
|
||
|
case 125:
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.braceR);
|
||
|
case 58:
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.colon);
|
||
|
case 96:
|
||
|
if (this.options.ecmaVersion < 6) {
|
||
|
break;
|
||
|
}
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.backQuote);
|
||
|
case 48:
|
||
|
var next = this.input.charCodeAt(this.pos + 1);
|
||
|
if (next === 120 || next === 88) {
|
||
|
return this.readRadixNumber(16);
|
||
|
}
|
||
|
if (this.options.ecmaVersion >= 6) {
|
||
|
if (next === 111 || next === 79) {
|
||
|
return this.readRadixNumber(8);
|
||
|
}
|
||
|
if (next === 98 || next === 66) {
|
||
|
return this.readRadixNumber(2);
|
||
|
}
|
||
|
}
|
||
|
case 49:
|
||
|
case 50:
|
||
|
case 51:
|
||
|
case 52:
|
||
|
case 53:
|
||
|
case 54:
|
||
|
case 55:
|
||
|
case 56:
|
||
|
case 57:
|
||
|
return this.readNumber(false);
|
||
|
case 34:
|
||
|
case 39:
|
||
|
return this.readString(code);
|
||
|
case 47:
|
||
|
return this.readToken_slash();
|
||
|
case 37:
|
||
|
case 42:
|
||
|
return this.readToken_mult_modulo_exp(code);
|
||
|
case 124:
|
||
|
case 38:
|
||
|
return this.readToken_pipe_amp(code);
|
||
|
case 94:
|
||
|
return this.readToken_caret();
|
||
|
case 43:
|
||
|
case 45:
|
||
|
return this.readToken_plus_min(code);
|
||
|
case 60:
|
||
|
case 62:
|
||
|
return this.readToken_lt_gt(code);
|
||
|
case 61:
|
||
|
case 33:
|
||
|
return this.readToken_eq_excl(code);
|
||
|
case 63:
|
||
|
return this.readToken_question();
|
||
|
case 126:
|
||
|
return this.finishOp(types$1.prefix, 1);
|
||
|
case 35:
|
||
|
return this.readToken_numberSign();
|
||
|
}
|
||
|
this.raise(this.pos, "Unexpected character '" + codePointToString(code) + "'");
|
||
|
};
|
||
|
pp.finishOp = function(type, size) {
|
||
|
var str = this.input.slice(this.pos, this.pos + size);
|
||
|
this.pos += size;
|
||
|
return this.finishToken(type, str);
|
||
|
};
|
||
|
pp.readRegexp = function() {
|
||
|
var escaped, inClass, start = this.pos;
|
||
|
for (; ; ) {
|
||
|
if (this.pos >= this.input.length) {
|
||
|
this.raise(start, "Unterminated regular expression");
|
||
|
}
|
||
|
var ch = this.input.charAt(this.pos);
|
||
|
if (lineBreak.test(ch)) {
|
||
|
this.raise(start, "Unterminated regular expression");
|
||
|
}
|
||
|
if (!escaped) {
|
||
|
if (ch === "[") {
|
||
|
inClass = true;
|
||
|
} else if (ch === "]" && inClass) {
|
||
|
inClass = false;
|
||
|
} else if (ch === "/" && !inClass) {
|
||
|
break;
|
||
|
}
|
||
|
escaped = ch === "\\";
|
||
|
} else {
|
||
|
escaped = false;
|
||
|
}
|
||
|
++this.pos;
|
||
|
}
|
||
|
var pattern = this.input.slice(start, this.pos);
|
||
|
++this.pos;
|
||
|
var flagsStart = this.pos;
|
||
|
var flags = this.readWord1();
|
||
|
if (this.containsEsc) {
|
||
|
this.unexpected(flagsStart);
|
||
|
}
|
||
|
var state = this.regexpState || (this.regexpState = new RegExpValidationState(this));
|
||
|
state.reset(start, pattern, flags);
|
||
|
this.validateRegExpFlags(state);
|
||
|
this.validateRegExpPattern(state);
|
||
|
var value = null;
|
||
|
try {
|
||
|
value = new RegExp(pattern, flags);
|
||
|
} catch (e) {
|
||
|
}
|
||
|
return this.finishToken(types$1.regexp, { pattern, flags, value });
|
||
|
};
|
||
|
pp.readInt = function(radix, len, maybeLegacyOctalNumericLiteral) {
|
||
|
var allowSeparators = this.options.ecmaVersion >= 12 && len === void 0;
|
||
|
var isLegacyOctalNumericLiteral = maybeLegacyOctalNumericLiteral && this.input.charCodeAt(this.pos) === 48;
|
||
|
var start = this.pos, total = 0, lastCode = 0;
|
||
|
for (var i = 0, e = len == null ? Infinity : len; i < e; ++i, ++this.pos) {
|
||
|
var code = this.input.charCodeAt(this.pos), val = void 0;
|
||
|
if (allowSeparators && code === 95) {
|
||
|
if (isLegacyOctalNumericLiteral) {
|
||
|
this.raiseRecoverable(this.pos, "Numeric separator is not allowed in legacy octal numeric literals");
|
||
|
}
|
||
|
if (lastCode === 95) {
|
||
|
this.raiseRecoverable(this.pos, "Numeric separator must be exactly one underscore");
|
||
|
}
|
||
|
if (i === 0) {
|
||
|
this.raiseRecoverable(this.pos, "Numeric separator is not allowed at the first of digits");
|
||
|
}
|
||
|
lastCode = code;
|
||
|
continue;
|
||
|
}
|
||
|
if (code >= 97) {
|
||
|
val = code - 97 + 10;
|
||
|
} else if (code >= 65) {
|
||
|
val = code - 65 + 10;
|
||
|
} else if (code >= 48 && code <= 57) {
|
||
|
val = code - 48;
|
||
|
} else {
|
||
|
val = Infinity;
|
||
|
}
|
||
|
if (val >= radix) {
|
||
|
break;
|
||
|
}
|
||
|
lastCode = code;
|
||
|
total = total * radix + val;
|
||
|
}
|
||
|
if (allowSeparators && lastCode === 95) {
|
||
|
this.raiseRecoverable(this.pos - 1, "Numeric separator is not allowed at the last of digits");
|
||
|
}
|
||
|
if (this.pos === start || len != null && this.pos - start !== len) {
|
||
|
return null;
|
||
|
}
|
||
|
return total;
|
||
|
};
|
||
|
function stringToNumber(str, isLegacyOctalNumericLiteral) {
|
||
|
if (isLegacyOctalNumericLiteral) {
|
||
|
return parseInt(str, 8);
|
||
|
}
|
||
|
return parseFloat(str.replace(/_/g, ""));
|
||
|
}
|
||
|
function stringToBigInt(str) {
|
||
|
if (typeof BigInt !== "function") {
|
||
|
return null;
|
||
|
}
|
||
|
return BigInt(str.replace(/_/g, ""));
|
||
|
}
|
||
|
pp.readRadixNumber = function(radix) {
|
||
|
var start = this.pos;
|
||
|
this.pos += 2;
|
||
|
var val = this.readInt(radix);
|
||
|
if (val == null) {
|
||
|
this.raise(this.start + 2, "Expected number in radix " + radix);
|
||
|
}
|
||
|
if (this.options.ecmaVersion >= 11 && this.input.charCodeAt(this.pos) === 110) {
|
||
|
val = stringToBigInt(this.input.slice(start, this.pos));
|
||
|
++this.pos;
|
||
|
} else if (isIdentifierStart(this.fullCharCodeAtPos())) {
|
||
|
this.raise(this.pos, "Identifier directly after number");
|
||
|
}
|
||
|
return this.finishToken(types$1.num, val);
|
||
|
};
|
||
|
pp.readNumber = function(startsWithDot) {
|
||
|
var start = this.pos;
|
||
|
if (!startsWithDot && this.readInt(10, void 0, true) === null) {
|
||
|
this.raise(start, "Invalid number");
|
||
|
}
|
||
|
var octal = this.pos - start >= 2 && this.input.charCodeAt(start) === 48;
|
||
|
if (octal && this.strict) {
|
||
|
this.raise(start, "Invalid number");
|
||
|
}
|
||
|
var next = this.input.charCodeAt(this.pos);
|
||
|
if (!octal && !startsWithDot && this.options.ecmaVersion >= 11 && next === 110) {
|
||
|
var val$1 = stringToBigInt(this.input.slice(start, this.pos));
|
||
|
++this.pos;
|
||
|
if (isIdentifierStart(this.fullCharCodeAtPos())) {
|
||
|
this.raise(this.pos, "Identifier directly after number");
|
||
|
}
|
||
|
return this.finishToken(types$1.num, val$1);
|
||
|
}
|
||
|
if (octal && /[89]/.test(this.input.slice(start, this.pos))) {
|
||
|
octal = false;
|
||
|
}
|
||
|
if (next === 46 && !octal) {
|
||
|
++this.pos;
|
||
|
this.readInt(10);
|
||
|
next = this.input.charCodeAt(this.pos);
|
||
|
}
|
||
|
if ((next === 69 || next === 101) && !octal) {
|
||
|
next = this.input.charCodeAt(++this.pos);
|
||
|
if (next === 43 || next === 45) {
|
||
|
++this.pos;
|
||
|
}
|
||
|
if (this.readInt(10) === null) {
|
||
|
this.raise(start, "Invalid number");
|
||
|
}
|
||
|
}
|
||
|
if (isIdentifierStart(this.fullCharCodeAtPos())) {
|
||
|
this.raise(this.pos, "Identifier directly after number");
|
||
|
}
|
||
|
var val = stringToNumber(this.input.slice(start, this.pos), octal);
|
||
|
return this.finishToken(types$1.num, val);
|
||
|
};
|
||
|
pp.readCodePoint = function() {
|
||
|
var ch = this.input.charCodeAt(this.pos), code;
|
||
|
if (ch === 123) {
|
||
|
if (this.options.ecmaVersion < 6) {
|
||
|
this.unexpected();
|
||
|
}
|
||
|
var codePos = ++this.pos;
|
||
|
code = this.readHexChar(this.input.indexOf("}", this.pos) - this.pos);
|
||
|
++this.pos;
|
||
|
if (code > 1114111) {
|
||
|
this.invalidStringToken(codePos, "Code point out of bounds");
|
||
|
}
|
||
|
} else {
|
||
|
code = this.readHexChar(4);
|
||
|
}
|
||
|
return code;
|
||
|
};
|
||
|
pp.readString = function(quote) {
|
||
|
var out = "", chunkStart = ++this.pos;
|
||
|
for (; ; ) {
|
||
|
if (this.pos >= this.input.length) {
|
||
|
this.raise(this.start, "Unterminated string constant");
|
||
|
}
|
||
|
var ch = this.input.charCodeAt(this.pos);
|
||
|
if (ch === quote) {
|
||
|
break;
|
||
|
}
|
||
|
if (ch === 92) {
|
||
|
out += this.input.slice(chunkStart, this.pos);
|
||
|
out += this.readEscapedChar(false);
|
||
|
chunkStart = this.pos;
|
||
|
} else if (ch === 8232 || ch === 8233) {
|
||
|
if (this.options.ecmaVersion < 10) {
|
||
|
this.raise(this.start, "Unterminated string constant");
|
||
|
}
|
||
|
++this.pos;
|
||
|
if (this.options.locations) {
|
||
|
this.curLine++;
|
||
|
this.lineStart = this.pos;
|
||
|
}
|
||
|
} else {
|
||
|
if (isNewLine(ch)) {
|
||
|
this.raise(this.start, "Unterminated string constant");
|
||
|
}
|
||
|
++this.pos;
|
||
|
}
|
||
|
}
|
||
|
out += this.input.slice(chunkStart, this.pos++);
|
||
|
return this.finishToken(types$1.string, out);
|
||
|
};
|
||
|
var INVALID_TEMPLATE_ESCAPE_ERROR = {};
|
||
|
pp.tryReadTemplateToken = function() {
|
||
|
this.inTemplateElement = true;
|
||
|
try {
|
||
|
this.readTmplToken();
|
||
|
} catch (err) {
|
||
|
if (err === INVALID_TEMPLATE_ESCAPE_ERROR) {
|
||
|
this.readInvalidTemplateToken();
|
||
|
} else {
|
||
|
throw err;
|
||
|
}
|
||
|
}
|
||
|
this.inTemplateElement = false;
|
||
|
};
|
||
|
pp.invalidStringToken = function(position, message) {
|
||
|
if (this.inTemplateElement && this.options.ecmaVersion >= 9) {
|
||
|
throw INVALID_TEMPLATE_ESCAPE_ERROR;
|
||
|
} else {
|
||
|
this.raise(position, message);
|
||
|
}
|
||
|
};
|
||
|
pp.readTmplToken = function() {
|
||
|
var out = "", chunkStart = this.pos;
|
||
|
for (; ; ) {
|
||
|
if (this.pos >= this.input.length) {
|
||
|
this.raise(this.start, "Unterminated template");
|
||
|
}
|
||
|
var ch = this.input.charCodeAt(this.pos);
|
||
|
if (ch === 96 || ch === 36 && this.input.charCodeAt(this.pos + 1) === 123) {
|
||
|
if (this.pos === this.start && (this.type === types$1.template || this.type === types$1.invalidTemplate)) {
|
||
|
if (ch === 36) {
|
||
|
this.pos += 2;
|
||
|
return this.finishToken(types$1.dollarBraceL);
|
||
|
} else {
|
||
|
++this.pos;
|
||
|
return this.finishToken(types$1.backQuote);
|
||
|
}
|
||
|
}
|
||
|
out += this.input.slice(chunkStart, this.pos);
|
||
|
return this.finishToken(types$1.template, out);
|
||
|
}
|
||
|
if (ch === 92) {
|
||
|
out += this.input.slice(chunkStart, this.pos);
|
||
|
out += this.readEscapedChar(true);
|
||
|
chunkStart = this.pos;
|
||
|
} else if (isNewLine(ch)) {
|
||
|
out += this.input.slice(chunkStart, this.pos);
|
||
|
++this.pos;
|
||
|
switch (ch) {
|
||
|
case 13:
|
||
|
if (this.input.charCodeAt(this.pos) === 10) {
|
||
|
++this.pos;
|
||
|
}
|
||
|
case 10:
|
||
|
out += "\n";
|
||
|
break;
|
||
|
default:
|
||
|
out += String.fromCharCode(ch);
|
||
|
break;
|
||
|
}
|
||
|
if (this.options.locations) {
|
||
|
++this.curLine;
|
||
|
this.lineStart = this.pos;
|
||
|
}
|
||
|
chunkStart = this.pos;
|
||
|
} else {
|
||
|
++this.pos;
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
pp.readInvalidTemplateToken = function() {
|
||
|
for (; this.pos < this.input.length; this.pos++) {
|
||
|
switch (this.input[this.pos]) {
|
||
|
case "\\":
|
||
|
++this.pos;
|
||
|
break;
|
||
|
case "$":
|
||
|
if (this.input[this.pos + 1] !== "{") {
|
||
|
break;
|
||
|
}
|
||
|
case "`":
|
||
|
return this.finishToken(types$1.invalidTemplate, this.input.slice(this.start, this.pos));
|
||
|
}
|
||
|
}
|
||
|
this.raise(this.start, "Unterminated template");
|
||
|
};
|
||
|
pp.readEscapedChar = function(inTemplate) {
|
||
|
var ch = this.input.charCodeAt(++this.pos);
|
||
|
++this.pos;
|
||
|
switch (ch) {
|
||
|
case 110:
|
||
|
return "\n";
|
||
|
case 114:
|
||
|
return "\r";
|
||
|
case 120:
|
||
|
return String.fromCharCode(this.readHexChar(2));
|
||
|
case 117:
|
||
|
return codePointToString(this.readCodePoint());
|
||
|
case 116:
|
||
|
return " ";
|
||
|
case 98:
|
||
|
return "\b";
|
||
|
case 118:
|
||
|
return "\v";
|
||
|
case 102:
|
||
|
return "\f";
|
||
|
case 13:
|
||
|
if (this.input.charCodeAt(this.pos) === 10) {
|
||
|
++this.pos;
|
||
|
}
|
||
|
case 10:
|
||
|
if (this.options.locations) {
|
||
|
this.lineStart = this.pos;
|
||
|
++this.curLine;
|
||
|
}
|
||
|
return "";
|
||
|
case 56:
|
||
|
case 57:
|
||
|
if (this.strict) {
|
||
|
this.invalidStringToken(
|
||
|
this.pos - 1,
|
||
|
"Invalid escape sequence"
|
||
|
);
|
||
|
}
|
||
|
if (inTemplate) {
|
||
|
var codePos = this.pos - 1;
|
||
|
this.invalidStringToken(
|
||
|
codePos,
|
||
|
"Invalid escape sequence in template string"
|
||
|
);
|
||
|
return null;
|
||
|
}
|
||
|
default:
|
||
|
if (ch >= 48 && ch <= 55) {
|
||
|
var octalStr = this.input.substr(this.pos - 1, 3).match(/^[0-7]+/)[0];
|
||
|
var octal = parseInt(octalStr, 8);
|
||
|
if (octal > 255) {
|
||
|
octalStr = octalStr.slice(0, -1);
|
||
|
octal = parseInt(octalStr, 8);
|
||
|
}
|
||
|
this.pos += octalStr.length - 1;
|
||
|
ch = this.input.charCodeAt(this.pos);
|
||
|
if ((octalStr !== "0" || ch === 56 || ch === 57) && (this.strict || inTemplate)) {
|
||
|
this.invalidStringToken(
|
||
|
this.pos - 1 - octalStr.length,
|
||
|
inTemplate ? "Octal literal in template string" : "Octal literal in strict mode"
|
||
|
);
|
||
|
}
|
||
|
return String.fromCharCode(octal);
|
||
|
}
|
||
|
if (isNewLine(ch)) {
|
||
|
return "";
|
||
|
}
|
||
|
return String.fromCharCode(ch);
|
||
|
}
|
||
|
};
|
||
|
pp.readHexChar = function(len) {
|
||
|
var codePos = this.pos;
|
||
|
var n = this.readInt(16, len);
|
||
|
if (n === null) {
|
||
|
this.invalidStringToken(codePos, "Bad character escape sequence");
|
||
|
}
|
||
|
return n;
|
||
|
};
|
||
|
pp.readWord1 = function() {
|
||
|
this.containsEsc = false;
|
||
|
var word = "", first = true, chunkStart = this.pos;
|
||
|
var astral = this.options.ecmaVersion >= 6;
|
||
|
while (this.pos < this.input.length) {
|
||
|
var ch = this.fullCharCodeAtPos();
|
||
|
if (isIdentifierChar(ch, astral)) {
|
||
|
this.pos += ch <= 65535 ? 1 : 2;
|
||
|
} else if (ch === 92) {
|
||
|
this.containsEsc = true;
|
||
|
word += this.input.slice(chunkStart, this.pos);
|
||
|
var escStart = this.pos;
|
||
|
if (this.input.charCodeAt(++this.pos) !== 117) {
|
||
|
this.invalidStringToken(this.pos, "Expecting Unicode escape sequence \\uXXXX");
|
||
|
}
|
||
|
++this.pos;
|
||
|
var esc = this.readCodePoint();
|
||
|
if (!(first ? isIdentifierStart : isIdentifierChar)(esc, astral)) {
|
||
|
this.invalidStringToken(escStart, "Invalid Unicode escape");
|
||
|
}
|
||
|
word += codePointToString(esc);
|
||
|
chunkStart = this.pos;
|
||
|
} else {
|
||
|
break;
|
||
|
}
|
||
|
first = false;
|
||
|
}
|
||
|
return word + this.input.slice(chunkStart, this.pos);
|
||
|
};
|
||
|
pp.readWord = function() {
|
||
|
var word = this.readWord1();
|
||
|
var type = types$1.name;
|
||
|
if (this.keywords.test(word)) {
|
||
|
type = keywords[word];
|
||
|
}
|
||
|
return this.finishToken(type, word);
|
||
|
};
|
||
|
var version = "8.8.0";
|
||
|
Parser.acorn = {
|
||
|
Parser,
|
||
|
version,
|
||
|
defaultOptions,
|
||
|
Position,
|
||
|
SourceLocation,
|
||
|
getLineInfo,
|
||
|
Node,
|
||
|
TokenType,
|
||
|
tokTypes: types$1,
|
||
|
keywordTypes: keywords,
|
||
|
TokContext,
|
||
|
tokContexts: types,
|
||
|
isIdentifierChar,
|
||
|
isIdentifierStart,
|
||
|
Token,
|
||
|
isNewLine,
|
||
|
lineBreak,
|
||
|
lineBreakG,
|
||
|
nonASCIIwhitespace
|
||
|
};
|
||
|
const BUILTIN_MODULES = new Set(builtinModules);
|
||
|
const isWindows$1 = process.platform === "win32";
|
||
|
const own$1 = {}.hasOwnProperty;
|
||
|
const messages = /* @__PURE__ */ new Map();
|
||
|
const nodeInternalPrefix = "__node_internal_";
|
||
|
let userStackTraceLimit;
|
||
|
createError(
|
||
|
"ERR_INVALID_MODULE_SPECIFIER",
|
||
|
(request, reason, base = void 0) => {
|
||
|
return `Invalid module "${request}" ${reason}${base ? ` imported from ${base}` : ""}`;
|
||
|
},
|
||
|
TypeError
|
||
|
);
|
||
|
createError(
|
||
|
"ERR_INVALID_PACKAGE_CONFIG",
|
||
|
(path2, base, message) => {
|
||
|
return `Invalid package config ${path2}${base ? ` while importing ${base}` : ""}${message ? `. ${message}` : ""}`;
|
||
|
},
|
||
|
Error
|
||
|
);
|
||
|
createError(
|
||
|
"ERR_INVALID_PACKAGE_TARGET",
|
||
|
(pkgPath, key, target, isImport = false, base = void 0) => {
|
||
|
const relError = typeof target === "string" && !isImport && target.length > 0 && !target.startsWith("./");
|
||
|
if (key === ".") {
|
||
|
assert(isImport === false);
|
||
|
return `Invalid "exports" main target ${JSON.stringify(target)} defined in the package config ${pkgPath}package.json${base ? ` imported from ${base}` : ""}${relError ? '; targets must start with "./"' : ""}`;
|
||
|
}
|
||
|
return `Invalid "${isImport ? "imports" : "exports"}" target ${JSON.stringify(
|
||
|
target
|
||
|
)} defined for '${key}' in the package config ${pkgPath}package.json${base ? ` imported from ${base}` : ""}${relError ? '; targets must start with "./"' : ""}`;
|
||
|
},
|
||
|
Error
|
||
|
);
|
||
|
createError(
|
||
|
"ERR_MODULE_NOT_FOUND",
|
||
|
(path2, base, type = "package") => {
|
||
|
return `Cannot find ${type} '${path2}' imported from ${base}`;
|
||
|
},
|
||
|
Error
|
||
|
);
|
||
|
createError(
|
||
|
"ERR_PACKAGE_IMPORT_NOT_DEFINED",
|
||
|
(specifier, packagePath, base) => {
|
||
|
return `Package import specifier "${specifier}" is not defined${packagePath ? ` in package ${packagePath}package.json` : ""} imported from ${base}`;
|
||
|
},
|
||
|
TypeError
|
||
|
);
|
||
|
createError(
|
||
|
"ERR_PACKAGE_PATH_NOT_EXPORTED",
|
||
|
(pkgPath, subpath, base = void 0) => {
|
||
|
if (subpath === ".") {
|
||
|
return `No "exports" main defined in ${pkgPath}package.json${base ? ` imported from ${base}` : ""}`;
|
||
|
}
|
||
|
return `Package subpath '${subpath}' is not defined by "exports" in ${pkgPath}package.json${base ? ` imported from ${base}` : ""}`;
|
||
|
},
|
||
|
Error
|
||
|
);
|
||
|
createError(
|
||
|
"ERR_UNSUPPORTED_DIR_IMPORT",
|
||
|
"Directory import '%s' is not supported resolving ES modules imported from %s",
|
||
|
Error
|
||
|
);
|
||
|
createError(
|
||
|
"ERR_UNKNOWN_FILE_EXTENSION",
|
||
|
'Unknown file extension "%s" for %s',
|
||
|
TypeError
|
||
|
);
|
||
|
createError(
|
||
|
"ERR_INVALID_ARG_VALUE",
|
||
|
(name, value, reason = "is invalid") => {
|
||
|
let inspected = inspect(value);
|
||
|
if (inspected.length > 128) {
|
||
|
inspected = `${inspected.slice(0, 128)}...`;
|
||
|
}
|
||
|
const type = name.includes(".") ? "property" : "argument";
|
||
|
return `The ${type} '${name}' ${reason}. Received ${inspected}`;
|
||
|
},
|
||
|
TypeError
|
||
|
);
|
||
|
createError(
|
||
|
"ERR_UNSUPPORTED_ESM_URL_SCHEME",
|
||
|
(url) => {
|
||
|
let message = "Only file and data URLs are supported by the default ESM loader";
|
||
|
if (isWindows$1 && url.protocol.length === 2) {
|
||
|
message += ". On Windows, absolute paths must be valid file:// URLs";
|
||
|
}
|
||
|
message += `. Received protocol '${url.protocol}'`;
|
||
|
return message;
|
||
|
},
|
||
|
Error
|
||
|
);
|
||
|
function createError(sym, value, def) {
|
||
|
messages.set(sym, value);
|
||
|
return makeNodeErrorWithCode(def, sym);
|
||
|
}
|
||
|
function makeNodeErrorWithCode(Base, key) {
|
||
|
return NodeError;
|
||
|
function NodeError(...args) {
|
||
|
const limit = Error.stackTraceLimit;
|
||
|
if (isErrorStackTraceLimitWritable()) {
|
||
|
Error.stackTraceLimit = 0;
|
||
|
}
|
||
|
const error = new Base();
|
||
|
if (isErrorStackTraceLimitWritable()) {
|
||
|
Error.stackTraceLimit = limit;
|
||
|
}
|
||
|
const message = getMessage(key, args, error);
|
||
|
Object.defineProperty(error, "message", {
|
||
|
value: message,
|
||
|
enumerable: false,
|
||
|
writable: true,
|
||
|
configurable: true
|
||
|
});
|
||
|
Object.defineProperty(error, "toString", {
|
||
|
value() {
|
||
|
return `${this.name} [${key}]: ${this.message}`;
|
||
|
},
|
||
|
enumerable: false,
|
||
|
writable: true,
|
||
|
configurable: true
|
||
|
});
|
||
|
addCodeToName(error, Base.name, key);
|
||
|
error.code = key;
|
||
|
return error;
|
||
|
}
|
||
|
}
|
||
|
const addCodeToName = hideStackFrames(
|
||
|
function(error, name, code) {
|
||
|
error = captureLargerStackTrace(error);
|
||
|
error.name = `${name} [${code}]`;
|
||
|
error.stack;
|
||
|
if (name === "SystemError") {
|
||
|
Object.defineProperty(error, "name", {
|
||
|
value: name,
|
||
|
enumerable: false,
|
||
|
writable: true,
|
||
|
configurable: true
|
||
|
});
|
||
|
} else {
|
||
|
delete error.name;
|
||
|
}
|
||
|
}
|
||
|
);
|
||
|
function isErrorStackTraceLimitWritable() {
|
||
|
const desc = Object.getOwnPropertyDescriptor(Error, "stackTraceLimit");
|
||
|
if (desc === void 0) {
|
||
|
return Object.isExtensible(Error);
|
||
|
}
|
||
|
return own$1.call(desc, "writable") ? desc.writable : desc.set !== void 0;
|
||
|
}
|
||
|
function hideStackFrames(fn) {
|
||
|
const hidden = nodeInternalPrefix + fn.name;
|
||
|
Object.defineProperty(fn, "name", { value: hidden });
|
||
|
return fn;
|
||
|
}
|
||
|
const captureLargerStackTrace = hideStackFrames(
|
||
|
function(error) {
|
||
|
const stackTraceLimitIsWritable = isErrorStackTraceLimitWritable();
|
||
|
if (stackTraceLimitIsWritable) {
|
||
|
userStackTraceLimit = Error.stackTraceLimit;
|
||
|
Error.stackTraceLimit = Number.POSITIVE_INFINITY;
|
||
|
}
|
||
|
Error.captureStackTrace(error);
|
||
|
if (stackTraceLimitIsWritable) {
|
||
|
Error.stackTraceLimit = userStackTraceLimit;
|
||
|
}
|
||
|
return error;
|
||
|
}
|
||
|
);
|
||
|
function getMessage(key, args, self) {
|
||
|
const message = messages.get(key);
|
||
|
if (typeof message === "function") {
|
||
|
assert(
|
||
|
message.length <= args.length,
|
||
|
`Code: ${key}; The provided arguments length (${args.length}) does not match the required ones (${message.length}).`
|
||
|
);
|
||
|
return Reflect.apply(message, self, args);
|
||
|
}
|
||
|
const expectedLength = (message.match(/%[dfijoOs]/g) || []).length;
|
||
|
assert(
|
||
|
expectedLength === args.length,
|
||
|
`Code: ${key}; The provided arguments length (${args.length}) does not match the required ones (${expectedLength}).`
|
||
|
);
|
||
|
if (args.length === 0) {
|
||
|
return message;
|
||
|
}
|
||
|
args.unshift(message);
|
||
|
return Reflect.apply(format$1, null, args);
|
||
|
}
|
||
|
Object.freeze(["node", "import"]);
|
||
|
function isNodeBuiltin(id = "") {
|
||
|
id = id.replace(/^node:/, "").split("/")[0];
|
||
|
return BUILTIN_MODULES.has(id);
|
||
|
}
|
||
|
pathToFileURL(process.cwd());
|
||
|
var browser = { exports: {} };
|
||
|
var ms;
|
||
|
var hasRequiredMs;
|
||
|
function requireMs() {
|
||
|
if (hasRequiredMs)
|
||
|
return ms;
|
||
|
hasRequiredMs = 1;
|
||
|
var s = 1e3;
|
||
|
var m = s * 60;
|
||
|
var h = m * 60;
|
||
|
var d = h * 24;
|
||
|
var w = d * 7;
|
||
|
var y = d * 365.25;
|
||
|
ms = function(val, options) {
|
||
|
options = options || {};
|
||
|
var type = typeof val;
|
||
|
if (type === "string" && val.length > 0) {
|
||
|
return parse4(val);
|
||
|
} else if (type === "number" && isFinite(val)) {
|
||
|
return options.long ? fmtLong(val) : fmtShort(val);
|
||
|
}
|
||
|
throw new Error(
|
||
|
"val is not a non-empty string or a valid number. val=" + JSON.stringify(val)
|
||
|
);
|
||
|
};
|
||
|
function parse4(str) {
|
||
|
str = String(str);
|
||
|
if (str.length > 100) {
|
||
|
return;
|
||
|
}
|
||
|
var match = /^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(
|
||
|
str
|
||
|
);
|
||
|
if (!match) {
|
||
|
return;
|
||
|
}
|
||
|
var n = parseFloat(match[1]);
|
||
|
var type = (match[2] || "ms").toLowerCase();
|
||
|
switch (type) {
|
||
|
case "years":
|
||
|
case "year":
|
||
|
case "yrs":
|
||
|
case "yr":
|
||
|
case "y":
|
||
|
return n * y;
|
||
|
case "weeks":
|
||
|
case "week":
|
||
|
case "w":
|
||
|
return n * w;
|
||
|
case "days":
|
||
|
case "day":
|
||
|
case "d":
|
||
|
return n * d;
|
||
|
case "hours":
|
||
|
case "hour":
|
||
|
case "hrs":
|
||
|
case "hr":
|
||
|
case "h":
|
||
|
return n * h;
|
||
|
case "minutes":
|
||
|
case "minute":
|
||
|
case "mins":
|
||
|
case "min":
|
||
|
case "m":
|
||
|
return n * m;
|
||
|
case "seconds":
|
||
|
case "second":
|
||
|
case "secs":
|
||
|
case "sec":
|
||
|
case "s":
|
||
|
return n * s;
|
||
|
case "milliseconds":
|
||
|
case "millisecond":
|
||
|
case "msecs":
|
||
|
case "msec":
|
||
|
case "ms":
|
||
|
return n;
|
||
|
default:
|
||
|
return void 0;
|
||
|
}
|
||
|
}
|
||
|
function fmtShort(ms2) {
|
||
|
var msAbs = Math.abs(ms2);
|
||
|
if (msAbs >= d) {
|
||
|
return Math.round(ms2 / d) + "d";
|
||
|
}
|
||
|
if (msAbs >= h) {
|
||
|
return Math.round(ms2 / h) + "h";
|
||
|
}
|
||
|
if (msAbs >= m) {
|
||
|
return Math.round(ms2 / m) + "m";
|
||
|
}
|
||
|
if (msAbs >= s) {
|
||
|
return Math.round(ms2 / s) + "s";
|
||
|
}
|
||
|
return ms2 + "ms";
|
||
|
}
|
||
|
function fmtLong(ms2) {
|
||
|
var msAbs = Math.abs(ms2);
|
||
|
if (msAbs >= d) {
|
||
|
return plural(ms2, msAbs, d, "day");
|
||
|
}
|
||
|
if (msAbs >= h) {
|
||
|
return plural(ms2, msAbs, h, "hour");
|
||
|
}
|
||
|
if (msAbs >= m) {
|
||
|
return plural(ms2, msAbs, m, "minute");
|
||
|
}
|
||
|
if (msAbs >= s) {
|
||
|
return plural(ms2, msAbs, s, "second");
|
||
|
}
|
||
|
return ms2 + " ms";
|
||
|
}
|
||
|
function plural(ms2, msAbs, n, name) {
|
||
|
var isPlural = msAbs >= n * 1.5;
|
||
|
return Math.round(ms2 / n) + " " + name + (isPlural ? "s" : "");
|
||
|
}
|
||
|
return ms;
|
||
|
}
|
||
|
function setup(env) {
|
||
|
createDebug2.debug = createDebug2;
|
||
|
createDebug2.default = createDebug2;
|
||
|
createDebug2.coerce = coerce;
|
||
|
createDebug2.disable = disable;
|
||
|
createDebug2.enable = enable;
|
||
|
createDebug2.enabled = enabled;
|
||
|
createDebug2.humanize = requireMs();
|
||
|
createDebug2.destroy = destroy;
|
||
|
Object.keys(env).forEach((key) => {
|
||
|
createDebug2[key] = env[key];
|
||
|
});
|
||
|
createDebug2.names = [];
|
||
|
createDebug2.skips = [];
|
||
|
createDebug2.formatters = {};
|
||
|
function selectColor(namespace) {
|
||
|
let hash = 0;
|
||
|
for (let i = 0; i < namespace.length; i++) {
|
||
|
hash = (hash << 5) - hash + namespace.charCodeAt(i);
|
||
|
hash |= 0;
|
||
|
}
|
||
|
return createDebug2.colors[Math.abs(hash) % createDebug2.colors.length];
|
||
|
}
|
||
|
createDebug2.selectColor = selectColor;
|
||
|
function createDebug2(namespace) {
|
||
|
let prevTime;
|
||
|
let enableOverride = null;
|
||
|
let namespacesCache;
|
||
|
let enabledCache;
|
||
|
function debug(...args) {
|
||
|
if (!debug.enabled) {
|
||
|
return;
|
||
|
}
|
||
|
const self = debug;
|
||
|
const curr = Number(new Date());
|
||
|
const ms2 = curr - (prevTime || curr);
|
||
|
self.diff = ms2;
|
||
|
self.prev = prevTime;
|
||
|
self.curr = curr;
|
||
|
prevTime = curr;
|
||
|
args[0] = createDebug2.coerce(args[0]);
|
||
|
if (typeof args[0] !== "string") {
|
||
|
args.unshift("%O");
|
||
|
}
|
||
|
let index = 0;
|
||
|
args[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format2) => {
|
||
|
if (match === "%%") {
|
||
|
return "%";
|
||
|
}
|
||
|
index++;
|
||
|
const formatter = createDebug2.formatters[format2];
|
||
|
if (typeof formatter === "function") {
|
||
|
const val = args[index];
|
||
|
match = formatter.call(self, val);
|
||
|
args.splice(index, 1);
|
||
|
index--;
|
||
|
}
|
||
|
return match;
|
||
|
});
|
||
|
createDebug2.formatArgs.call(self, args);
|
||
|
const logFn = self.log || createDebug2.log;
|
||
|
logFn.apply(self, args);
|
||
|
}
|
||
|
debug.namespace = namespace;
|
||
|
debug.useColors = createDebug2.useColors();
|
||
|
debug.color = createDebug2.selectColor(namespace);
|
||
|
debug.extend = extend2;
|
||
|
debug.destroy = createDebug2.destroy;
|
||
|
Object.defineProperty(debug, "enabled", {
|
||
|
enumerable: true,
|
||
|
configurable: false,
|
||
|
get: () => {
|
||
|
if (enableOverride !== null) {
|
||
|
return enableOverride;
|
||
|
}
|
||
|
if (namespacesCache !== createDebug2.namespaces) {
|
||
|
namespacesCache = createDebug2.namespaces;
|
||
|
enabledCache = createDebug2.enabled(namespace);
|
||
|
}
|
||
|
return enabledCache;
|
||
|
},
|
||
|
set: (v) => {
|
||
|
enableOverride = v;
|
||
|
}
|
||
|
});
|
||
|
if (typeof createDebug2.init === "function") {
|
||
|
createDebug2.init(debug);
|
||
|
}
|
||
|
return debug;
|
||
|
}
|
||
|
function extend2(namespace, delimiter2) {
|
||
|
const newDebug = createDebug2(this.namespace + (typeof delimiter2 === "undefined" ? ":" : delimiter2) + namespace);
|
||
|
newDebug.log = this.log;
|
||
|
return newDebug;
|
||
|
}
|
||
|
function enable(namespaces) {
|
||
|
createDebug2.save(namespaces);
|
||
|
createDebug2.namespaces = namespaces;
|
||
|
createDebug2.names = [];
|
||
|
createDebug2.skips = [];
|
||
|
let i;
|
||
|
const split = (typeof namespaces === "string" ? namespaces : "").split(/[\s,]+/);
|
||
|
const len = split.length;
|
||
|
for (i = 0; i < len; i++) {
|
||
|
if (!split[i]) {
|
||
|
continue;
|
||
|
}
|
||
|
namespaces = split[i].replace(/\*/g, ".*?");
|
||
|
if (namespaces[0] === "-") {
|
||
|
createDebug2.skips.push(new RegExp("^" + namespaces.slice(1) + "$"));
|
||
|
} else {
|
||
|
createDebug2.names.push(new RegExp("^" + namespaces + "$"));
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
function disable() {
|
||
|
const namespaces = [
|
||
|
...createDebug2.names.map(toNamespace),
|
||
|
...createDebug2.skips.map(toNamespace).map((namespace) => "-" + namespace)
|
||
|
].join(",");
|
||
|
createDebug2.enable("");
|
||
|
return namespaces;
|
||
|
}
|
||
|
function enabled(name) {
|
||
|
if (name[name.length - 1] === "*") {
|
||
|
return true;
|
||
|
}
|
||
|
let i;
|
||
|
let len;
|
||
|
for (i = 0, len = createDebug2.skips.length; i < len; i++) {
|
||
|
if (createDebug2.skips[i].test(name)) {
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
for (i = 0, len = createDebug2.names.length; i < len; i++) {
|
||
|
if (createDebug2.names[i].test(name)) {
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
return false;
|
||
|
}
|
||
|
function toNamespace(regexp) {
|
||
|
return regexp.toString().substring(2, regexp.toString().length - 2).replace(/\.\*\?$/, "*");
|
||
|
}
|
||
|
function coerce(val) {
|
||
|
if (val instanceof Error) {
|
||
|
return val.stack || val.message;
|
||
|
}
|
||
|
return val;
|
||
|
}
|
||
|
function destroy() {
|
||
|
console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.");
|
||
|
}
|
||
|
createDebug2.enable(createDebug2.load());
|
||
|
return createDebug2;
|
||
|
}
|
||
|
var common = setup;
|
||
|
(function(module, exports) {
|
||
|
exports.formatArgs = formatArgs;
|
||
|
exports.save = save;
|
||
|
exports.load = load;
|
||
|
exports.useColors = useColors;
|
||
|
exports.storage = localstorage();
|
||
|
exports.destroy = (() => {
|
||
|
let warned = false;
|
||
|
return () => {
|
||
|
if (!warned) {
|
||
|
warned = true;
|
||
|
console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.");
|
||
|
}
|
||
|
};
|
||
|
})();
|
||
|
exports.colors = [
|
||
|
"#0000CC",
|
||
|
"#0000FF",
|
||
|
"#0033CC",
|
||
|
"#0033FF",
|
||
|
"#0066CC",
|
||
|
"#0066FF",
|
||
|
"#0099CC",
|
||
|
"#0099FF",
|
||
|
"#00CC00",
|
||
|
"#00CC33",
|
||
|
"#00CC66",
|
||
|
"#00CC99",
|
||
|
"#00CCCC",
|
||
|
"#00CCFF",
|
||
|
"#3300CC",
|
||
|
"#3300FF",
|
||
|
"#3333CC",
|
||
|
"#3333FF",
|
||
|
"#3366CC",
|
||
|
"#3366FF",
|
||
|
"#3399CC",
|
||
|
"#3399FF",
|
||
|
"#33CC00",
|
||
|
"#33CC33",
|
||
|
"#33CC66",
|
||
|
"#33CC99",
|
||
|
"#33CCCC",
|
||
|
"#33CCFF",
|
||
|
"#6600CC",
|
||
|
"#6600FF",
|
||
|
"#6633CC",
|
||
|
"#6633FF",
|
||
|
"#66CC00",
|
||
|
"#66CC33",
|
||
|
"#9900CC",
|
||
|
"#9900FF",
|
||
|
"#9933CC",
|
||
|
"#9933FF",
|
||
|
"#99CC00",
|
||
|
"#99CC33",
|
||
|
"#CC0000",
|
||
|
"#CC0033",
|
||
|
"#CC0066",
|
||
|
"#CC0099",
|
||
|
"#CC00CC",
|
||
|
"#CC00FF",
|
||
|
"#CC3300",
|
||
|
"#CC3333",
|
||
|
"#CC3366",
|
||
|
"#CC3399",
|
||
|
"#CC33CC",
|
||
|
"#CC33FF",
|
||
|
"#CC6600",
|
||
|
"#CC6633",
|
||
|
"#CC9900",
|
||
|
"#CC9933",
|
||
|
"#CCCC00",
|
||
|
"#CCCC33",
|
||
|
"#FF0000",
|
||
|
"#FF0033",
|
||
|
"#FF0066",
|
||
|
"#FF0099",
|
||
|
"#FF00CC",
|
||
|
"#FF00FF",
|
||
|
"#FF3300",
|
||
|
"#FF3333",
|
||
|
"#FF3366",
|
||
|
"#FF3399",
|
||
|
"#FF33CC",
|
||
|
"#FF33FF",
|
||
|
"#FF6600",
|
||
|
"#FF6633",
|
||
|
"#FF9900",
|
||
|
"#FF9933",
|
||
|
"#FFCC00",
|
||
|
"#FFCC33"
|
||
|
];
|
||
|
function useColors() {
|
||
|
if (typeof window !== "undefined" && window.process && (window.process.type === "renderer" || window.process.__nwjs)) {
|
||
|
return true;
|
||
|
}
|
||
|
if (typeof navigator !== "undefined" && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)) {
|
||
|
return false;
|
||
|
}
|
||
|
return typeof document !== "undefined" && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance || typeof window !== "undefined" && window.console && (window.console.firebug || window.console.exception && window.console.table) || typeof navigator !== "undefined" && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31 || typeof navigator !== "undefined" && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/);
|
||
|
}
|
||
|
function formatArgs(args) {
|
||
|
args[0] = (this.useColors ? "%c" : "") + this.namespace + (this.useColors ? " %c" : " ") + args[0] + (this.useColors ? "%c " : " ") + "+" + module.exports.humanize(this.diff);
|
||
|
if (!this.useColors) {
|
||
|
return;
|
||
|
}
|
||
|
const c = "color: " + this.color;
|
||
|
args.splice(1, 0, c, "color: inherit");
|
||
|
let index = 0;
|
||
|
let lastC = 0;
|
||
|
args[0].replace(/%[a-zA-Z%]/g, (match) => {
|
||
|
if (match === "%%") {
|
||
|
return;
|
||
|
}
|
||
|
index++;
|
||
|
if (match === "%c") {
|
||
|
lastC = index;
|
||
|
}
|
||
|
});
|
||
|
args.splice(lastC, 0, c);
|
||
|
}
|
||
|
exports.log = console.debug || console.log || (() => {
|
||
|
});
|
||
|
function save(namespaces) {
|
||
|
try {
|
||
|
if (namespaces) {
|
||
|
exports.storage.setItem("debug", namespaces);
|
||
|
} else {
|
||
|
exports.storage.removeItem("debug");
|
||
|
}
|
||
|
} catch (error) {
|
||
|
}
|
||
|
}
|
||
|
function load() {
|
||
|
let r;
|
||
|
try {
|
||
|
r = exports.storage.getItem("debug");
|
||
|
} catch (error) {
|
||
|
}
|
||
|
if (!r && typeof process !== "undefined" && "env" in process) {
|
||
|
r = process.env.DEBUG;
|
||
|
}
|
||
|
return r;
|
||
|
}
|
||
|
function localstorage() {
|
||
|
try {
|
||
|
return localStorage;
|
||
|
} catch (error) {
|
||
|
}
|
||
|
}
|
||
|
module.exports = common(exports);
|
||
|
const { formatters } = module.exports;
|
||
|
formatters.j = function(v) {
|
||
|
try {
|
||
|
return JSON.stringify(v);
|
||
|
} catch (error) {
|
||
|
return "[UnexpectedJSONParseError]: " + error.message;
|
||
|
}
|
||
|
};
|
||
|
})(browser, browser.exports);
|
||
|
const createDebug = browser.exports;
|
||
|
const isWindows = process.platform === "win32";
|
||
|
function slash(str) {
|
||
|
return str.replace(/\\/g, "/");
|
||
|
}
|
||
|
function mergeSlashes(str) {
|
||
|
return str.replace(/\/\//g, "/");
|
||
|
}
|
||
|
function normalizeRequestId(id, base) {
|
||
|
if (base && id.startsWith(base))
|
||
|
id = `/${id.slice(base.length)}`;
|
||
|
return id.replace(/^\/@id\/__x00__/, "\0").replace(/^\/@id\//, "").replace(/^__vite-browser-external:/, "").replace(/^(node|file):/, "").replace(/^\/+/, "/").replace(/\?v=\w+/, "?").replace(/&v=\w+/, "").replace(/\?t=\w+/, "?").replace(/&t=\w+/, "").replace(/\?import/, "?").replace(/&import/, "").replace(/\?&/, "?").replace(/\?+$/, "");
|
||
|
}
|
||
|
function normalizeModuleId(id) {
|
||
|
return id.replace(/\\/g, "/").replace(/^\/@fs\//, "/").replace(/^file:\//, "/").replace(/^\/+/, "/");
|
||
|
}
|
||
|
function isPrimitive(v) {
|
||
|
return v !== Object(v);
|
||
|
}
|
||
|
function toFilePath(id, root) {
|
||
|
let absolute = id.startsWith("/@fs/") ? id.slice(4) : id.startsWith(root) ? id : id.startsWith("/") ? resolve(root, id.slice(1)) : id;
|
||
|
if (absolute.startsWith("//"))
|
||
|
absolute = absolute.slice(1);
|
||
|
return isWindows && absolute.startsWith("/") ? slash(fileURLToPath(pathToFileURL(absolute.slice(1)).href)) : absolute;
|
||
|
}
|
||
|
const debugExecute = createDebug("vite-node:client:execute");
|
||
|
const debugNative = createDebug("vite-node:client:native");
|
||
|
const DEFAULT_REQUEST_STUBS = {
|
||
|
"/@vite/client": {
|
||
|
injectQuery: (id) => id,
|
||
|
createHotContext() {
|
||
|
return {
|
||
|
accept: () => {
|
||
|
},
|
||
|
prune: () => {
|
||
|
},
|
||
|
dispose: () => {
|
||
|
},
|
||
|
decline: () => {
|
||
|
},
|
||
|
invalidate: () => {
|
||
|
},
|
||
|
on: () => {
|
||
|
}
|
||
|
};
|
||
|
},
|
||
|
updateStyle(id, css) {
|
||
|
if (typeof document === "undefined")
|
||
|
return;
|
||
|
const element = document.getElementById(id);
|
||
|
if (element)
|
||
|
element.remove();
|
||
|
const head = document.querySelector("head");
|
||
|
const style = document.createElement("style");
|
||
|
style.setAttribute("type", "text/css");
|
||
|
style.id = id;
|
||
|
style.innerHTML = css;
|
||
|
head == null ? void 0 : head.appendChild(style);
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
class ModuleCacheMap extends Map {
|
||
|
normalizePath(fsPath) {
|
||
|
return normalizeModuleId(fsPath);
|
||
|
}
|
||
|
update(fsPath, mod) {
|
||
|
fsPath = this.normalizePath(fsPath);
|
||
|
if (!super.has(fsPath))
|
||
|
super.set(fsPath, mod);
|
||
|
else
|
||
|
Object.assign(super.get(fsPath), mod);
|
||
|
return this;
|
||
|
}
|
||
|
set(fsPath, mod) {
|
||
|
fsPath = this.normalizePath(fsPath);
|
||
|
return super.set(fsPath, mod);
|
||
|
}
|
||
|
get(fsPath) {
|
||
|
fsPath = this.normalizePath(fsPath);
|
||
|
if (!super.has(fsPath))
|
||
|
super.set(fsPath, {});
|
||
|
return super.get(fsPath);
|
||
|
}
|
||
|
delete(fsPath) {
|
||
|
fsPath = this.normalizePath(fsPath);
|
||
|
return super.delete(fsPath);
|
||
|
}
|
||
|
invalidateDepTree(ids, invalidated = /* @__PURE__ */ new Set()) {
|
||
|
for (const _id of ids) {
|
||
|
const id = this.normalizePath(_id);
|
||
|
if (invalidated.has(id))
|
||
|
continue;
|
||
|
invalidated.add(id);
|
||
|
const mod = super.get(id);
|
||
|
if (mod == null ? void 0 : mod.importers)
|
||
|
this.invalidateDepTree(mod.importers, invalidated);
|
||
|
super.delete(id);
|
||
|
}
|
||
|
return invalidated;
|
||
|
}
|
||
|
invalidateSubDepTree(ids, invalidated = /* @__PURE__ */ new Set()) {
|
||
|
for (const _id of ids) {
|
||
|
const id = this.normalizePath(_id);
|
||
|
if (invalidated.has(id))
|
||
|
continue;
|
||
|
invalidated.add(id);
|
||
|
const subIds = Array.from(super.entries()).filter(([, mod]) => {
|
||
|
var _a;
|
||
|
return (_a = mod.importers) == null ? void 0 : _a.has(id);
|
||
|
}).map(([key]) => key);
|
||
|
subIds.length && this.invalidateSubDepTree(subIds, invalidated);
|
||
|
super.delete(id);
|
||
|
}
|
||
|
return invalidated;
|
||
|
}
|
||
|
}
|
||
|
class ViteNodeRunner {
|
||
|
constructor(options) {
|
||
|
this.options = options;
|
||
|
this.root = options.root ?? process.cwd();
|
||
|
this.moduleCache = options.moduleCache ?? new ModuleCacheMap();
|
||
|
this.debug = options.debug ?? (typeof process !== "undefined" ? !!process.env.VITE_NODE_DEBUG_RUNNER : false);
|
||
|
}
|
||
|
async executeFile(file) {
|
||
|
return await this.cachedRequest(`/@fs/${slash(resolve(file))}`, []);
|
||
|
}
|
||
|
async executeId(id) {
|
||
|
return await this.cachedRequest(id, []);
|
||
|
}
|
||
|
async cachedRequest(rawId, callstack) {
|
||
|
const id = normalizeRequestId(rawId, this.options.base);
|
||
|
const fsPath = toFilePath(id, this.root);
|
||
|
const mod = this.moduleCache.get(fsPath);
|
||
|
const importee = callstack[callstack.length - 1];
|
||
|
if (!mod.importers)
|
||
|
mod.importers = /* @__PURE__ */ new Set();
|
||
|
if (importee)
|
||
|
mod.importers.add(importee);
|
||
|
if (callstack.includes(fsPath) && mod.exports)
|
||
|
return mod.exports;
|
||
|
if (mod.promise)
|
||
|
return mod.promise;
|
||
|
const promise = this.directRequest(id, fsPath, callstack);
|
||
|
Object.assign(mod, { promise });
|
||
|
return await promise;
|
||
|
}
|
||
|
async directRequest(id, fsPath, _callstack) {
|
||
|
const callstack = [..._callstack, fsPath];
|
||
|
const mod = this.moduleCache.get(fsPath);
|
||
|
const request = async (dep) => {
|
||
|
var _a;
|
||
|
const depFsPath = toFilePath(normalizeRequestId(dep, this.options.base), this.root);
|
||
|
const getStack = () => {
|
||
|
return `stack:
|
||
|
${[...callstack, depFsPath].reverse().map((p) => `- ${p}`).join("\n")}`;
|
||
|
};
|
||
|
let debugTimer;
|
||
|
if (this.debug)
|
||
|
debugTimer = setTimeout(() => console.warn(() => `module ${depFsPath} takes over 2s to load.
|
||
|
${getStack()}`), 2e3);
|
||
|
try {
|
||
|
if (callstack.includes(depFsPath)) {
|
||
|
const depExports = (_a = this.moduleCache.get(depFsPath)) == null ? void 0 : _a.exports;
|
||
|
if (depExports)
|
||
|
return depExports;
|
||
|
throw new Error(`[vite-node] Failed to resolve circular dependency, ${getStack()}`);
|
||
|
}
|
||
|
return await this.cachedRequest(dep, callstack);
|
||
|
} finally {
|
||
|
if (debugTimer)
|
||
|
clearTimeout(debugTimer);
|
||
|
}
|
||
|
};
|
||
|
Object.defineProperty(request, "callstack", { get: () => callstack });
|
||
|
const resolveId = async (dep, callstackPosition = 1) => {
|
||
|
if (this.options.resolveId && this.shouldResolveId(dep)) {
|
||
|
let importer = callstack[callstack.length - callstackPosition];
|
||
|
if (importer && importer.startsWith("mock:"))
|
||
|
importer = importer.slice(5);
|
||
|
const { id: id2 } = await this.options.resolveId(dep, importer) || {};
|
||
|
dep = id2 && isAbsolute(id2) ? mergeSlashes(`/@fs/${id2}`) : id2 || dep;
|
||
|
}
|
||
|
return dep;
|
||
|
};
|
||
|
id = await resolveId(id, 2);
|
||
|
const requestStubs = this.options.requestStubs || DEFAULT_REQUEST_STUBS;
|
||
|
if (id in requestStubs)
|
||
|
return requestStubs[id];
|
||
|
let { code: transformed, externalize } = await this.options.fetchModule(id);
|
||
|
if (externalize) {
|
||
|
debugNative(externalize);
|
||
|
const exports2 = await this.interopedImport(externalize);
|
||
|
mod.exports = exports2;
|
||
|
return exports2;
|
||
|
}
|
||
|
if (transformed == null)
|
||
|
throw new Error(`[vite-node] Failed to load ${id}`);
|
||
|
const url = pathToFileURL(fsPath).href;
|
||
|
const meta = { url };
|
||
|
const exports = /* @__PURE__ */ Object.create(null);
|
||
|
Object.defineProperty(exports, Symbol.toStringTag, {
|
||
|
value: "Module",
|
||
|
enumerable: false,
|
||
|
configurable: false
|
||
|
});
|
||
|
const cjsExports = new Proxy(exports, {
|
||
|
get(_, p, receiver) {
|
||
|
return Reflect.get(exports, p, receiver);
|
||
|
},
|
||
|
set(_, p, value) {
|
||
|
if (p !== "default") {
|
||
|
if (!Reflect.has(exports, "default"))
|
||
|
exports.default = {};
|
||
|
if (exports.default === null || typeof exports.default !== "object") {
|
||
|
defineExport(exports, p, () => void 0);
|
||
|
return true;
|
||
|
}
|
||
|
exports.default[p] = value;
|
||
|
defineExport(exports, p, () => value);
|
||
|
return true;
|
||
|
}
|
||
|
return Reflect.set(exports, p, value);
|
||
|
}
|
||
|
});
|
||
|
Object.assign(mod, { code: transformed, exports });
|
||
|
const __filename = fileURLToPath(url);
|
||
|
const moduleProxy = {
|
||
|
set exports(value) {
|
||
|
exportAll(cjsExports, value);
|
||
|
cjsExports.default = value;
|
||
|
},
|
||
|
get exports() {
|
||
|
return cjsExports;
|
||
|
}
|
||
|
};
|
||
|
let hotContext;
|
||
|
if (this.options.createHotContext) {
|
||
|
Object.defineProperty(meta, "hot", {
|
||
|
enumerable: true,
|
||
|
get: () => {
|
||
|
var _a, _b;
|
||
|
hotContext || (hotContext = (_b = (_a = this.options).createHotContext) == null ? void 0 : _b.call(_a, this, `/@fs/${fsPath}`));
|
||
|
return hotContext;
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
const context = this.prepareContext({
|
||
|
__vite_ssr_import__: request,
|
||
|
__vite_ssr_dynamic_import__: request,
|
||
|
__vite_ssr_exports__: exports,
|
||
|
__vite_ssr_exportAll__: (obj) => exportAll(exports, obj),
|
||
|
__vite_ssr_import_meta__: meta,
|
||
|
__vitest_resolve_id__: resolveId,
|
||
|
require: createRequire(url),
|
||
|
exports: cjsExports,
|
||
|
module: moduleProxy,
|
||
|
__filename,
|
||
|
__dirname: dirname(__filename)
|
||
|
});
|
||
|
debugExecute(__filename);
|
||
|
if (transformed[0] === "#")
|
||
|
transformed = transformed.replace(/^\#\!.*/, (s) => " ".repeat(s.length));
|
||
|
const fn = vm.runInThisContext(`'use strict';async (${Object.keys(context).join(",")})=>{{${transformed}
|
||
|
}}`, {
|
||
|
filename: fsPath,
|
||
|
lineOffset: 0
|
||
|
});
|
||
|
await fn(...Object.values(context));
|
||
|
return exports;
|
||
|
}
|
||
|
prepareContext(context) {
|
||
|
return context;
|
||
|
}
|
||
|
shouldResolveId(dep) {
|
||
|
if (isNodeBuiltin(dep) || dep in (this.options.requestStubs || DEFAULT_REQUEST_STUBS) || dep.startsWith("/@vite"))
|
||
|
return false;
|
||
|
return !isAbsolute(dep) || !extname(dep);
|
||
|
}
|
||
|
shouldInterop(path2, mod) {
|
||
|
if (this.options.interopDefault === false)
|
||
|
return false;
|
||
|
return !path2.endsWith(".mjs") && "default" in mod;
|
||
|
}
|
||
|
async interopedImport(path2) {
|
||
|
const mod = await import(path2);
|
||
|
if (this.shouldInterop(path2, mod)) {
|
||
|
const tryDefault = this.hasNestedDefault(mod);
|
||
|
return new Proxy(mod, {
|
||
|
get: proxyMethod("get", tryDefault),
|
||
|
set: proxyMethod("set", tryDefault),
|
||
|
has: proxyMethod("has", tryDefault),
|
||
|
deleteProperty: proxyMethod("deleteProperty", tryDefault)
|
||
|
});
|
||
|
}
|
||
|
return mod;
|
||
|
}
|
||
|
hasNestedDefault(target) {
|
||
|
return "__esModule" in target && target.__esModule && "default" in target.default;
|
||
|
}
|
||
|
}
|
||
|
function proxyMethod(name, tryDefault) {
|
||
|
return function(target, key, ...args) {
|
||
|
const result = Reflect[name](target, key, ...args);
|
||
|
if (isPrimitive(target.default))
|
||
|
return result;
|
||
|
if (tryDefault && key === "default" || typeof result === "undefined")
|
||
|
return Reflect[name](target.default, key, ...args);
|
||
|
return result;
|
||
|
};
|
||
|
}
|
||
|
function defineExport(exports, key, value) {
|
||
|
Object.defineProperty(exports, key, {
|
||
|
enumerable: true,
|
||
|
configurable: true,
|
||
|
get: value
|
||
|
});
|
||
|
}
|
||
|
function exportAll(exports, sourceModule) {
|
||
|
if (exports === sourceModule)
|
||
|
return;
|
||
|
if (typeof sourceModule !== "object" || Array.isArray(sourceModule) || !sourceModule)
|
||
|
return;
|
||
|
for (const key in sourceModule) {
|
||
|
if (key !== "default") {
|
||
|
try {
|
||
|
defineExport(exports, key, () => sourceModule[key]);
|
||
|
} catch (_err) {
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
export {
|
||
|
DEFAULT_REQUEST_STUBS,
|
||
|
ModuleCacheMap,
|
||
|
ViteNodeRunner
|
||
|
};
|